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