@luanpdd/kit-mcp 1.21.0 → 1.26.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (275) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +914 -648
  3. package/kit/COMANDOS.md +138 -138
  4. package/kit/README.md +76 -52
  5. package/kit/agents/advisor-researcher.md +106 -106
  6. package/kit/agents/assumptions-analyzer.md +107 -107
  7. package/kit/agents/audit-log-implementer.md +138 -0
  8. package/kit/agents/auditor-consistencia-isolamento.md +413 -0
  9. package/kit/agents/codebase-mapper.md +768 -768
  10. package/kit/agents/crm-pipeline-implementer.md +106 -0
  11. package/kit/agents/debugger.md +813 -772
  12. package/kit/agents/detector-tenant-quente.md +337 -0
  13. package/kit/agents/evolution-go-integrator.md +21 -0
  14. package/kit/agents/example-reviewer.md +21 -21
  15. package/kit/agents/executor.md +564 -523
  16. package/kit/agents/integration-checker.md +200 -200
  17. package/kit/agents/invite-flow-implementer.md +52 -0
  18. package/kit/agents/lgpd-compliance-auditor.md +89 -0
  19. package/kit/agents/multi-tenant-isolation-auditor.md +10 -0
  20. package/kit/agents/multi-tenant-rls-writer.md +78 -0
  21. package/kit/agents/nyquist-auditor.md +178 -178
  22. package/kit/agents/org-onboarding-implementer.md +21 -0
  23. package/kit/agents/phase-researcher.md +696 -696
  24. package/kit/agents/plan-checker.md +272 -272
  25. package/kit/agents/planner.md +922 -891
  26. package/kit/agents/project-researcher.md +652 -652
  27. package/kit/agents/research-synthesizer.md +245 -245
  28. package/kit/agents/roadmapper.md +677 -677
  29. package/kit/agents/supabase-architect.md +27 -0
  30. package/kit/agents/supabase-auth-bootstrapper.md +80 -0
  31. package/kit/agents/supabase-column-privileges-writer.md +399 -0
  32. package/kit/agents/supabase-migration-writer.md +141 -14
  33. package/kit/agents/supabase-rbac-implementer.md +392 -0
  34. package/kit/agents/supabase-rls-hardener.md +521 -0
  35. package/kit/agents/supabase-rls-writer.md +105 -9
  36. package/kit/agents/supabase-roles-implementer.md +355 -0
  37. package/kit/agents/super-admin-implementer.md +99 -0
  38. package/kit/agents/ui-auditor.md +437 -437
  39. package/kit/agents/ui-checker.md +302 -302
  40. package/kit/agents/ui-researcher.md +355 -355
  41. package/kit/agents/user-profiler.md +175 -175
  42. package/kit/agents/validador-evolucao-schema.md +335 -0
  43. package/kit/agents/verifier.md +728 -728
  44. package/kit/commands/adicionar-backlog.md +75 -75
  45. package/kit/commands/adicionar-fase.md +42 -42
  46. package/kit/commands/adicionar-tarefa.md +45 -45
  47. package/kit/commands/adicionar-testes.md +41 -41
  48. package/kit/commands/ajuda.md +21 -21
  49. package/kit/commands/atualizar.md +37 -37
  50. package/kit/commands/auditar-marco.md +179 -179
  51. package/kit/commands/auditar-uat.md +23 -23
  52. package/kit/commands/autonomo.md +40 -40
  53. package/kit/commands/branch-pr.md +24 -24
  54. package/kit/commands/concluir-marco.md +247 -247
  55. package/kit/commands/configuracoes.md +36 -36
  56. package/kit/commands/dados-distribuidos.md +188 -0
  57. package/kit/commands/definir-perfil.md +10 -10
  58. package/kit/commands/depurar.md +190 -190
  59. package/kit/commands/discutir-fase.md +131 -131
  60. package/kit/commands/entrar-discord.md +17 -17
  61. package/kit/commands/estatisticas.md +18 -18
  62. package/kit/commands/example-greeting.md +33 -33
  63. package/kit/commands/executar-fase.md +58 -58
  64. package/kit/commands/expresso.md +56 -56
  65. package/kit/commands/fase-ui.md +34 -34
  66. package/kit/commands/fazer.md +57 -57
  67. package/kit/commands/fio.md +125 -125
  68. package/kit/commands/fluxos-trabalho.md +64 -64
  69. package/kit/commands/forense.md +176 -176
  70. package/kit/commands/gerenciador.md +38 -38
  71. package/kit/commands/inserir-fase.md +31 -31
  72. package/kit/commands/limpeza.md +17 -17
  73. package/kit/commands/listar-hipoteses-fase.md +45 -45
  74. package/kit/commands/listar-workspaces.md +18 -18
  75. package/kit/commands/mapear-codebase.md +70 -70
  76. package/kit/commands/nota.md +33 -33
  77. package/kit/commands/novo-marco.md +43 -43
  78. package/kit/commands/novo-projeto.md +41 -41
  79. package/kit/commands/novo-workspace.md +43 -43
  80. package/kit/commands/pausar-trabalho.md +37 -37
  81. package/kit/commands/perfil-usuario.md +45 -45
  82. package/kit/commands/pesquisar-fase.md +195 -195
  83. package/kit/commands/planejar-fase.md +67 -67
  84. package/kit/commands/planejar-lacunas.md +33 -33
  85. package/kit/commands/plantar-ideia.md +25 -25
  86. package/kit/commands/progresso.md +24 -24
  87. package/kit/commands/proximo.md +30 -30
  88. package/kit/commands/publicar.md +490 -490
  89. package/kit/commands/rapido.md +35 -35
  90. package/kit/commands/reaplicar-patches.md +124 -124
  91. package/kit/commands/relatorio-sessao.md +19 -19
  92. package/kit/commands/remover-fase.md +31 -31
  93. package/kit/commands/remover-workspace.md +26 -26
  94. package/kit/commands/resumo-marco.md +50 -50
  95. package/kit/commands/retomar-trabalho.md +40 -40
  96. package/kit/commands/revisar-backlog.md +60 -60
  97. package/kit/commands/revisar-ui.md +32 -32
  98. package/kit/commands/revisar.md +37 -37
  99. package/kit/commands/saude.md +21 -21
  100. package/kit/commands/setup-notion.md +93 -93
  101. package/kit/commands/supabase.md +55 -8
  102. package/kit/commands/sync-main.md +68 -68
  103. package/kit/commands/validar-fase.md +35 -35
  104. package/kit/commands/verificar-tarefas.md +44 -44
  105. package/kit/commands/verificar-trabalho.md +64 -64
  106. package/kit/file-manifest.json +52 -32
  107. package/kit/framework/bin/lib/commands.cjs +959 -959
  108. package/kit/framework/bin/lib/config.cjs +442 -442
  109. package/kit/framework/bin/lib/core.cjs +1230 -1230
  110. package/kit/framework/bin/lib/frontmatter.cjs +336 -336
  111. package/kit/framework/bin/lib/init.cjs +1442 -1442
  112. package/kit/framework/bin/lib/milestone.cjs +252 -252
  113. package/kit/framework/bin/lib/model-profiles.cjs +68 -68
  114. package/kit/framework/bin/lib/phase.cjs +888 -888
  115. package/kit/framework/bin/lib/profile-output.cjs +952 -952
  116. package/kit/framework/bin/lib/profile-pipeline.cjs +539 -539
  117. package/kit/framework/bin/lib/roadmap.cjs +329 -329
  118. package/kit/framework/bin/lib/security.cjs +382 -382
  119. package/kit/framework/bin/lib/state.cjs +1031 -1031
  120. package/kit/framework/bin/lib/template.cjs +222 -222
  121. package/kit/framework/bin/lib/uat.cjs +282 -282
  122. package/kit/framework/bin/lib/verify.cjs +888 -888
  123. package/kit/framework/bin/lib/workstream.cjs +491 -491
  124. package/kit/framework/bin/tools.cjs +918 -918
  125. package/kit/framework/commands/workstreams.md +63 -63
  126. package/kit/framework/references/checkpoints.md +778 -778
  127. package/kit/framework/references/continuation-format.md +249 -249
  128. package/kit/framework/references/decimal-phase-calculation.md +64 -64
  129. package/kit/framework/references/git-integration.md +295 -295
  130. package/kit/framework/references/git-planning-commit.md +38 -38
  131. package/kit/framework/references/model-profile-resolution.md +36 -36
  132. package/kit/framework/references/model-profiles.md +139 -139
  133. package/kit/framework/references/phase-argument-parsing.md +61 -61
  134. package/kit/framework/references/planning-config.md +202 -202
  135. package/kit/framework/references/questioning.md +162 -162
  136. package/kit/framework/references/tdd.md +263 -263
  137. package/kit/framework/references/ui-brand.md +160 -160
  138. package/kit/framework/references/user-profiling.md +657 -657
  139. package/kit/framework/references/verification-patterns.md +612 -612
  140. package/kit/framework/references/workstream-flag.md +58 -58
  141. package/kit/framework/templates/DEBUG.md +164 -164
  142. package/kit/framework/templates/UAT.md +265 -265
  143. package/kit/framework/templates/UI-SPEC.md +100 -100
  144. package/kit/framework/templates/VALIDATION.md +76 -76
  145. package/kit/framework/templates/claude-md.md +122 -122
  146. package/kit/framework/templates/codebase/architecture.md +185 -185
  147. package/kit/framework/templates/codebase/concerns.md +205 -205
  148. package/kit/framework/templates/codebase/conventions.md +204 -204
  149. package/kit/framework/templates/codebase/integrations.md +192 -192
  150. package/kit/framework/templates/codebase/stack.md +158 -158
  151. package/kit/framework/templates/codebase/structure.md +199 -199
  152. package/kit/framework/templates/codebase/testing.md +301 -301
  153. package/kit/framework/templates/config.json +44 -44
  154. package/kit/framework/templates/context.md +352 -352
  155. package/kit/framework/templates/continue-here.md +78 -78
  156. package/kit/framework/templates/copilot-instructions.md +7 -7
  157. package/kit/framework/templates/debug-subagent-prompt.md +91 -91
  158. package/kit/framework/templates/dev-preferences.md +20 -20
  159. package/kit/framework/templates/discovery.md +146 -146
  160. package/kit/framework/templates/discussion-log.md +63 -63
  161. package/kit/framework/templates/milestone-archive.md +123 -123
  162. package/kit/framework/templates/milestone.md +115 -115
  163. package/kit/framework/templates/phase-prompt.md +610 -610
  164. package/kit/framework/templates/planner-subagent-prompt.md +117 -117
  165. package/kit/framework/templates/project.md +186 -186
  166. package/kit/framework/templates/requirements.md +231 -231
  167. package/kit/framework/templates/research-project/ARCHITECTURE.md +204 -204
  168. package/kit/framework/templates/research-project/FEATURES.md +147 -147
  169. package/kit/framework/templates/research-project/PITFALLS.md +200 -200
  170. package/kit/framework/templates/research-project/STACK.md +120 -120
  171. package/kit/framework/templates/research-project/SUMMARY.md +170 -170
  172. package/kit/framework/templates/research.md +419 -419
  173. package/kit/framework/templates/retrospective.md +54 -54
  174. package/kit/framework/templates/roadmap.md +202 -202
  175. package/kit/framework/templates/state.md +176 -176
  176. package/kit/framework/templates/summary-complex.md +59 -59
  177. package/kit/framework/templates/summary-minimal.md +41 -41
  178. package/kit/framework/templates/summary-standard.md +48 -48
  179. package/kit/framework/templates/summary.md +209 -209
  180. package/kit/framework/templates/user-profile.md +146 -146
  181. package/kit/framework/templates/user-setup.md +256 -256
  182. package/kit/framework/templates/verification-report.md +258 -258
  183. package/kit/framework/workflows/add-phase.md +112 -112
  184. package/kit/framework/workflows/add-tests.md +351 -351
  185. package/kit/framework/workflows/add-todo.md +158 -158
  186. package/kit/framework/workflows/audit-milestone.md +340 -340
  187. package/kit/framework/workflows/audit-uat.md +109 -109
  188. package/kit/framework/workflows/autonomous.md +891 -891
  189. package/kit/framework/workflows/check-todos.md +177 -177
  190. package/kit/framework/workflows/cleanup.md +152 -152
  191. package/kit/framework/workflows/complete-milestone.md +696 -696
  192. package/kit/framework/workflows/diagnose-issues.md +231 -231
  193. package/kit/framework/workflows/discovery-phase.md +289 -289
  194. package/kit/framework/workflows/discuss-phase-assumptions.md +653 -653
  195. package/kit/framework/workflows/discuss-phase.md +784 -784
  196. package/kit/framework/workflows/do.md +104 -104
  197. package/kit/framework/workflows/execute-phase.md +838 -838
  198. package/kit/framework/workflows/execute-plan.md +510 -510
  199. package/kit/framework/workflows/fast.md +102 -102
  200. package/kit/framework/workflows/forensics.md +265 -265
  201. package/kit/framework/workflows/health.md +181 -181
  202. package/kit/framework/workflows/help.md +619 -619
  203. package/kit/framework/workflows/insert-phase.md +130 -130
  204. package/kit/framework/workflows/list-phase-assumptions.md +178 -178
  205. package/kit/framework/workflows/list-workspaces.md +56 -56
  206. package/kit/framework/workflows/manager.md +362 -362
  207. package/kit/framework/workflows/map-codebase.md +377 -377
  208. package/kit/framework/workflows/milestone-summary.md +223 -223
  209. package/kit/framework/workflows/new-milestone.md +486 -486
  210. package/kit/framework/workflows/new-project.md +1159 -1159
  211. package/kit/framework/workflows/new-workspace.md +237 -237
  212. package/kit/framework/workflows/next.md +97 -97
  213. package/kit/framework/workflows/node-repair.md +92 -92
  214. package/kit/framework/workflows/note.md +156 -156
  215. package/kit/framework/workflows/pause-work.md +176 -176
  216. package/kit/framework/workflows/plan-milestone-gaps.md +273 -273
  217. package/kit/framework/workflows/plan-phase.md +765 -765
  218. package/kit/framework/workflows/plant-seed.md +169 -169
  219. package/kit/framework/workflows/pr-branch.md +129 -129
  220. package/kit/framework/workflows/profile-user.md +450 -450
  221. package/kit/framework/workflows/progress.md +507 -507
  222. package/kit/framework/workflows/quick.md +757 -757
  223. package/kit/framework/workflows/remove-phase.md +155 -155
  224. package/kit/framework/workflows/remove-workspace.md +90 -90
  225. package/kit/framework/workflows/research-phase.md +82 -82
  226. package/kit/framework/workflows/resume-project.md +326 -326
  227. package/kit/framework/workflows/review.md +228 -228
  228. package/kit/framework/workflows/session-report.md +146 -146
  229. package/kit/framework/workflows/settings.md +283 -283
  230. package/kit/framework/workflows/ship.md +228 -228
  231. package/kit/framework/workflows/stats.md +60 -60
  232. package/kit/framework/workflows/transition.md +671 -671
  233. package/kit/framework/workflows/ui-phase.md +302 -302
  234. package/kit/framework/workflows/ui-review.md +165 -165
  235. package/kit/framework/workflows/update.md +323 -323
  236. package/kit/framework/workflows/validate-phase.md +174 -174
  237. package/kit/framework/workflows/verify-phase.md +252 -252
  238. package/kit/framework/workflows/verify-work.md +637 -637
  239. package/kit/hooks/check-update.js +118 -118
  240. package/kit/hooks/context-monitor.js +163 -163
  241. package/kit/hooks/prompt-guard.js +103 -103
  242. package/kit/hooks/statusline.js +125 -125
  243. package/kit/hooks/workflow-guard.js +101 -101
  244. package/kit/settings.json +45 -45
  245. package/kit/skills/_shared-dados-distribuidos/glossary.md +224 -0
  246. package/kit/skills/_shared-supabase/glossary.md +27 -0
  247. package/kit/skills/armadilhas-sistemas-distribuidos/SKILL.md +447 -0
  248. package/kit/skills/audit-log-multi-tenant/SKILL.md +6 -0
  249. package/kit/skills/cascading-failures/SKILL.md +4 -0
  250. package/kit/skills/consistencia-leitura-replica/SKILL.md +385 -0
  251. package/kit/skills/crm-lead-pipeline-patterns/SKILL.md +17 -0
  252. package/kit/skills/escolha-modelo-consistencia/SKILL.md +495 -0
  253. package/kit/skills/evolucao-schema-compativel/SKILL.md +448 -0
  254. package/kit/skills/example-skill/SKILL.md +42 -42
  255. package/kit/skills/multi-tenant-performance-scaling/SKILL.md +4 -0
  256. package/kit/skills/multi-tenant-rls-hierarchy/SKILL.md +4 -0
  257. package/kit/skills/postgres-isolamento-concorrencia/SKILL.md +552 -0
  258. package/kit/skills/rbac-permissions-matrix-supabase/SKILL.md +37 -0
  259. package/kit/skills/streams-eventos-cdc/SKILL.md +712 -0
  260. package/kit/skills/supabase-column-level-security/SKILL.md +426 -0
  261. package/kit/skills/supabase-cron-queues/SKILL.md +9 -0
  262. package/kit/skills/supabase-custom-claims-rbac/SKILL.md +472 -0
  263. package/kit/skills/supabase-database-functions/SKILL.md +85 -0
  264. package/kit/skills/supabase-migrations/SKILL.md +133 -11
  265. package/kit/skills/supabase-postgres-roles/SKILL.md +392 -0
  266. package/kit/skills/supabase-rls-defense-in-depth/SKILL.md +418 -0
  267. package/kit/skills/supabase-rls-policies/SKILL.md +462 -12
  268. package/kit/skills/super-admin-platform-pattern/SKILL.md +4 -0
  269. package/kit/skills/tenant-quente-mitigacao/SKILL.md +605 -0
  270. package/package.json +63 -63
  271. package/src/core/kit.js +216 -216
  272. package/src/core/reflect.js +247 -247
  273. package/src/core/reverse-sync.js +372 -372
  274. package/src/core/sync.js +418 -418
  275. package/src/core/watch.js +121 -121
