@luanpdd/kit-mcp 1.18.0 → 1.20.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 (232) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +648 -648
  3. package/kit/COMANDOS.md +138 -138
  4. package/kit/README.md +52 -52
  5. package/kit/agents/advisor-researcher.md +106 -106
  6. package/kit/agents/assumptions-analyzer.md +107 -107
  7. package/kit/agents/codebase-mapper.md +768 -768
  8. package/kit/agents/debugger.md +772 -772
  9. package/kit/agents/example-reviewer.md +21 -21
  10. package/kit/agents/executor.md +523 -523
  11. package/kit/agents/integration-checker.md +200 -200
  12. package/kit/agents/nyquist-auditor.md +178 -178
  13. package/kit/agents/phase-researcher.md +696 -696
  14. package/kit/agents/plan-checker.md +272 -272
  15. package/kit/agents/planner.md +891 -891
  16. package/kit/agents/project-researcher.md +652 -652
  17. package/kit/agents/research-synthesizer.md +245 -245
  18. package/kit/agents/roadmapper.md +677 -677
  19. package/kit/agents/ui-auditor.md +437 -437
  20. package/kit/agents/ui-checker.md +302 -302
  21. package/kit/agents/ui-researcher.md +355 -355
  22. package/kit/agents/user-profiler.md +175 -175
  23. package/kit/agents/verifier.md +728 -728
  24. package/kit/commands/adicionar-backlog.md +75 -75
  25. package/kit/commands/adicionar-fase.md +42 -42
  26. package/kit/commands/adicionar-tarefa.md +45 -45
  27. package/kit/commands/adicionar-testes.md +41 -41
  28. package/kit/commands/ajuda.md +21 -21
  29. package/kit/commands/atualizar.md +37 -37
  30. package/kit/commands/auditar-marco.md +179 -179
  31. package/kit/commands/auditar-uat.md +23 -23
  32. package/kit/commands/autonomo.md +40 -40
  33. package/kit/commands/branch-pr.md +24 -24
  34. package/kit/commands/burn-rate-status.md +338 -70
  35. package/kit/commands/concluir-marco.md +247 -247
  36. package/kit/commands/configuracoes.md +36 -36
  37. package/kit/commands/definir-perfil.md +10 -10
  38. package/kit/commands/depurar.md +190 -190
  39. package/kit/commands/discutir-fase.md +131 -131
  40. package/kit/commands/entrar-discord.md +17 -17
  41. package/kit/commands/estatisticas.md +18 -18
  42. package/kit/commands/example-greeting.md +33 -33
  43. package/kit/commands/executar-fase.md +58 -58
  44. package/kit/commands/expresso.md +56 -56
  45. package/kit/commands/fase-ui.md +34 -34
  46. package/kit/commands/fazer.md +57 -57
  47. package/kit/commands/fio.md +125 -125
  48. package/kit/commands/fluxos-trabalho.md +64 -64
  49. package/kit/commands/forense.md +176 -176
  50. package/kit/commands/gerenciador.md +38 -38
  51. package/kit/commands/inserir-fase.md +31 -31
  52. package/kit/commands/limpeza.md +17 -17
  53. package/kit/commands/listar-hipoteses-fase.md +45 -45
  54. package/kit/commands/listar-workspaces.md +18 -18
  55. package/kit/commands/mapear-codebase.md +70 -70
  56. package/kit/commands/nota.md +33 -33
  57. package/kit/commands/novo-marco.md +43 -43
  58. package/kit/commands/novo-projeto.md +41 -41
  59. package/kit/commands/novo-workspace.md +43 -43
  60. package/kit/commands/pausar-trabalho.md +37 -37
  61. package/kit/commands/perfil-usuario.md +45 -45
  62. package/kit/commands/pesquisar-fase.md +195 -195
  63. package/kit/commands/planejar-fase.md +67 -67
  64. package/kit/commands/planejar-lacunas.md +33 -33
  65. package/kit/commands/plantar-ideia.md +25 -25
  66. package/kit/commands/progresso.md +24 -24
  67. package/kit/commands/proximo.md +30 -30
  68. package/kit/commands/publicar.md +490 -490
  69. package/kit/commands/rapido.md +35 -35
  70. package/kit/commands/reaplicar-patches.md +124 -124
  71. package/kit/commands/relatorio-sessao.md +19 -19
  72. package/kit/commands/remover-fase.md +31 -31
  73. package/kit/commands/remover-workspace.md +26 -26
  74. package/kit/commands/resumo-marco.md +50 -50
  75. package/kit/commands/retomar-trabalho.md +40 -40
  76. package/kit/commands/revisar-backlog.md +60 -60
  77. package/kit/commands/revisar-ui.md +32 -32
  78. package/kit/commands/revisar.md +37 -37
  79. package/kit/commands/saude.md +21 -21
  80. package/kit/commands/setup-notion.md +93 -93
  81. package/kit/commands/sync-main.md +68 -68
  82. package/kit/commands/validar-fase.md +35 -35
  83. package/kit/commands/verificar-tarefas.md +44 -44
  84. package/kit/commands/verificar-trabalho.md +64 -64
  85. package/kit/file-manifest.json +3 -3
  86. package/kit/framework/bin/lib/commands.cjs +959 -959
  87. package/kit/framework/bin/lib/config.cjs +442 -442
  88. package/kit/framework/bin/lib/core.cjs +1230 -1230
  89. package/kit/framework/bin/lib/frontmatter.cjs +336 -336
  90. package/kit/framework/bin/lib/init.cjs +1442 -1442
  91. package/kit/framework/bin/lib/milestone.cjs +252 -252
  92. package/kit/framework/bin/lib/model-profiles.cjs +68 -68
  93. package/kit/framework/bin/lib/phase.cjs +888 -888
  94. package/kit/framework/bin/lib/profile-output.cjs +952 -952
  95. package/kit/framework/bin/lib/profile-pipeline.cjs +539 -539
  96. package/kit/framework/bin/lib/roadmap.cjs +329 -329
  97. package/kit/framework/bin/lib/security.cjs +382 -382
  98. package/kit/framework/bin/lib/state.cjs +1031 -1031
  99. package/kit/framework/bin/lib/template.cjs +222 -222
  100. package/kit/framework/bin/lib/uat.cjs +282 -282
  101. package/kit/framework/bin/lib/verify.cjs +888 -888
  102. package/kit/framework/bin/lib/workstream.cjs +491 -491
  103. package/kit/framework/bin/tools.cjs +918 -918
  104. package/kit/framework/commands/workstreams.md +63 -63
  105. package/kit/framework/references/checkpoints.md +778 -778
  106. package/kit/framework/references/continuation-format.md +249 -249
  107. package/kit/framework/references/decimal-phase-calculation.md +64 -64
  108. package/kit/framework/references/git-integration.md +295 -295
  109. package/kit/framework/references/git-planning-commit.md +38 -38
  110. package/kit/framework/references/model-profile-resolution.md +36 -36
  111. package/kit/framework/references/model-profiles.md +139 -139
  112. package/kit/framework/references/phase-argument-parsing.md +61 -61
  113. package/kit/framework/references/planning-config.md +202 -202
  114. package/kit/framework/references/questioning.md +162 -162
  115. package/kit/framework/references/tdd.md +263 -263
  116. package/kit/framework/references/ui-brand.md +160 -160
  117. package/kit/framework/references/user-profiling.md +657 -657
  118. package/kit/framework/references/verification-patterns.md +612 -612
  119. package/kit/framework/references/workstream-flag.md +58 -58
  120. package/kit/framework/templates/DEBUG.md +164 -164
  121. package/kit/framework/templates/UAT.md +265 -265
  122. package/kit/framework/templates/UI-SPEC.md +100 -100
  123. package/kit/framework/templates/VALIDATION.md +76 -76
  124. package/kit/framework/templates/claude-md.md +122 -122
  125. package/kit/framework/templates/codebase/architecture.md +185 -185
  126. package/kit/framework/templates/codebase/concerns.md +205 -205
  127. package/kit/framework/templates/codebase/conventions.md +204 -204
  128. package/kit/framework/templates/codebase/integrations.md +192 -192
  129. package/kit/framework/templates/codebase/stack.md +158 -158
  130. package/kit/framework/templates/codebase/structure.md +199 -199
  131. package/kit/framework/templates/codebase/testing.md +301 -301
  132. package/kit/framework/templates/config.json +44 -44
  133. package/kit/framework/templates/context.md +352 -352
  134. package/kit/framework/templates/continue-here.md +78 -78
  135. package/kit/framework/templates/copilot-instructions.md +7 -7
  136. package/kit/framework/templates/debug-subagent-prompt.md +91 -91
  137. package/kit/framework/templates/dev-preferences.md +20 -20
  138. package/kit/framework/templates/discovery.md +146 -146
  139. package/kit/framework/templates/discussion-log.md +63 -63
  140. package/kit/framework/templates/milestone-archive.md +123 -123
  141. package/kit/framework/templates/milestone.md +115 -115
  142. package/kit/framework/templates/phase-prompt.md +610 -610
  143. package/kit/framework/templates/planner-subagent-prompt.md +117 -117
  144. package/kit/framework/templates/project.md +186 -186
  145. package/kit/framework/templates/requirements.md +231 -231
  146. package/kit/framework/templates/research-project/ARCHITECTURE.md +204 -204
  147. package/kit/framework/templates/research-project/FEATURES.md +147 -147
  148. package/kit/framework/templates/research-project/PITFALLS.md +200 -200
  149. package/kit/framework/templates/research-project/STACK.md +120 -120
  150. package/kit/framework/templates/research-project/SUMMARY.md +170 -170
  151. package/kit/framework/templates/research.md +419 -419
  152. package/kit/framework/templates/retrospective.md +54 -54
  153. package/kit/framework/templates/roadmap.md +202 -202
  154. package/kit/framework/templates/state.md +176 -176
  155. package/kit/framework/templates/summary-complex.md +59 -59
  156. package/kit/framework/templates/summary-minimal.md +41 -41
  157. package/kit/framework/templates/summary-standard.md +48 -48
  158. package/kit/framework/templates/summary.md +209 -209
  159. package/kit/framework/templates/user-profile.md +146 -146
  160. package/kit/framework/templates/user-setup.md +256 -256
  161. package/kit/framework/templates/verification-report.md +258 -258
  162. package/kit/framework/workflows/add-phase.md +112 -112
  163. package/kit/framework/workflows/add-tests.md +351 -351
  164. package/kit/framework/workflows/add-todo.md +158 -158
  165. package/kit/framework/workflows/audit-milestone.md +340 -340
  166. package/kit/framework/workflows/audit-uat.md +109 -109
  167. package/kit/framework/workflows/autonomous.md +891 -891
  168. package/kit/framework/workflows/check-todos.md +177 -177
  169. package/kit/framework/workflows/cleanup.md +152 -152
  170. package/kit/framework/workflows/complete-milestone.md +696 -696
  171. package/kit/framework/workflows/diagnose-issues.md +231 -231
  172. package/kit/framework/workflows/discovery-phase.md +289 -289
  173. package/kit/framework/workflows/discuss-phase-assumptions.md +653 -653
  174. package/kit/framework/workflows/discuss-phase.md +784 -784
  175. package/kit/framework/workflows/do.md +104 -104
  176. package/kit/framework/workflows/execute-phase.md +838 -838
  177. package/kit/framework/workflows/execute-plan.md +510 -510
  178. package/kit/framework/workflows/fast.md +102 -102
  179. package/kit/framework/workflows/forensics.md +265 -265
  180. package/kit/framework/workflows/health.md +181 -181
  181. package/kit/framework/workflows/help.md +619 -619
  182. package/kit/framework/workflows/insert-phase.md +130 -130
  183. package/kit/framework/workflows/list-phase-assumptions.md +178 -178
  184. package/kit/framework/workflows/list-workspaces.md +56 -56
  185. package/kit/framework/workflows/manager.md +362 -362
  186. package/kit/framework/workflows/map-codebase.md +377 -377
  187. package/kit/framework/workflows/milestone-summary.md +223 -223
  188. package/kit/framework/workflows/new-milestone.md +486 -486
  189. package/kit/framework/workflows/new-project.md +1159 -1159
  190. package/kit/framework/workflows/new-workspace.md +237 -237
  191. package/kit/framework/workflows/next.md +97 -97
  192. package/kit/framework/workflows/node-repair.md +92 -92
  193. package/kit/framework/workflows/note.md +156 -156
  194. package/kit/framework/workflows/pause-work.md +176 -176
  195. package/kit/framework/workflows/plan-milestone-gaps.md +273 -273
  196. package/kit/framework/workflows/plan-phase.md +765 -765
  197. package/kit/framework/workflows/plant-seed.md +169 -169
  198. package/kit/framework/workflows/pr-branch.md +129 -129
  199. package/kit/framework/workflows/profile-user.md +450 -450
  200. package/kit/framework/workflows/progress.md +507 -507
  201. package/kit/framework/workflows/quick.md +757 -757
  202. package/kit/framework/workflows/remove-phase.md +155 -155
  203. package/kit/framework/workflows/remove-workspace.md +90 -90
  204. package/kit/framework/workflows/research-phase.md +82 -82
  205. package/kit/framework/workflows/resume-project.md +326 -326
  206. package/kit/framework/workflows/review.md +228 -228
  207. package/kit/framework/workflows/session-report.md +146 -146
  208. package/kit/framework/workflows/settings.md +283 -283
  209. package/kit/framework/workflows/ship.md +228 -228
  210. package/kit/framework/workflows/stats.md +60 -60
  211. package/kit/framework/workflows/transition.md +671 -671
  212. package/kit/framework/workflows/ui-phase.md +302 -302
  213. package/kit/framework/workflows/ui-review.md +165 -165
  214. package/kit/framework/workflows/update.md +323 -323
  215. package/kit/framework/workflows/validate-phase.md +174 -174
  216. package/kit/framework/workflows/verify-phase.md +252 -252
  217. package/kit/framework/workflows/verify-work.md +637 -637
  218. package/kit/hooks/check-update.js +118 -118
  219. package/kit/hooks/context-monitor.js +163 -163
  220. package/kit/hooks/prompt-guard.js +103 -103
  221. package/kit/hooks/statusline.js +125 -125
  222. package/kit/hooks/workflow-guard.js +101 -101
  223. package/kit/settings.json +45 -45
  224. package/kit/skills/example-skill/SKILL.md +42 -42
  225. package/package.json +63 -59
  226. package/src/core/kit.js +216 -216
  227. package/src/core/metrics.js +135 -10
  228. package/src/core/reflect.js +247 -247
  229. package/src/core/reverse-sync.js +372 -372
  230. package/src/core/sync.js +418 -418
  231. package/src/core/watch.js +121 -121
  232. package/src/mcp-server/index.js +34 -3
@@ -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>