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