@@ -1,263 +1,263 @@
1
- <overview>
2
- TDD é sobre qualidade de design, não métricas de cobertura. O ciclo vermelho-verde-refatorar força você a pensar sobre o comportamento antes da implementação, produzindo interfaces mais limpas e código mais testável.
3
-
4
- **Princípio:** Se você pode descrever o comportamento como `expect(fn(input)).toBe(output)` antes de escrever `fn`, o TDD melhora o resultado.
5
-
6
- **Insight chave:** O trabalho TDD é fundamentalmente mais pesado do que tarefas padrão — requer 2-3 ciclos de execução (VERMELHO → VERDE → REFATORAR), cada um com leituras de arquivo, execuções de teste e possível debugging. Funcionalidades TDD recebem planos dedicados para garantir que o contexto completo esteja disponível durante todo o ciclo.
7
- </overview>
8
-
9
- <when_to_use_tdd>
10
- ## Quando o TDD Melhora a Qualidade
11
-
12
- **Candidatos a TDD (criar um plano TDD):**
13
- - Lógica de negócio com entradas/saídas definidas
14
- - Endpoints de API com contratos de requisição/resposta
15
- - Transformações de dados, análise, formatação
16
- - Regras e restrições de validação
17
- - Algoritmos com comportamento testável
18
- - Máquinas de estado e workflows
19
- - Funções utilitárias com especificações claras
20
-
21
- **Pular TDD (usar plano padrão com tarefas `type="auto"`):**
22
- - Layout de UI, estilo, componentes visuais
23
- - Alterações de configuração
24
- - Código de cola conectando componentes existentes
25
- - Scripts e migrações de uso único
26
- - CRUD simples sem lógica de negócio
27
- - Prototipagem exploratória
28
-
29
- **Heurística:** Você pode escrever `expect(fn(input)).toBe(output)` antes de escrever `fn`?
30
- → Sim: Crie um plano TDD
31
- → Não: Use plano padrão, adicione testes depois se necessário
32
- </when_to_use_tdd>
33
-
34
- <tdd_plan_structure>
35
- ## Estrutura do Plano TDD
36
-
37
- Cada plano TDD implementa **uma funcionalidade** através do ciclo completo VERMELHO-VERDE-REFATORAR.
38
-
39
- ```markdown
40
- ---
41
- phase: XX-nome
42
- plan: NN
43
- type: tdd
44
- ---
45
-
46
- <objective>
47
- [O que é a funcionalidade e por quê]
48
- Purpose: [Benefício de design do TDD para esta funcionalidade]
49
- Output: [Funcionalidade funcionando e testada]
50
- </objective>
51
-
52
- <context>
53
- @.planning/PROJECT.md
54
- @.planning/ROADMAP.md
55
- @relevant/source/files.ts
56
- </context>
57
-
58
- <feature>
59
- <name>[Nome da funcionalidade]</name>
60
- <files>[arquivo fonte, arquivo de teste]</files>
61
- <behavior>
62
- [Comportamento esperado em termos testáveis]
63
- Casos: entrada → saída esperada
64
- </behavior>
65
- <implementation>[Como implementar uma vez que os testes passem]</implementation>
66
- </feature>
67
-
68
- <verification>
69
- [Comando de teste que prova que a funcionalidade funciona]
70
- </verification>
71
-
72
- <success_criteria>
73
- - Teste falhando escrito e commitado
74
- - Implementação passa no teste
75
- - Refatoração concluída (se necessário)
76
- - Todos os 2-3 commits presentes
77
- </success_criteria>
78
-
79
- <output>
80
- Após a conclusão, crie SUMMARY.md com:
81
- - VERMELHO: Qual teste foi escrito, por que falhou
82
- - VERDE: Qual implementação fez passar
83
- - REFATORAR: Qual limpeza foi feita (se houver)
84
- - Commits: Lista de commits produzidos
85
- </output>
86
- ```
87
-
88
- **Uma funcionalidade por plano TDD.** Se as funcionalidades são triviais o suficiente para agrupar, são triviais o suficiente para pular o TDD — use um plano padrão e adicione testes depois.
89
- </tdd_plan_structure>
90
-
91
- <execution_flow>
92
- ## Ciclo Vermelho-Verde-Refatorar
93
-
94
- **VERMELHO - Escrever teste falhando:**
95
- 1. Criar arquivo de teste seguindo convenções do projeto
96
- 2. Escrever teste descrevendo o comportamento esperado (do elemento `<behavior>`)
97
- 3. Executar o teste - DEVE falhar
98
- 4. Se o teste passar: a funcionalidade existe ou o teste está errado. Investigue.
99
- 5. Commit: `test({fase}-{plano}): add failing test for [funcionalidade]`
100
-
101
- **VERDE - Implementar para passar:**
102
- 1. Escrever código mínimo para fazer o teste passar
103
- 2. Sem astúcias, sem otimização — apenas faça funcionar
104
- 3. Executar o teste - DEVE passar
105
- 4. Commit: `feat({fase}-{plano}): implement [funcionalidade]`
106
-
107
- **REFATORAR (se necessário):**
108
- 1. Limpar a implementação se houver melhorias óbvias
109
- 2. Executar os testes - DEVEM ainda passar
110
- 3. Commitar apenas se houver alterações: `refactor({fase}-{plano}): clean up [funcionalidade]`
111
-
112
- **Resultado:** Cada plano TDD produz 2-3 commits atômicos.
113
- </execution_flow>
114
-
115
- <test_quality>
116
- ## Bons Testes vs. Testes Ruins
117
-
118
- **Teste o comportamento, não a implementação:**
119
- - Bom: "retorna string de data formatada"
120
- - Ruim: "chama o helper formatDate com os parâmetros corretos"
121
- - Os testes devem sobreviver a refatorações
122
-
123
- **Um conceito por teste:**
124
- - Bom: Testes separados para entrada válida, entrada vazia, entrada malformada
125
- - Ruim: Teste único verificando todos os casos extremos com múltiplas asserções
126
-
127
- **Nomes descritivos:**
128
- - Bom: "should reject empty email", "returns null for invalid ID"
129
- - Ruim: "test1", "handles error", "works correctly"
130
-
131
- **Sem detalhes de implementação:**
132
- - Bom: Testar API pública, comportamento observável
133
- - Ruim: Mockar internos, testar métodos privados, verificar estado interno
134
- </test_quality>
135
-
136
- <framework_setup>
137
- ## Configuração do Framework de Teste (Se Nenhum Existir)
138
-
139
- Ao executar um plano TDD mas nenhum framework de teste estiver configurado, configure-o como parte da fase VERMELHO:
140
-
141
- **1. Detectar o tipo de projeto:**
142
- ```bash
143
- # JavaScript/TypeScript
144
- if [ -f package.json ]; then echo "node"; fi
145
-
146
- # Python
147
- if [ -f requirements.txt ] || [ -f pyproject.toml ]; then echo "python"; fi
148
-
149
- # Go
150
- if [ -f go.mod ]; then echo "go"; fi
151
-
152
- # Rust
153
- if [ -f Cargo.toml ]; then echo "rust"; fi
154
- ```
155
-
156
- **2. Instalar o framework mínimo:**
157
- | Projeto | Framework | Instalação |
158
- |---------|-----------|------------|
159
- | Node.js | Jest | `npm install -D jest @types/jest ts-jest` |
160
- | Node.js (Vite) | Vitest | `npm install -D vitest` |
161
- | Python | pytest | `pip install pytest` |
162
- | Go | testing | Integrado |
163
- | Rust | cargo test | Integrado |
164
-
165
- **3. Criar config se necessário:**
166
- - Jest: `jest.config.js` com preset ts-jest
167
- - Vitest: `vitest.config.ts` com globals de teste
168
- - pytest: `pytest.ini` ou seção `pyproject.toml`
169
-
170
- **4. Verificar a configuração:**
171
- ```bash
172
- # Executar suite de testes vazia — deve passar com 0 testes
173
- npm test # Node
174
- pytest # Python
175
- go test ./... # Go
176
- cargo test # Rust
177
- ```
178
-
179
- **5. Criar primeiro arquivo de teste:**
180
- Siga as convenções do projeto para localização dos testes:
181
- - `*.test.ts` / `*.spec.ts` ao lado da fonte
182
- - Diretório `__tests__/`
183
- - Diretório `tests/` na raiz
184
-
185
- A configuração do framework é um custo único incluído na fase VERMELHO do primeiro plano TDD.
186
- </framework_setup>
187
-
188
- <error_handling>
189
- ## Tratamento de Erros
190
-
191
- **O teste não falha na fase VERMELHO:**
192
- - A funcionalidade pode já existir — investigue
193
- - O teste pode estar errado (não testando o que você pensa)
194
- - Corrija antes de prosseguir
195
-
196
- **O teste não passa na fase VERDE:**
197
- - Depure a implementação
198
- - Não pule para refatorar
199
- - Continue iterando até ficar verde
200
-
201
- **Os testes falham na fase REFATORAR:**
202
- - Desfaça a refatoração
203
- - O commit foi prematuro
204
- - Refatore em passos menores
205
-
206
- **Testes não relacionados quebram:**
207
- - Pare e investigue
208
- - Pode indicar problema de acoplamento
209
- - Corrija antes de prosseguir
210
- </error_handling>
211
-
212
- <commit_pattern>
213
- ## Padrão de Commit para Planos TDD
214
-
215
- Planos TDD produzem 2-3 commits atômicos (um por fase):
216
-
217
- ```
218
- test(08-02): add failing test for email validation
219
-
220
- - Tests valid email formats accepted
221
- - Tests invalid formats rejected
222
- - Tests empty input handling
223
-
224
- feat(08-02): implement email validation
225
-
226
- - Regex pattern matches RFC 5322
227
- - Returns boolean for validity
228
- - Handles edge cases (empty, null)
229
-
230
- refactor(08-02): extract regex to constant (optional)
231
-
232
- - Moved pattern to EMAIL_REGEX constant
233
- - No behavior changes
234
- - Tests still pass
235
- ```
236
-
237
- **Comparação com planos padrão:**
238
- - Planos padrão: 1 commit por tarefa, 2-4 commits por plano
239
- - Planos TDD: 2-3 commits para uma única funcionalidade
240
-
241
- Ambos seguem o mesmo formato: `{tipo}({fase}-{plano}): {descrição}`
242
-
243
- **Benefícios:**
244
- - Cada commit é revertível independentemente
245
- - `git bisect` funciona no nível de commit
246
- - Histórico claro mostrando disciplina TDD
247
- - Consistente com a estratégia geral de commits
248
- </commit_pattern>
249
-
250
- <context_budget>
251
- ## Orçamento de Contexto
252
-
253
- Planos TDD visam **~40% de uso de contexto** (menor que os ~50% dos planos padrão).
254
-
255
- Por que menor:
256
- - Fase VERMELHO: escrever teste, executar teste, potencialmente depurar por que não falhou
257
- - Fase VERDE: implementar, executar teste, potencialmente iterar em falhas
258
- - Fase REFATORAR: modificar código, executar testes, verificar se não houve regressões
259
-
260
- Cada fase envolve leitura de arquivos, execução de comandos, análise de saída. O vai e vem é inerentemente mais pesado do que a execução linear de tarefas.
261
-
262
- O foco em uma única funcionalidade garante qualidade total durante todo o ciclo.
263
- </context_budget>
1
+ <overview>
2
+ TDD é sobre qualidade de design, não métricas de cobertura. O ciclo vermelho-verde-refatorar força você a pensar sobre o comportamento antes da implementação, produzindo interfaces mais limpas e código mais testável.
3
+
4
+ **Princípio:** Se você pode descrever o comportamento como `expect(fn(input)).toBe(output)` antes de escrever `fn`, o TDD melhora o resultado.
5
+
6
+ **Insight chave:** O trabalho TDD é fundamentalmente mais pesado do que tarefas padrão — requer 2-3 ciclos de execução (VERMELHO → VERDE → REFATORAR), cada um com leituras de arquivo, execuções de teste e possível debugging. Funcionalidades TDD recebem planos dedicados para garantir que o contexto completo esteja disponível durante todo o ciclo.
7
+ </overview>
8
+
9
+ <when_to_use_tdd>
10
+ ## Quando o TDD Melhora a Qualidade
11
+
12
+ **Candidatos a TDD (criar um plano TDD):**
13
+ - Lógica de negócio com entradas/saídas definidas
14
+ - Endpoints de API com contratos de requisição/resposta
15
+ - Transformações de dados, análise, formatação
16
+ - Regras e restrições de validação
17
+ - Algoritmos com comportamento testável
18
+ - Máquinas de estado e workflows
19
+ - Funções utilitárias com especificações claras
20
+
21
+ **Pular TDD (usar plano padrão com tarefas `type="auto"`):**
22
+ - Layout de UI, estilo, componentes visuais
23
+ - Alterações de configuração
24
+ - Código de cola conectando componentes existentes
25
+ - Scripts e migrações de uso único
26
+ - CRUD simples sem lógica de negócio
27
+ - Prototipagem exploratória
28
+
29
+ **Heurística:** Você pode escrever `expect(fn(input)).toBe(output)` antes de escrever `fn`?
30
+ → Sim: Crie um plano TDD
31
+ → Não: Use plano padrão, adicione testes depois se necessário
32
+ </when_to_use_tdd>
33
+
34
+ <tdd_plan_structure>
35
+ ## Estrutura do Plano TDD
36
+
37
+ Cada plano TDD implementa **uma funcionalidade** através do ciclo completo VERMELHO-VERDE-REFATORAR.
38
+
39
+ ```markdown
40
+ ---
41
+ phase: XX-nome
42
+ plan: NN
43
+ type: tdd
44
+ ---
45
+
46
+ <objective>
47
+ [O que é a funcionalidade e por quê]
48
+ Purpose: [Benefício de design do TDD para esta funcionalidade]
49
+ Output: [Funcionalidade funcionando e testada]
50
+ </objective>
51
+
52
+ <context>
53
+ @.planning/PROJECT.md
54
+ @.planning/ROADMAP.md
55
+ @relevant/source/files.ts
56
+ </context>
57
+
58
+ <feature>
59
+ <name>[Nome da funcionalidade]</name>
60
+ <files>[arquivo fonte, arquivo de teste]</files>
61
+ <behavior>
62
+ [Comportamento esperado em termos testáveis]
63
+ Casos: entrada → saída esperada
64
+ </behavior>
65
+ <implementation>[Como implementar uma vez que os testes passem]</implementation>
66
+ </feature>
67
+
68
+ <verification>
69
+ [Comando de teste que prova que a funcionalidade funciona]
70
+ </verification>
71
+
72
+ <success_criteria>
73
+ - Teste falhando escrito e commitado
74
+ - Implementação passa no teste
75
+ - Refatoração concluída (se necessário)
76
+ - Todos os 2-3 commits presentes
77
+ </success_criteria>
78
+
79
+ <output>
80
+ Após a conclusão, crie SUMMARY.md com:
81
+ - VERMELHO: Qual teste foi escrito, por que falhou
82
+ - VERDE: Qual implementação fez passar
83
+ - REFATORAR: Qual limpeza foi feita (se houver)
84
+ - Commits: Lista de commits produzidos
85
+ </output>
86
+ ```
87
+
88
+ **Uma funcionalidade por plano TDD.** Se as funcionalidades são triviais o suficiente para agrupar, são triviais o suficiente para pular o TDD — use um plano padrão e adicione testes depois.
89
+ </tdd_plan_structure>
90
+
91
+ <execution_flow>
92
+ ## Ciclo Vermelho-Verde-Refatorar
93
+
94
+ **VERMELHO - Escrever teste falhando:**
95
+ 1. Criar arquivo de teste seguindo convenções do projeto
96
+ 2. Escrever teste descrevendo o comportamento esperado (do elemento `<behavior>`)
97
+ 3. Executar o teste - DEVE falhar
98
+ 4. Se o teste passar: a funcionalidade existe ou o teste está errado. Investigue.
99
+ 5. Commit: `test({fase}-{plano}): add failing test for [funcionalidade]`
100
+
101
+ **VERDE - Implementar para passar:**
102
+ 1. Escrever código mínimo para fazer o teste passar
103
+ 2. Sem astúcias, sem otimização — apenas faça funcionar
104
+ 3. Executar o teste - DEVE passar
105
+ 4. Commit: `feat({fase}-{plano}): implement [funcionalidade]`
106
+
107
+ **REFATORAR (se necessário):**
108
+ 1. Limpar a implementação se houver melhorias óbvias
109
+ 2. Executar os testes - DEVEM ainda passar
110
+ 3. Commitar apenas se houver alterações: `refactor({fase}-{plano}): clean up [funcionalidade]`
111
+
112
+ **Resultado:** Cada plano TDD produz 2-3 commits atômicos.
113
+ </execution_flow>
114
+
115
+ <test_quality>
116
+ ## Bons Testes vs. Testes Ruins
117
+
118
+ **Teste o comportamento, não a implementação:**
119
+ - Bom: "retorna string de data formatada"
120
+ - Ruim: "chama o helper formatDate com os parâmetros corretos"
121
+ - Os testes devem sobreviver a refatorações
122
+
123
+ **Um conceito por teste:**
124
+ - Bom: Testes separados para entrada válida, entrada vazia, entrada malformada
125
+ - Ruim: Teste único verificando todos os casos extremos com múltiplas asserções
126
+
127
+ **Nomes descritivos:**
128
+ - Bom: "should reject empty email", "returns null for invalid ID"
129
+ - Ruim: "test1", "handles error", "works correctly"
130
+
131
+ **Sem detalhes de implementação:**
132
+ - Bom: Testar API pública, comportamento observável
133
+ - Ruim: Mockar internos, testar métodos privados, verificar estado interno
134
+ </test_quality>
135
+
136
+ <framework_setup>
137
+ ## Configuração do Framework de Teste (Se Nenhum Existir)
138
+
139
+ Ao executar um plano TDD mas nenhum framework de teste estiver configurado, configure-o como parte da fase VERMELHO:
140
+
141
+ **1. Detectar o tipo de projeto:**
142
+ ```bash
143
+ # JavaScript/TypeScript
144
+ if [ -f package.json ]; then echo "node"; fi
145
+
146
+ # Python
147
+ if [ -f requirements.txt ] || [ -f pyproject.toml ]; then echo "python"; fi
148
+
149
+ # Go
150
+ if [ -f go.mod ]; then echo "go"; fi
151
+
152
+ # Rust
153
+ if [ -f Cargo.toml ]; then echo "rust"; fi
154
+ ```
155
+
156
+ **2. Instalar o framework mínimo:**
157
+ | Projeto | Framework | Instalação |
158
+ |---------|-----------|------------|
159
+ | Node.js | Jest | `npm install -D jest @types/jest ts-jest` |
160
+ | Node.js (Vite) | Vitest | `npm install -D vitest` |
161
+ | Python | pytest | `pip install pytest` |
162
+ | Go | testing | Integrado |
163
+ | Rust | cargo test | Integrado |
164
+
165
+ **3. Criar config se necessário:**
166
+ - Jest: `jest.config.js` com preset ts-jest
167
+ - Vitest: `vitest.config.ts` com globals de teste
168
+ - pytest: `pytest.ini` ou seção `pyproject.toml`
169
+
170
+ **4. Verificar a configuração:**
171
+ ```bash
172
+ # Executar suite de testes vazia — deve passar com 0 testes
173
+ npm test # Node
174
+ pytest # Python
175
+ go test ./... # Go
176
+ cargo test # Rust
177
+ ```
178
+
179
+ **5. Criar primeiro arquivo de teste:**
180
+ Siga as convenções do projeto para localização dos testes:
181
+ - `*.test.ts` / `*.spec.ts` ao lado da fonte
182
+ - Diretório `__tests__/`
183
+ - Diretório `tests/` na raiz
184
+
185
+ A configuração do framework é um custo único incluído na fase VERMELHO do primeiro plano TDD.
186
+ </framework_setup>
187
+
188
+ <error_handling>
189
+ ## Tratamento de Erros
190
+
191
+ **O teste não falha na fase VERMELHO:**
192
+ - A funcionalidade pode já existir — investigue
193
+ - O teste pode estar errado (não testando o que você pensa)
194
+ - Corrija antes de prosseguir
195
+
196
+ **O teste não passa na fase VERDE:**
197
+ - Depure a implementação
198
+ - Não pule para refatorar
199
+ - Continue iterando até ficar verde
200
+
201
+ **Os testes falham na fase REFATORAR:**
202
+ - Desfaça a refatoração
203
+ - O commit foi prematuro
204
+ - Refatore em passos menores
205
+
206
+ **Testes não relacionados quebram:**
207
+ - Pare e investigue
208
+ - Pode indicar problema de acoplamento
209
+ - Corrija antes de prosseguir
210
+ </error_handling>
211
+
212
+ <commit_pattern>
213
+ ## Padrão de Commit para Planos TDD
214
+
215
+ Planos TDD produzem 2-3 commits atômicos (um por fase):
216
+
217
+ ```
218
+ test(08-02): add failing test for email validation
219
+
220
+ - Tests valid email formats accepted
221
+ - Tests invalid formats rejected
222
+ - Tests empty input handling
223
+
224
+ feat(08-02): implement email validation
225
+
226
+ - Regex pattern matches RFC 5322
227
+ - Returns boolean for validity
228
+ - Handles edge cases (empty, null)
229
+
230
+ refactor(08-02): extract regex to constant (optional)
231
+
232
+ - Moved pattern to EMAIL_REGEX constant
233
+ - No behavior changes
234
+ - Tests still pass
235
+ ```
236
+
237
+ **Comparação com planos padrão:**
238
+ - Planos padrão: 1 commit por tarefa, 2-4 commits por plano
239
+ - Planos TDD: 2-3 commits para uma única funcionalidade
240
+
241
+ Ambos seguem o mesmo formato: `{tipo}({fase}-{plano}): {descrição}`
242
+
243
+ **Benefícios:**
244
+ - Cada commit é revertível independentemente
245
+ - `git bisect` funciona no nível de commit
246
+ - Histórico claro mostrando disciplina TDD
247
+ - Consistente com a estratégia geral de commits
248
+ </commit_pattern>
249
+
250
+ <context_budget>
251
+ ## Orçamento de Contexto
252
+
253
+ Planos TDD visam **~40% de uso de contexto** (menor que os ~50% dos planos padrão).
254
+
255
+ Por que menor:
256
+ - Fase VERMELHO: escrever teste, executar teste, potencialmente depurar por que não falhou
257
+ - Fase VERDE: implementar, executar teste, potencialmente iterar em falhas
258
+ - Fase REFATORAR: modificar código, executar testes, verificar se não houve regressões
259
+
260
+ Cada fase envolve leitura de arquivos, execução de comandos, análise de saída. O vai e vem é inerentemente mais pesado do que a execução linear de tarefas.
261
+
262
+ O foco em uma única funcionalidade garante qualidade total durante todo o ciclo.
263
+ </context_budget>