@luanpdd/kit-mcp 1.28.0 → 1.30.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 (332) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +168 -168
  3. package/gates/agent-no-recursive-dispatch.md +82 -82
  4. package/kit/COMANDOS.md +138 -138
  5. package/kit/README.md +76 -76
  6. package/kit/agents/advisor-researcher.md +106 -106
  7. package/kit/agents/assumptions-analyzer.md +107 -107
  8. package/kit/agents/audit-log-implementer.md +313 -313
  9. package/kit/agents/auditor-consistencia-isolamento.md +413 -413
  10. package/kit/agents/b2b-saas-architect.md +156 -156
  11. package/kit/agents/cascading-failures-auditor.md +298 -298
  12. package/kit/agents/codebase-mapper.md +768 -768
  13. package/kit/agents/crm-pipeline-implementer.md +256 -256
  14. package/kit/agents/debugger.md +813 -813
  15. package/kit/agents/detector-tenant-quente.md +337 -337
  16. package/kit/agents/evolution-go-integrator.md +200 -200
  17. package/kit/agents/example-reviewer.md +21 -21
  18. package/kit/agents/executor.md +564 -564
  19. package/kit/agents/integration-checker.md +200 -200
  20. package/kit/agents/invite-flow-implementer.md +189 -189
  21. package/kit/agents/legacy-characterizer.md +368 -368
  22. package/kit/agents/lgpd-compliance-auditor.md +295 -295
  23. package/kit/agents/multi-tenant-isolation-auditor.md +253 -253
  24. package/kit/agents/multi-tenant-rls-writer.md +340 -340
  25. package/kit/agents/nyquist-auditor.md +178 -178
  26. package/kit/agents/observability-coverage-auditor.md +315 -315
  27. package/kit/agents/org-onboarding-implementer.md +223 -223
  28. package/kit/agents/payload-capture-instrumenter.md +273 -273
  29. package/kit/agents/phase-researcher.md +696 -696
  30. package/kit/agents/plan-checker.md +272 -272
  31. package/kit/agents/planner.md +922 -922
  32. package/kit/agents/project-researcher.md +652 -652
  33. package/kit/agents/refactor-safety-auditor.md +404 -404
  34. package/kit/agents/research-synthesizer.md +245 -245
  35. package/kit/agents/roadmapper.md +677 -677
  36. package/kit/agents/seam-finder.md +359 -359
  37. package/kit/agents/shotgun-surgery-detector.md +349 -349
  38. package/kit/agents/supabase-branching-architect.md +562 -562
  39. package/kit/agents/supabase-cicd-pipeline-implementer.md +777 -777
  40. package/kit/agents/supabase-column-privileges-writer.md +399 -399
  41. package/kit/agents/supabase-edge-fn-tester.md +287 -0
  42. package/kit/agents/supabase-edge-fn-writer.md +239 -210
  43. package/kit/agents/supabase-migration-writer.md +385 -385
  44. package/kit/agents/supabase-rbac-implementer.md +392 -392
  45. package/kit/agents/supabase-realtime-implementer.md +363 -267
  46. package/kit/agents/supabase-rls-hardener.md +521 -521
  47. package/kit/agents/supabase-rls-writer.md +323 -323
  48. package/kit/agents/supabase-roles-implementer.md +355 -355
  49. package/kit/agents/super-admin-implementer.md +281 -281
  50. package/kit/agents/ui-auditor.md +437 -437
  51. package/kit/agents/ui-checker.md +302 -302
  52. package/kit/agents/ui-researcher.md +355 -355
  53. package/kit/agents/user-profiler.md +175 -175
  54. package/kit/agents/validador-evolucao-schema.md +335 -335
  55. package/kit/agents/verifier.md +728 -728
  56. package/kit/commands/adicionar-backlog.md +75 -75
  57. package/kit/commands/adicionar-fase.md +42 -42
  58. package/kit/commands/adicionar-tarefa.md +45 -45
  59. package/kit/commands/adicionar-testes.md +41 -41
  60. package/kit/commands/ajuda.md +21 -21
  61. package/kit/commands/atualizar.md +37 -37
  62. package/kit/commands/auditar-cascading.md +111 -111
  63. package/kit/commands/auditar-marco.md +179 -179
  64. package/kit/commands/auditar-observabilidade-cobertura.md +183 -183
  65. package/kit/commands/auditar-refactor.md +219 -219
  66. package/kit/commands/auditar-release.md +109 -109
  67. package/kit/commands/auditar-uat.md +23 -23
  68. package/kit/commands/autonomo.md +40 -40
  69. package/kit/commands/branch-pr.md +24 -24
  70. package/kit/commands/burn-rate-status.md +408 -408
  71. package/kit/commands/capturar-payloads.md +193 -193
  72. package/kit/commands/caracterizar.md +212 -212
  73. package/kit/commands/concluir-marco.md +247 -247
  74. package/kit/commands/configuracoes.md +36 -36
  75. package/kit/commands/dados-distribuidos.md +188 -188
  76. package/kit/commands/definir-perfil.md +10 -10
  77. package/kit/commands/depurar.md +190 -190
  78. package/kit/commands/detectar-duplicacao.md +197 -197
  79. package/kit/commands/discutir-fase.md +131 -131
  80. package/kit/commands/encontrar-seams.md +136 -136
  81. package/kit/commands/entrar-discord.md +17 -17
  82. package/kit/commands/estatisticas.md +18 -18
  83. package/kit/commands/example-greeting.md +33 -33
  84. package/kit/commands/executar-fase.md +58 -58
  85. package/kit/commands/expresso.md +56 -56
  86. package/kit/commands/fase-ui.md +34 -34
  87. package/kit/commands/fazer.md +57 -57
  88. package/kit/commands/fio.md +125 -125
  89. package/kit/commands/fluxos-trabalho.md +64 -64
  90. package/kit/commands/forense.md +176 -176
  91. package/kit/commands/gerenciador.md +38 -38
  92. package/kit/commands/inserir-fase.md +31 -31
  93. package/kit/commands/legacy.md +263 -263
  94. package/kit/commands/limpeza.md +17 -17
  95. package/kit/commands/listar-hipoteses-fase.md +45 -45
  96. package/kit/commands/listar-workspaces.md +18 -18
  97. package/kit/commands/load-shedding.md +117 -117
  98. package/kit/commands/mapear-codebase.md +70 -70
  99. package/kit/commands/multi-tenant.md +163 -163
  100. package/kit/commands/nota.md +33 -33
  101. package/kit/commands/novo-marco.md +43 -43
  102. package/kit/commands/novo-projeto.md +41 -41
  103. package/kit/commands/novo-workspace.md +43 -43
  104. package/kit/commands/pausar-trabalho.md +37 -37
  105. package/kit/commands/perfil-usuario.md +45 -45
  106. package/kit/commands/pesquisar-fase.md +195 -195
  107. package/kit/commands/planejar-fase.md +67 -67
  108. package/kit/commands/planejar-lacunas.md +33 -33
  109. package/kit/commands/plantar-ideia.md +25 -25
  110. package/kit/commands/progresso.md +24 -24
  111. package/kit/commands/proximo.md +30 -30
  112. package/kit/commands/publicar.md +490 -490
  113. package/kit/commands/rapido.md +35 -35
  114. package/kit/commands/reaplicar-patches.md +124 -124
  115. package/kit/commands/refactor-seguro.md +321 -321
  116. package/kit/commands/relatorio-sessao.md +19 -19
  117. package/kit/commands/remover-fase.md +31 -31
  118. package/kit/commands/remover-workspace.md +26 -26
  119. package/kit/commands/resumo-marco.md +50 -50
  120. package/kit/commands/retomar-trabalho.md +40 -40
  121. package/kit/commands/revisar-backlog.md +60 -60
  122. package/kit/commands/revisar-ui.md +32 -32
  123. package/kit/commands/revisar.md +37 -37
  124. package/kit/commands/saude.md +21 -21
  125. package/kit/commands/setup-notion.md +93 -93
  126. package/kit/commands/storytelling.md +179 -179
  127. package/kit/commands/supabase.md +30 -7
  128. package/kit/commands/sync-main.md +68 -68
  129. package/kit/commands/validar-fase.md +35 -35
  130. package/kit/commands/verificar-tarefas.md +44 -44
  131. package/kit/commands/verificar-trabalho.md +64 -64
  132. package/kit/file-manifest.json +14 -8
  133. package/kit/framework/bin/lib/commands.cjs +959 -959
  134. package/kit/framework/bin/lib/config.cjs +442 -442
  135. package/kit/framework/bin/lib/core.cjs +1230 -1230
  136. package/kit/framework/bin/lib/frontmatter.cjs +336 -336
  137. package/kit/framework/bin/lib/init.cjs +1442 -1442
  138. package/kit/framework/bin/lib/milestone.cjs +252 -252
  139. package/kit/framework/bin/lib/model-profiles.cjs +68 -68
  140. package/kit/framework/bin/lib/phase.cjs +888 -888
  141. package/kit/framework/bin/lib/profile-output.cjs +952 -952
  142. package/kit/framework/bin/lib/profile-pipeline.cjs +539 -539
  143. package/kit/framework/bin/lib/roadmap.cjs +329 -329
  144. package/kit/framework/bin/lib/security.cjs +382 -382
  145. package/kit/framework/bin/lib/state.cjs +1031 -1031
  146. package/kit/framework/bin/lib/template.cjs +222 -222
  147. package/kit/framework/bin/lib/uat.cjs +282 -282
  148. package/kit/framework/bin/lib/verify.cjs +888 -888
  149. package/kit/framework/bin/lib/workstream.cjs +491 -491
  150. package/kit/framework/bin/tools.cjs +918 -918
  151. package/kit/framework/commands/workstreams.md +63 -63
  152. package/kit/framework/references/checkpoints.md +778 -778
  153. package/kit/framework/references/continuation-format.md +249 -249
  154. package/kit/framework/references/decimal-phase-calculation.md +64 -64
  155. package/kit/framework/references/git-integration.md +295 -295
  156. package/kit/framework/references/git-planning-commit.md +38 -38
  157. package/kit/framework/references/model-profile-resolution.md +36 -36
  158. package/kit/framework/references/model-profiles.md +139 -139
  159. package/kit/framework/references/phase-argument-parsing.md +61 -61
  160. package/kit/framework/references/planning-config.md +202 -202
  161. package/kit/framework/references/questioning.md +162 -162
  162. package/kit/framework/references/tdd.md +263 -263
  163. package/kit/framework/references/ui-brand.md +160 -160
  164. package/kit/framework/references/user-profiling.md +657 -657
  165. package/kit/framework/references/verification-patterns.md +612 -612
  166. package/kit/framework/references/workstream-flag.md +58 -58
  167. package/kit/framework/templates/DEBUG.md +164 -164
  168. package/kit/framework/templates/UAT.md +265 -265
  169. package/kit/framework/templates/UI-SPEC.md +100 -100
  170. package/kit/framework/templates/VALIDATION.md +76 -76
  171. package/kit/framework/templates/claude-md.md +122 -122
  172. package/kit/framework/templates/codebase/architecture.md +185 -185
  173. package/kit/framework/templates/codebase/concerns.md +205 -205
  174. package/kit/framework/templates/codebase/conventions.md +204 -204
  175. package/kit/framework/templates/codebase/integrations.md +192 -192
  176. package/kit/framework/templates/codebase/stack.md +158 -158
  177. package/kit/framework/templates/codebase/structure.md +199 -199
  178. package/kit/framework/templates/codebase/testing.md +301 -301
  179. package/kit/framework/templates/config.json +44 -44
  180. package/kit/framework/templates/context.md +352 -352
  181. package/kit/framework/templates/continue-here.md +78 -78
  182. package/kit/framework/templates/copilot-instructions.md +7 -7
  183. package/kit/framework/templates/debug-subagent-prompt.md +91 -91
  184. package/kit/framework/templates/dev-preferences.md +20 -20
  185. package/kit/framework/templates/discovery.md +146 -146
  186. package/kit/framework/templates/discussion-log.md +63 -63
  187. package/kit/framework/templates/milestone-archive.md +123 -123
  188. package/kit/framework/templates/milestone.md +115 -115
  189. package/kit/framework/templates/phase-prompt.md +610 -610
  190. package/kit/framework/templates/planner-subagent-prompt.md +117 -117
  191. package/kit/framework/templates/project.md +186 -186
  192. package/kit/framework/templates/requirements.md +231 -231
  193. package/kit/framework/templates/research-project/ARCHITECTURE.md +204 -204
  194. package/kit/framework/templates/research-project/FEATURES.md +147 -147
  195. package/kit/framework/templates/research-project/PITFALLS.md +200 -200
  196. package/kit/framework/templates/research-project/STACK.md +120 -120
  197. package/kit/framework/templates/research-project/SUMMARY.md +170 -170
  198. package/kit/framework/templates/research.md +419 -419
  199. package/kit/framework/templates/retrospective.md +54 -54
  200. package/kit/framework/templates/roadmap.md +202 -202
  201. package/kit/framework/templates/state.md +176 -176
  202. package/kit/framework/templates/summary-complex.md +59 -59
  203. package/kit/framework/templates/summary-minimal.md +41 -41
  204. package/kit/framework/templates/summary-standard.md +48 -48
  205. package/kit/framework/templates/summary.md +209 -209
  206. package/kit/framework/templates/user-profile.md +146 -146
  207. package/kit/framework/templates/user-setup.md +256 -256
  208. package/kit/framework/templates/verification-report.md +258 -258
  209. package/kit/framework/workflows/add-phase.md +112 -112
  210. package/kit/framework/workflows/add-tests.md +351 -351
  211. package/kit/framework/workflows/add-todo.md +158 -158
  212. package/kit/framework/workflows/audit-milestone.md +340 -340
  213. package/kit/framework/workflows/audit-uat.md +109 -109
  214. package/kit/framework/workflows/autonomous.md +891 -891
  215. package/kit/framework/workflows/check-todos.md +177 -177
  216. package/kit/framework/workflows/cleanup.md +152 -152
  217. package/kit/framework/workflows/complete-milestone.md +696 -696
  218. package/kit/framework/workflows/diagnose-issues.md +231 -231
  219. package/kit/framework/workflows/discovery-phase.md +289 -289
  220. package/kit/framework/workflows/discuss-phase-assumptions.md +653 -653
  221. package/kit/framework/workflows/discuss-phase.md +784 -784
  222. package/kit/framework/workflows/do.md +104 -104
  223. package/kit/framework/workflows/execute-phase.md +838 -838
  224. package/kit/framework/workflows/execute-plan.md +510 -510
  225. package/kit/framework/workflows/fast.md +102 -102
  226. package/kit/framework/workflows/forensics.md +265 -265
  227. package/kit/framework/workflows/health.md +181 -181
  228. package/kit/framework/workflows/help.md +619 -619
  229. package/kit/framework/workflows/insert-phase.md +130 -130
  230. package/kit/framework/workflows/list-phase-assumptions.md +178 -178
  231. package/kit/framework/workflows/list-workspaces.md +56 -56
  232. package/kit/framework/workflows/manager.md +362 -362
  233. package/kit/framework/workflows/map-codebase.md +377 -377
  234. package/kit/framework/workflows/milestone-summary.md +223 -223
  235. package/kit/framework/workflows/new-milestone.md +486 -486
  236. package/kit/framework/workflows/new-project.md +1159 -1159
  237. package/kit/framework/workflows/new-workspace.md +237 -237
  238. package/kit/framework/workflows/next.md +97 -97
  239. package/kit/framework/workflows/node-repair.md +92 -92
  240. package/kit/framework/workflows/note.md +156 -156
  241. package/kit/framework/workflows/pause-work.md +176 -176
  242. package/kit/framework/workflows/plan-milestone-gaps.md +273 -273
  243. package/kit/framework/workflows/plan-phase.md +765 -765
  244. package/kit/framework/workflows/plant-seed.md +169 -169
  245. package/kit/framework/workflows/pr-branch.md +129 -129
  246. package/kit/framework/workflows/profile-user.md +450 -450
  247. package/kit/framework/workflows/progress.md +507 -507
  248. package/kit/framework/workflows/quick.md +757 -757
  249. package/kit/framework/workflows/remove-phase.md +155 -155
  250. package/kit/framework/workflows/remove-workspace.md +90 -90
  251. package/kit/framework/workflows/research-phase.md +82 -82
  252. package/kit/framework/workflows/resume-project.md +326 -326
  253. package/kit/framework/workflows/review.md +228 -228
  254. package/kit/framework/workflows/session-report.md +146 -146
  255. package/kit/framework/workflows/settings.md +283 -283
  256. package/kit/framework/workflows/ship.md +228 -228
  257. package/kit/framework/workflows/stats.md +60 -60
  258. package/kit/framework/workflows/transition.md +671 -671
  259. package/kit/framework/workflows/ui-phase.md +302 -302
  260. package/kit/framework/workflows/ui-review.md +165 -165
  261. package/kit/framework/workflows/update.md +323 -323
  262. package/kit/framework/workflows/validate-phase.md +174 -174
  263. package/kit/framework/workflows/verify-phase.md +252 -252
  264. package/kit/framework/workflows/verify-work.md +637 -637
  265. package/kit/hooks/check-update.js +118 -118
  266. package/kit/hooks/context-monitor.js +163 -163
  267. package/kit/hooks/prompt-guard.js +103 -103
  268. package/kit/hooks/statusline.js +125 -125
  269. package/kit/hooks/workflow-guard.js +101 -101
  270. package/kit/settings.json +45 -45
  271. package/kit/skills/_shared-supabase/glossary.md +17 -0
  272. package/kit/skills/ai-prompt-characterization/SKILL.md +335 -335
  273. package/kit/skills/armadilhas-sistemas-distribuidos/SKILL.md +447 -447
  274. package/kit/skills/audit-log-multi-tenant/SKILL.md +340 -340
  275. package/kit/skills/b2b-saas-architecture/SKILL.md +300 -300
  276. package/kit/skills/consistencia-leitura-replica/SKILL.md +385 -385
  277. package/kit/skills/crm-lead-pipeline-patterns/SKILL.md +343 -343
  278. package/kit/skills/escolha-modelo-consistencia/SKILL.md +494 -494
  279. package/kit/skills/evolucao-schema-compativel/SKILL.md +448 -448
  280. package/kit/skills/evolution-go-whatsapp-integration/SKILL.md +322 -322
  281. package/kit/skills/example-skill/SKILL.md +42 -42
  282. package/kit/skills/legacy-api-only-applications/SKILL.md +358 -358
  283. package/kit/skills/legacy-characterization-tests/SKILL.md +330 -330
  284. package/kit/skills/legacy-effect-analysis/SKILL.md +331 -331
  285. package/kit/skills/legacy-extract-class/SKILL.md +203 -203
  286. package/kit/skills/legacy-programming-by-difference/SKILL.md +252 -252
  287. package/kit/skills/legacy-seams-and-test-harness/SKILL.md +460 -460
  288. package/kit/skills/legacy-shotgun-surgery/SKILL.md +286 -286
  289. package/kit/skills/legacy-sprout-wrap-techniques/SKILL.md +434 -434
  290. package/kit/skills/legacy-storytelling-naked-crc/SKILL.md +270 -270
  291. package/kit/skills/lgpd-multi-tenant-compliance/SKILL.md +340 -340
  292. package/kit/skills/member-invite-flow/SKILL.md +305 -305
  293. package/kit/skills/member-management-react-shadcn/SKILL.md +328 -328
  294. package/kit/skills/multi-tenant-performance-scaling/SKILL.md +316 -316
  295. package/kit/skills/multi-tenant-rls-hierarchy/SKILL.md +342 -342
  296. package/kit/skills/org-onboarding-flow/SKILL.md +257 -257
  297. package/kit/skills/org-switcher-react-pattern/SKILL.md +349 -349
  298. package/kit/skills/permission-gate-react-pattern/SKILL.md +271 -271
  299. package/kit/skills/postgres-isolamento-concorrencia/SKILL.md +552 -552
  300. package/kit/skills/pre-refactor-characterization/SKILL.md +421 -421
  301. package/kit/skills/rbac-permissions-matrix-supabase/SKILL.md +338 -338
  302. package/kit/skills/streams-eventos-cdc/SKILL.md +711 -711
  303. package/kit/skills/supabase-branching-workflow/SKILL.md +544 -544
  304. package/kit/skills/supabase-ci-cd-github-actions/SKILL.md +880 -880
  305. package/kit/skills/supabase-column-level-security/SKILL.md +426 -426
  306. package/kit/skills/supabase-config-toml-remotes/SKILL.md +807 -807
  307. package/kit/skills/supabase-custom-claims-rbac/SKILL.md +472 -472
  308. package/kit/skills/supabase-edge-functions/SKILL.md +229 -141
  309. package/kit/skills/supabase-edge-functions-auth/SKILL.md +309 -0
  310. package/kit/skills/supabase-edge-functions-limits/SKILL.md +302 -0
  311. package/kit/skills/supabase-edge-functions-mcp-server/SKILL.md +279 -0
  312. package/kit/skills/supabase-edge-functions-testing/SKILL.md +277 -0
  313. package/kit/skills/supabase-edge-runtime-builtins/SKILL.md +357 -0
  314. package/kit/skills/supabase-migration-repair/SKILL.md +823 -823
  315. package/kit/skills/supabase-migrations/SKILL.md +297 -297
  316. package/kit/skills/supabase-pgtap-testing/SKILL.md +1053 -1053
  317. package/kit/skills/supabase-postgres-roles/SKILL.md +392 -392
  318. package/kit/skills/supabase-realtime/SKILL.md +460 -236
  319. package/kit/skills/supabase-rls-defense-in-depth/SKILL.md +418 -418
  320. package/kit/skills/supabase-rls-policies/SKILL.md +635 -635
  321. package/kit/skills/super-admin-platform-pattern/SKILL.md +326 -326
  322. package/kit/skills/tenant-quente-mitigacao/SKILL.md +605 -605
  323. package/kit/skills/whatsapp-conversation-state-machine/SKILL.md +287 -287
  324. package/package.json +1 -1
  325. package/src/cli/index.js +33 -0
  326. package/src/core/kit.js +216 -216
  327. package/src/core/reflect.js +247 -247
  328. package/src/core/reverse-sync.js +372 -372
  329. package/src/core/sync.js +418 -418
  330. package/src/core/watch.js +121 -121
  331. package/src/mcp-server/index.js +693 -490
  332. package/src/mcp-server/roots.js +124 -0
@@ -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>