@luanpdd/kit-mcp 1.30.2 → 1.31.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 (347) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +168 -168
  3. package/gates/agent-no-recursive-dispatch.md +84 -82
  4. package/kit/COMANDOS.md +138 -138
  5. package/kit/README.md +76 -76
  6. package/kit/agents/advisor-researcher.md +107 -106
  7. package/kit/agents/ai-mutation-tester.md +1 -0
  8. package/kit/agents/assumptions-analyzer.md +108 -107
  9. package/kit/agents/audit-log-implementer.md +314 -313
  10. package/kit/agents/auditor-consistencia-isolamento.md +414 -413
  11. package/kit/agents/b2b-saas-architect.md +157 -156
  12. package/kit/agents/burn-rate-forecaster.md +1 -0
  13. package/kit/agents/cascading-failures-auditor.md +299 -298
  14. package/kit/agents/codebase-mapper.md +769 -768
  15. package/kit/agents/crm-pipeline-implementer.md +257 -256
  16. package/kit/agents/debugger.md +814 -813
  17. package/kit/agents/detector-tenant-quente.md +338 -337
  18. package/kit/agents/evolution-go-integrator.md +201 -200
  19. package/kit/agents/example-reviewer.md +22 -21
  20. package/kit/agents/executor.md +565 -564
  21. package/kit/agents/golden-signals-instrumenter.md +1 -0
  22. package/kit/agents/incident-investigator.md +1 -0
  23. package/kit/agents/integration-checker.md +201 -200
  24. package/kit/agents/invite-flow-implementer.md +190 -189
  25. package/kit/agents/legacy-characterizer.md +369 -368
  26. package/kit/agents/lgpd-compliance-auditor.md +296 -295
  27. package/kit/agents/load-shedding-instrumenter.md +1 -0
  28. package/kit/agents/multi-tenant-isolation-auditor.md +254 -253
  29. package/kit/agents/multi-tenant-rls-writer.md +341 -340
  30. package/kit/agents/nyquist-auditor.md +179 -178
  31. package/kit/agents/observability-coverage-auditor.md +316 -315
  32. package/kit/agents/observability-instrumenter.md +1 -0
  33. package/kit/agents/omm-auditor.md +1 -0
  34. package/kit/agents/org-onboarding-implementer.md +224 -223
  35. package/kit/agents/payload-capture-instrumenter.md +274 -273
  36. package/kit/agents/phase-researcher.md +697 -696
  37. package/kit/agents/plan-checker.md +273 -272
  38. package/kit/agents/planner.md +923 -922
  39. package/kit/agents/postmortem-writer.md +1 -0
  40. package/kit/agents/project-researcher.md +653 -652
  41. package/kit/agents/prr-conductor.md +1 -0
  42. package/kit/agents/refactor-safety-auditor.md +405 -404
  43. package/kit/agents/release-pipeline-auditor.md +1 -0
  44. package/kit/agents/research-synthesizer.md +246 -245
  45. package/kit/agents/roadmapper.md +678 -677
  46. package/kit/agents/schema-checker.md +1 -0
  47. package/kit/agents/seam-finder.md +360 -359
  48. package/kit/agents/shotgun-surgery-detector.md +350 -349
  49. package/kit/agents/slo-engineer.md +1 -0
  50. package/kit/agents/storytelling-analyst.md +1 -0
  51. package/kit/agents/supabase-architect.md +1 -0
  52. package/kit/agents/supabase-auth-bootstrapper.md +1 -0
  53. package/kit/agents/supabase-branching-architect.md +563 -562
  54. package/kit/agents/supabase-cicd-pipeline-implementer.md +778 -777
  55. package/kit/agents/supabase-column-privileges-writer.md +400 -399
  56. package/kit/agents/supabase-edge-fn-tester.md +2 -1
  57. package/kit/agents/supabase-edge-fn-writer.md +2 -1
  58. package/kit/agents/supabase-migration-writer.md +386 -385
  59. package/kit/agents/supabase-rbac-implementer.md +393 -392
  60. package/kit/agents/supabase-realtime-implementer.md +364 -363
  61. package/kit/agents/supabase-rls-hardener.md +522 -521
  62. package/kit/agents/supabase-rls-writer.md +324 -323
  63. package/kit/agents/supabase-roles-implementer.md +356 -355
  64. package/kit/agents/supabase-storage-implementer.md +1 -0
  65. package/kit/agents/super-admin-implementer.md +282 -281
  66. package/kit/agents/toil-auditor.md +1 -0
  67. package/kit/agents/ui-auditor.md +438 -437
  68. package/kit/agents/ui-checker.md +303 -302
  69. package/kit/agents/ui-researcher.md +356 -355
  70. package/kit/agents/user-profiler.md +176 -175
  71. package/kit/agents/validador-evolucao-schema.md +336 -335
  72. package/kit/agents/verifier.md +729 -728
  73. package/kit/commands/adicionar-backlog.md +75 -75
  74. package/kit/commands/adicionar-fase.md +42 -42
  75. package/kit/commands/adicionar-tarefa.md +45 -45
  76. package/kit/commands/adicionar-testes.md +41 -41
  77. package/kit/commands/ajuda.md +21 -21
  78. package/kit/commands/atualizar.md +37 -37
  79. package/kit/commands/auditar-cascading.md +111 -111
  80. package/kit/commands/auditar-marco.md +179 -179
  81. package/kit/commands/auditar-observabilidade-cobertura.md +183 -183
  82. package/kit/commands/auditar-refactor.md +219 -219
  83. package/kit/commands/auditar-release.md +109 -109
  84. package/kit/commands/auditar-uat.md +23 -23
  85. package/kit/commands/autonomo.md +40 -40
  86. package/kit/commands/branch-pr.md +24 -24
  87. package/kit/commands/burn-rate-status.md +408 -408
  88. package/kit/commands/capturar-payloads.md +193 -193
  89. package/kit/commands/caracterizar.md +212 -212
  90. package/kit/commands/concluir-marco.md +247 -247
  91. package/kit/commands/configuracoes.md +36 -36
  92. package/kit/commands/dados-distribuidos.md +188 -188
  93. package/kit/commands/definir-perfil.md +10 -10
  94. package/kit/commands/depurar.md +190 -190
  95. package/kit/commands/detectar-duplicacao.md +197 -197
  96. package/kit/commands/discutir-fase.md +131 -131
  97. package/kit/commands/encontrar-seams.md +136 -136
  98. package/kit/commands/entrar-discord.md +17 -17
  99. package/kit/commands/estatisticas.md +18 -18
  100. package/kit/commands/example-greeting.md +33 -33
  101. package/kit/commands/executar-fase.md +58 -58
  102. package/kit/commands/expresso.md +56 -56
  103. package/kit/commands/fase-ui.md +34 -34
  104. package/kit/commands/fazer.md +57 -57
  105. package/kit/commands/fio.md +125 -125
  106. package/kit/commands/fluxos-trabalho.md +64 -64
  107. package/kit/commands/forense.md +176 -176
  108. package/kit/commands/gerenciador.md +38 -38
  109. package/kit/commands/inserir-fase.md +31 -31
  110. package/kit/commands/legacy.md +263 -263
  111. package/kit/commands/limpeza.md +17 -17
  112. package/kit/commands/listar-hipoteses-fase.md +45 -45
  113. package/kit/commands/listar-workspaces.md +18 -18
  114. package/kit/commands/load-shedding.md +117 -117
  115. package/kit/commands/mapear-codebase.md +70 -70
  116. package/kit/commands/multi-tenant.md +163 -163
  117. package/kit/commands/nota.md +33 -33
  118. package/kit/commands/novo-marco.md +43 -43
  119. package/kit/commands/novo-projeto.md +41 -41
  120. package/kit/commands/novo-workspace.md +43 -43
  121. package/kit/commands/pausar-trabalho.md +37 -37
  122. package/kit/commands/perfil-usuario.md +45 -45
  123. package/kit/commands/pesquisar-fase.md +195 -195
  124. package/kit/commands/planejar-fase.md +67 -67
  125. package/kit/commands/planejar-lacunas.md +33 -33
  126. package/kit/commands/plantar-ideia.md +25 -25
  127. package/kit/commands/progresso.md +24 -24
  128. package/kit/commands/proximo.md +30 -30
  129. package/kit/commands/publicar.md +490 -490
  130. package/kit/commands/rapido.md +35 -35
  131. package/kit/commands/reaplicar-patches.md +124 -124
  132. package/kit/commands/refactor-seguro.md +321 -321
  133. package/kit/commands/relatorio-sessao.md +19 -19
  134. package/kit/commands/remover-fase.md +31 -31
  135. package/kit/commands/remover-workspace.md +26 -26
  136. package/kit/commands/resumo-marco.md +50 -50
  137. package/kit/commands/retomar-trabalho.md +40 -40
  138. package/kit/commands/revisar-backlog.md +60 -60
  139. package/kit/commands/revisar-ui.md +32 -32
  140. package/kit/commands/revisar.md +37 -37
  141. package/kit/commands/saude.md +21 -21
  142. package/kit/commands/setup-notion.md +93 -93
  143. package/kit/commands/storytelling.md +179 -179
  144. package/kit/commands/sync-main.md +68 -68
  145. package/kit/commands/validar-fase.md +35 -35
  146. package/kit/commands/verificar-tarefas.md +44 -44
  147. package/kit/commands/verificar-trabalho.md +64 -64
  148. package/kit/file-manifest.json +82 -81
  149. package/kit/framework/bin/lib/commands.cjs +959 -959
  150. package/kit/framework/bin/lib/config.cjs +442 -442
  151. package/kit/framework/bin/lib/core.cjs +1230 -1230
  152. package/kit/framework/bin/lib/frontmatter.cjs +336 -336
  153. package/kit/framework/bin/lib/init.cjs +1442 -1442
  154. package/kit/framework/bin/lib/milestone.cjs +252 -252
  155. package/kit/framework/bin/lib/model-profiles.cjs +68 -68
  156. package/kit/framework/bin/lib/phase.cjs +888 -888
  157. package/kit/framework/bin/lib/profile-output.cjs +952 -952
  158. package/kit/framework/bin/lib/profile-pipeline.cjs +539 -539
  159. package/kit/framework/bin/lib/roadmap.cjs +329 -329
  160. package/kit/framework/bin/lib/security.cjs +382 -382
  161. package/kit/framework/bin/lib/state.cjs +1031 -1031
  162. package/kit/framework/bin/lib/template.cjs +222 -222
  163. package/kit/framework/bin/lib/uat.cjs +282 -282
  164. package/kit/framework/bin/lib/verify.cjs +888 -888
  165. package/kit/framework/bin/lib/workstream.cjs +491 -491
  166. package/kit/framework/bin/tools.cjs +918 -918
  167. package/kit/framework/commands/workstreams.md +63 -63
  168. package/kit/framework/references/checkpoints.md +778 -778
  169. package/kit/framework/references/continuation-format.md +249 -249
  170. package/kit/framework/references/decimal-phase-calculation.md +64 -64
  171. package/kit/framework/references/git-integration.md +295 -295
  172. package/kit/framework/references/git-planning-commit.md +38 -38
  173. package/kit/framework/references/model-profile-resolution.md +36 -36
  174. package/kit/framework/references/model-profiles.md +139 -139
  175. package/kit/framework/references/phase-argument-parsing.md +61 -61
  176. package/kit/framework/references/planning-config.md +202 -202
  177. package/kit/framework/references/questioning.md +162 -162
  178. package/kit/framework/references/tdd.md +263 -263
  179. package/kit/framework/references/ui-brand.md +160 -160
  180. package/kit/framework/references/user-profiling.md +657 -657
  181. package/kit/framework/references/verification-patterns.md +612 -612
  182. package/kit/framework/references/workstream-flag.md +58 -58
  183. package/kit/framework/templates/DEBUG.md +164 -164
  184. package/kit/framework/templates/UAT.md +265 -265
  185. package/kit/framework/templates/UI-SPEC.md +100 -100
  186. package/kit/framework/templates/VALIDATION.md +76 -76
  187. package/kit/framework/templates/claude-md.md +122 -122
  188. package/kit/framework/templates/codebase/architecture.md +185 -185
  189. package/kit/framework/templates/codebase/concerns.md +205 -205
  190. package/kit/framework/templates/codebase/conventions.md +204 -204
  191. package/kit/framework/templates/codebase/integrations.md +192 -192
  192. package/kit/framework/templates/codebase/stack.md +158 -158
  193. package/kit/framework/templates/codebase/structure.md +199 -199
  194. package/kit/framework/templates/codebase/testing.md +301 -301
  195. package/kit/framework/templates/config.json +44 -44
  196. package/kit/framework/templates/context.md +352 -352
  197. package/kit/framework/templates/continue-here.md +78 -78
  198. package/kit/framework/templates/copilot-instructions.md +7 -7
  199. package/kit/framework/templates/debug-subagent-prompt.md +91 -91
  200. package/kit/framework/templates/dev-preferences.md +20 -20
  201. package/kit/framework/templates/discovery.md +146 -146
  202. package/kit/framework/templates/discussion-log.md +63 -63
  203. package/kit/framework/templates/milestone-archive.md +123 -123
  204. package/kit/framework/templates/milestone.md +115 -115
  205. package/kit/framework/templates/phase-prompt.md +610 -610
  206. package/kit/framework/templates/planner-subagent-prompt.md +117 -117
  207. package/kit/framework/templates/project.md +186 -186
  208. package/kit/framework/templates/requirements.md +231 -231
  209. package/kit/framework/templates/research-project/ARCHITECTURE.md +204 -204
  210. package/kit/framework/templates/research-project/FEATURES.md +147 -147
  211. package/kit/framework/templates/research-project/PITFALLS.md +200 -200
  212. package/kit/framework/templates/research-project/STACK.md +120 -120
  213. package/kit/framework/templates/research-project/SUMMARY.md +170 -170
  214. package/kit/framework/templates/research.md +419 -419
  215. package/kit/framework/templates/retrospective.md +54 -54
  216. package/kit/framework/templates/roadmap.md +202 -202
  217. package/kit/framework/templates/state.md +176 -176
  218. package/kit/framework/templates/summary-complex.md +59 -59
  219. package/kit/framework/templates/summary-minimal.md +41 -41
  220. package/kit/framework/templates/summary-standard.md +48 -48
  221. package/kit/framework/templates/summary.md +209 -209
  222. package/kit/framework/templates/user-profile.md +146 -146
  223. package/kit/framework/templates/user-setup.md +256 -256
  224. package/kit/framework/templates/verification-report.md +258 -258
  225. package/kit/framework/workflows/add-phase.md +112 -112
  226. package/kit/framework/workflows/add-tests.md +351 -351
  227. package/kit/framework/workflows/add-todo.md +158 -158
  228. package/kit/framework/workflows/audit-milestone.md +340 -340
  229. package/kit/framework/workflows/audit-uat.md +109 -109
  230. package/kit/framework/workflows/autonomous.md +891 -891
  231. package/kit/framework/workflows/check-todos.md +177 -177
  232. package/kit/framework/workflows/cleanup.md +152 -152
  233. package/kit/framework/workflows/complete-milestone.md +696 -696
  234. package/kit/framework/workflows/diagnose-issues.md +231 -231
  235. package/kit/framework/workflows/discovery-phase.md +289 -289
  236. package/kit/framework/workflows/discuss-phase-assumptions.md +653 -653
  237. package/kit/framework/workflows/discuss-phase.md +784 -784
  238. package/kit/framework/workflows/do.md +104 -104
  239. package/kit/framework/workflows/execute-phase.md +838 -838
  240. package/kit/framework/workflows/execute-plan.md +510 -510
  241. package/kit/framework/workflows/fast.md +102 -102
  242. package/kit/framework/workflows/forensics.md +265 -265
  243. package/kit/framework/workflows/health.md +181 -181
  244. package/kit/framework/workflows/help.md +619 -619
  245. package/kit/framework/workflows/insert-phase.md +130 -130
  246. package/kit/framework/workflows/list-phase-assumptions.md +178 -178
  247. package/kit/framework/workflows/list-workspaces.md +56 -56
  248. package/kit/framework/workflows/manager.md +362 -362
  249. package/kit/framework/workflows/map-codebase.md +377 -377
  250. package/kit/framework/workflows/milestone-summary.md +223 -223
  251. package/kit/framework/workflows/new-milestone.md +486 -486
  252. package/kit/framework/workflows/new-project.md +1159 -1159
  253. package/kit/framework/workflows/new-workspace.md +237 -237
  254. package/kit/framework/workflows/next.md +97 -97
  255. package/kit/framework/workflows/node-repair.md +92 -92
  256. package/kit/framework/workflows/note.md +156 -156
  257. package/kit/framework/workflows/pause-work.md +176 -176
  258. package/kit/framework/workflows/plan-milestone-gaps.md +273 -273
  259. package/kit/framework/workflows/plan-phase.md +765 -765
  260. package/kit/framework/workflows/plant-seed.md +169 -169
  261. package/kit/framework/workflows/pr-branch.md +129 -129
  262. package/kit/framework/workflows/profile-user.md +450 -450
  263. package/kit/framework/workflows/progress.md +507 -507
  264. package/kit/framework/workflows/quick.md +757 -757
  265. package/kit/framework/workflows/remove-phase.md +155 -155
  266. package/kit/framework/workflows/remove-workspace.md +90 -90
  267. package/kit/framework/workflows/research-phase.md +82 -82
  268. package/kit/framework/workflows/resume-project.md +326 -326
  269. package/kit/framework/workflows/review.md +228 -228
  270. package/kit/framework/workflows/session-report.md +146 -146
  271. package/kit/framework/workflows/settings.md +283 -283
  272. package/kit/framework/workflows/ship.md +228 -228
  273. package/kit/framework/workflows/stats.md +60 -60
  274. package/kit/framework/workflows/transition.md +671 -671
  275. package/kit/framework/workflows/ui-phase.md +302 -302
  276. package/kit/framework/workflows/ui-review.md +165 -165
  277. package/kit/framework/workflows/update.md +323 -323
  278. package/kit/framework/workflows/validate-phase.md +174 -174
  279. package/kit/framework/workflows/verify-phase.md +252 -252
  280. package/kit/framework/workflows/verify-work.md +637 -637
  281. package/kit/hooks/check-update.js +118 -118
  282. package/kit/hooks/context-monitor.js +163 -163
  283. package/kit/hooks/kit-attribution-reminder.cjs +29 -50
  284. package/kit/hooks/kit-router.cjs +137 -0
  285. package/kit/hooks/prompt-guard.js +103 -103
  286. package/kit/hooks/statusline.js +125 -125
  287. package/kit/hooks/workflow-guard.js +101 -101
  288. package/kit/settings.json +45 -45
  289. package/kit/skills/ai-prompt-characterization/SKILL.md +335 -335
  290. package/kit/skills/armadilhas-sistemas-distribuidos/SKILL.md +447 -447
  291. package/kit/skills/audit-log-multi-tenant/SKILL.md +340 -340
  292. package/kit/skills/b2b-saas-architecture/SKILL.md +300 -300
  293. package/kit/skills/consistencia-leitura-replica/SKILL.md +385 -385
  294. package/kit/skills/crm-lead-pipeline-patterns/SKILL.md +343 -343
  295. package/kit/skills/escolha-modelo-consistencia/SKILL.md +494 -494
  296. package/kit/skills/evolucao-schema-compativel/SKILL.md +448 -448
  297. package/kit/skills/evolution-go-whatsapp-integration/SKILL.md +322 -322
  298. package/kit/skills/example-skill/SKILL.md +42 -42
  299. package/kit/skills/legacy-api-only-applications/SKILL.md +358 -358
  300. package/kit/skills/legacy-characterization-tests/SKILL.md +330 -330
  301. package/kit/skills/legacy-effect-analysis/SKILL.md +331 -331
  302. package/kit/skills/legacy-extract-class/SKILL.md +203 -203
  303. package/kit/skills/legacy-programming-by-difference/SKILL.md +252 -252
  304. package/kit/skills/legacy-seams-and-test-harness/SKILL.md +460 -460
  305. package/kit/skills/legacy-shotgun-surgery/SKILL.md +286 -286
  306. package/kit/skills/legacy-sprout-wrap-techniques/SKILL.md +434 -434
  307. package/kit/skills/legacy-storytelling-naked-crc/SKILL.md +270 -270
  308. package/kit/skills/lgpd-multi-tenant-compliance/SKILL.md +340 -340
  309. package/kit/skills/member-invite-flow/SKILL.md +305 -305
  310. package/kit/skills/member-management-react-shadcn/SKILL.md +328 -328
  311. package/kit/skills/multi-tenant-performance-scaling/SKILL.md +316 -316
  312. package/kit/skills/multi-tenant-rls-hierarchy/SKILL.md +342 -342
  313. package/kit/skills/org-onboarding-flow/SKILL.md +257 -257
  314. package/kit/skills/org-switcher-react-pattern/SKILL.md +349 -349
  315. package/kit/skills/permission-gate-react-pattern/SKILL.md +271 -271
  316. package/kit/skills/postgres-isolamento-concorrencia/SKILL.md +552 -552
  317. package/kit/skills/pre-refactor-characterization/SKILL.md +421 -421
  318. package/kit/skills/rbac-permissions-matrix-supabase/SKILL.md +338 -338
  319. package/kit/skills/streams-eventos-cdc/SKILL.md +711 -711
  320. package/kit/skills/supabase-branching-workflow/SKILL.md +544 -544
  321. package/kit/skills/supabase-ci-cd-github-actions/SKILL.md +880 -880
  322. package/kit/skills/supabase-column-level-security/SKILL.md +426 -426
  323. package/kit/skills/supabase-config-toml-remotes/SKILL.md +807 -807
  324. package/kit/skills/supabase-custom-claims-rbac/SKILL.md +472 -472
  325. package/kit/skills/supabase-edge-functions/SKILL.md +1 -1
  326. package/kit/skills/supabase-edge-functions-auth/SKILL.md +1 -1
  327. package/kit/skills/supabase-edge-functions-limits/SKILL.md +1 -1
  328. package/kit/skills/supabase-edge-functions-mcp-server/SKILL.md +1 -1
  329. package/kit/skills/supabase-edge-functions-testing/SKILL.md +1 -1
  330. package/kit/skills/supabase-edge-runtime-builtins/SKILL.md +1 -1
  331. package/kit/skills/supabase-migration-repair/SKILL.md +823 -823
  332. package/kit/skills/supabase-migrations/SKILL.md +297 -297
  333. package/kit/skills/supabase-pgtap-testing/SKILL.md +1053 -1053
  334. package/kit/skills/supabase-postgres-roles/SKILL.md +392 -392
  335. package/kit/skills/supabase-realtime/SKILL.md +460 -460
  336. package/kit/skills/supabase-rls-defense-in-depth/SKILL.md +418 -418
  337. package/kit/skills/supabase-rls-policies/SKILL.md +635 -635
  338. package/kit/skills/super-admin-platform-pattern/SKILL.md +326 -326
  339. package/kit/skills/tenant-quente-mitigacao/SKILL.md +605 -605
  340. package/kit/skills/whatsapp-conversation-state-machine/SKILL.md +287 -287
  341. package/package.json +1 -1
  342. package/src/core/kit.js +216 -216
  343. package/src/core/reflect.js +247 -247
  344. package/src/core/reverse-sync.js +372 -372
  345. package/src/core/sync.js +437 -418
  346. package/src/core/watch.js +121 -121
  347. package/src/mcp-server/index.js +794 -746
@@ -1,351 +1,351 @@
1
- <purpose>
2
- Gerar testes unitários e E2E para uma fase concluída com base em seu SUMMARY.md, CONTEXT.md e implementação. Classifica cada arquivo alterado nas categorias TDD (unitário), E2E (navegador) ou Skip, apresenta um plano de testes para aprovação do usuário, então gera testes seguindo as convenções RED-GREEN.
3
-
4
- Os usuários atualmente criam prompts `/expresso` manualmente para geração de testes após cada fase. Este workflow padroniza o processo com classificação adequada, portões de qualidade e relatório de lacunas.
5
- </purpose>
6
-
7
- <required_reading>
8
- Leia todos os arquivos referenciados pelo execution_context do prompt que invocou antes de começar.
9
- </required_reading>
10
-
11
- <process>
12
-
13
- <step name="parse_arguments">
14
- Analisar `$ARGUMENTS` para:
15
- - Número de fase (inteiro, decimal ou sufixo de letra) → armazenar como `$PHASE_ARG`
16
- - Texto restante após o número da fase → armazenar como `$EXTRA_INSTRUCTIONS` (opcional)
17
-
18
- Exemplo: `/adicionar-testes 12 focar nos casos extremos` → `$PHASE_ARG=12`, `$EXTRA_INSTRUCTIONS="focar nos casos extremos"`
19
-
20
- Se nenhum argumento de fase fornecido:
21
-
22
- ```
23
- ERRO: Número de fase obrigatório
24
- Uso: /adicionar-testes <fase> [instruções adicionais]
25
- Exemplo: /adicionar-testes 12
26
- Exemplo: /adicionar-testes 12 focar nos casos extremos no módulo de preços
27
- ```
28
-
29
- Sair.
30
- </step>
31
-
32
- <step name="init_context">
33
- Carregar contexto de operação de fase:
34
-
35
- ```bash
36
- INIT=$(node "./.claude/framework/bin/tools.cjs" init phase-op "${PHASE_ARG}")
37
- if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
38
- ```
39
-
40
- Extrair do JSON de init: `phase_dir`, `phase_number`, `phase_name`.
41
-
42
- Verificar se o diretório de fase existe. Se não:
43
- ```
44
- ERRO: Diretório de fase não encontrado para a fase ${PHASE_ARG}
45
- Certifique-se de que a fase existe em .planning/phases/
46
- ```
47
- Sair.
48
-
49
- Ler os artefatos da fase (em ordem de prioridade):
50
- 1. `${phase_dir}/*-SUMMARY.md` — o que foi implementado, arquivos alterados
51
- 2. `${phase_dir}/CONTEXT.md` — critérios de aceitação, decisões
52
- 3. `${phase_dir}/*-VERIFICATION.md` — cenários verificados pelo usuário (se UAT foi feito)
53
-
54
- Se nenhum SUMMARY.md existir:
55
- ```
56
- ERRO: Nenhum SUMMARY.md encontrado para a fase ${PHASE_ARG}
57
- Este comando funciona em fases concluídas. Execute /executar-fase primeiro.
58
- ```
59
- Sair.
60
-
61
- Apresentar banner:
62
- ```
63
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
64
- framework ► ADICIONAR TESTES — Fase ${phase_number}: ${phase_name}
65
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
66
- ```
67
- </step>
68
-
69
- <step name="analyze_implementation">
70
- Extrair a lista de arquivos modificados pela fase do SUMMARY.md (seção "Files Changed" ou equivalente).
71
-
72
- Para cada arquivo, classificar em uma das três categorias:
73
-
74
- | Categoria | Critérios | Tipo de Teste |
75
- |-----------|-----------|---------------|
76
- | **TDD** | Funções puras onde `expect(fn(input)).toBe(output)` é escrevível | Testes unitários |
77
- | **E2E** | Comportamento de UI verificável por automação de navegador | Testes Playwright/E2E |
78
- | **Skip** | Não testável de forma significativa ou já coberto | Nenhum |
79
-
80
- **Classificação TDD — aplicar quando:**
81
- - Lógica de negócio: cálculos, preços, regras fiscais, validação
82
- - Transformações de dados: mapeamento, filtragem, agregação, formatação
83
- - Parsers: CSV, JSON, XML, análise de formato personalizado
84
- - Validadores: validação de input, validação de schema, regras de negócio
85
- - Máquinas de estado: transições de status, etapas de workflow
86
- - Utilitários: manipulação de strings, tratamento de datas, formatação de números
87
-
88
- **Classificação E2E — aplicar quando:**
89
- - Atalhos de teclado: keybindings, teclas modificadoras, sequências de accordes
90
- - Navegação: transições de página, roteamento, breadcrumbs, voltar/avançar
91
- - Interações de formulário: envio, erros de validação, foco de campo, autocomplete
92
- - Seleção: seleção de linha, multi-seleção, intervalos com shift-click
93
- - Arrastar e soltar: reordenação, mover entre contêineres
94
- - Diálogos modais: abrir, fechar, confirmar, cancelar
95
- - Grids de dados: ordenação, filtragem, edição inline, redimensionamento de coluna
96
-
97
- **Classificação Skip — aplicar quando:**
98
- - Layout/estilo de UI: classes CSS, aparência visual, breakpoints responsivos
99
- - Configuração: arquivos de config, variáveis de ambiente, feature flags
100
- - Código de cola: configuração de injeção de dependência, registro de middleware, tabelas de roteamento
101
- - Migrations: migrations de banco de dados, mudanças de schema
102
- - CRUD simples: create/read/update/delete básico sem lógica de negócio
103
- - Definições de tipo: records, DTOs, interfaces sem lógica
104
-
105
- Ler cada arquivo para verificar a classificação. Não classificar apenas pelo nome do arquivo.
106
- </step>
107
-
108
- <step name="present_classification">
109
- Apresentar a classificação ao usuário para confirmação antes de prosseguir:
110
-
111
- ```
112
- AskUserQuestion(
113
- header: "Classificação de Testes",
114
- question: |
115
- ## Arquivos classificados para teste
116
-
117
- ### TDD (Testes Unitários) — {N} arquivos
118
- {lista de arquivos com breve motivo}
119
-
120
- ### E2E (Testes de Navegador) — {M} arquivos
121
- {lista de arquivos com breve motivo}
122
-
123
- ### Skip — {K} arquivos
124
- {lista de arquivos com breve motivo}
125
-
126
- {se $EXTRA_INSTRUCTIONS: "Instruções adicionais: ${EXTRA_INSTRUCTIONS}"}
127
-
128
- Como você gostaria de prosseguir?
129
- options:
130
- - "Aprovar e gerar plano de testes"
131
- - "Ajustar classificação (vou especificar mudanças)"
132
- - "Cancelar"
133
- )
134
- ```
135
-
136
- Se o usuário selecionar "Ajustar classificação": aplicar as mudanças e reapresentar.
137
- Se o usuário selecionar "Cancelar": sair graciosamente.
138
- </step>
139
-
140
- <step name="discover_test_structure">
141
- Antes de gerar o plano de testes, descobrir a estrutura de testes existente do projeto:
142
-
143
- ```bash
144
- # Encontrar diretórios de testes existentes
145
- find . -type d -name "*test*" -o -name "*spec*" -o -name "*__tests__*" 2>/dev/null | head -20
146
- # Encontrar arquivos de teste existentes para correspondência de convenções
147
- find . -type f \( -name "*.test.*" -o -name "*.spec.*" -o -name "*Tests.fs" -o -name "*Test.fs" \) 2>/dev/null | head -20
148
- # Verificar runners de teste
149
- ls package.json *.sln 2>/dev/null || true
150
- ```
151
-
152
- Identificar:
153
- - Estrutura de diretórios de teste (onde ficam testes unitários, onde ficam testes E2E)
154
- - Convenções de nomenclatura (`.test.ts`, `.spec.ts`, `*Tests.fs`, etc.)
155
- - Comandos do runner de testes (como executar testes unitários, como executar testes E2E)
156
- - Framework de testes (xUnit, NUnit, Jest, Playwright, etc.)
157
-
158
- Se a estrutura de testes for ambígua, perguntar ao usuário:
159
- ```
160
- AskUserQuestion(
161
- header: "Estrutura de Testes",
162
- question: "Encontrei múltiplos locais de testes. Onde devo criar os testes?",
163
- options: [listar locais descobertos]
164
- )
165
- ```
166
- </step>
167
-
168
- <step name="generate_test_plan">
169
- Para cada arquivo aprovado, criar um plano de testes detalhado.
170
-
171
- **Para arquivos TDD**, planejar testes seguindo RED-GREEN-REFACTOR:
172
- 1. Identificar funções/métodos testáveis no arquivo
173
- 2. Para cada função: listar cenários de input, outputs esperados, casos extremos
174
- 3. Nota: como o código já existe, os testes podem passar imediatamente — isso é OK, mas verificar que eles testam o comportamento CORRETO
175
-
176
- **Para arquivos E2E**, planejar testes seguindo portões RED-GREEN:
177
- 1. Identificar cenários de usuário do CONTEXT.md/VERIFICATION.md
178
- 2. Para cada cenário: descrever a ação do usuário, resultado esperado, asserções
179
- 3. Nota: portão RED significa confirmar que o teste falharia se a funcionalidade estivesse quebrada
180
-
181
- Apresentar o plano completo de testes:
182
-
183
- ```
184
- AskUserQuestion(
185
- header: "Plano de Testes",
186
- question: |
187
- ## Plano de Geração de Testes
188
-
189
- ### Testes Unitários ({N} testes em {M} arquivos)
190
- {para cada arquivo: caminho do arquivo de teste, lista de casos de teste}
191
-
192
- ### Testes E2E ({P} testes em {Q} arquivos)
193
- {para cada arquivo: caminho do arquivo de teste, lista de cenários de teste}
194
-
195
- ### Comandos de Teste
196
- - Unitários: {comando de teste descoberto}
197
- - E2E: {comando e2e descoberto}
198
-
199
- Pronto para gerar?
200
- options:
201
- - "Gerar todos"
202
- - "Escolher individualmente (vou especificar quais)"
203
- - "Ajustar plano"
204
- )
205
- ```
206
-
207
- Se "Escolher individualmente": perguntar ao usuário quais testes incluir.
208
- Se "Ajustar plano": aplicar mudanças e reapresentar.
209
- </step>
210
-
211
- <step name="execute_tdd_generation">
212
- Para cada teste TDD aprovado:
213
-
214
- 1. **Criar arquivo de teste** seguindo as convenções do projeto descobertas (diretório, nomenclatura, imports)
215
-
216
- 2. **Escrever teste** com estrutura clara arrange/act/assert:
217
- ```
218
- // Arrange — configurar inputs e outputs esperados
219
- // Act — chamar a função sob teste
220
- // Assert — verificar que o output corresponde às expectativas
221
- ```
222
-
223
- 3. **Executar o teste**:
224
- ```bash
225
- {comando de teste descoberto}
226
- ```
227
-
228
- 4. **Avaliar resultado:**
229
- - **Teste passa**: Bom — a implementação satisfaz o teste. Verificar que o teste testa comportamento significativo (não apenas que compila).
230
- - **Teste falha com erro de asserção**: Isso pode ser um bug genuíno descoberto pelo teste. Sinalizar:
231
- ```
232
- ⚠️ Bug potencial encontrado: {nome do teste}
233
- Esperado: {esperado}
234
- Atual: {atual}
235
- Arquivo: {arquivo de implementação}
236
- ```
237
- NÃO corrigir a implementação — este é um comando de geração de testes, não de correção. Registrar o achado.
238
- - **Teste falha com erro (import, sintaxe, etc.)**: Este é um erro de teste. Corrigir o teste e re-executar.
239
- </step>
240
-
241
- <step name="execute_e2e_generation">
242
- Para cada teste E2E aprovado:
243
-
244
- 1. **Verificar testes existentes** cobrindo o mesmo cenário:
245
- ```bash
246
- grep -r "{palavra-chave do cenário}" {diretório de testes e2e} 2>/dev/null || true
247
- ```
248
- Se encontrado, estender em vez de duplicar.
249
-
250
- 2. **Criar arquivo de teste** direcionado ao cenário de usuário do CONTEXT.md/VERIFICATION.md
251
-
252
- 3. **Executar o teste E2E**:
253
- ```bash
254
- {comando e2e descoberto}
255
- ```
256
-
257
- 4. **Avaliar resultado:**
258
- - **VERDE (passa)**: Registrar sucesso
259
- - **VERMELHO (falha)**: Determinar se é um problema de teste ou um bug genuíno de aplicação. Sinalizar bugs:
260
- ```
261
- ⚠️ Falha E2E: {nome do teste}
262
- Cenário: {descrição}
263
- Erro: {mensagem de erro}
264
- ```
265
- - **Não pode executar**: Reportar bloqueio. NÃO marcar como concluído.
266
- ```
267
- 🛑 Bloqueio E2E: {motivo pelo qual os testes não podem ser executados}
268
- ```
269
-
270
- **Regra sem-pular:** Se os testes E2E não puderem ser executados (dependências ausentes, problemas de ambiente), reportar o bloqueio e marcar o teste como incompleto. Nunca marcar sucesso sem realmente executar o teste.
271
- </step>
272
-
273
- <step name="summary_and_commit">
274
- Criar um relatório de cobertura de testes e apresentar ao usuário:
275
-
276
- ```
277
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
278
- framework ► GERAÇÃO DE TESTES CONCLUÍDA
279
- ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
280
-
281
- ## Resultados
282
-
283
- | Categoria | Gerados | Passando | Falhando | Bloqueados |
284
- |-----------|---------|----------|----------|------------|
285
- | Unitários | {N} | {n1} | {n2} | {n3} |
286
- | E2E | {M} | {m1} | {m2} | {m3} |
287
-
288
- ## Arquivos Criados/Modificados
289
- {lista de arquivos de teste com caminhos}
290
-
291
- ## Lacunas de Cobertura
292
- {áreas que não puderam ser testadas e por quê}
293
-
294
- ## Bugs Descobertos
295
- {quaisquer falhas de asserção que indicam bugs de implementação}
296
- ```
297
-
298
- Registrar geração de testes no estado do projeto:
299
- ```bash
300
- node "./.claude/framework/bin/tools.cjs" state-snapshot
301
- ```
302
-
303
- Se houver testes passando para commitar:
304
-
305
- ```bash
306
- git add {arquivos de teste}
307
- git commit -m "test(phase-${phase_number}): adicionar testes unitários e E2E do comando adicionar-testes"
308
- ```
309
-
310
- Apresentar próximos passos:
311
-
312
- ```
313
- ---
314
-
315
- ## ▶ Próximo Passo
316
-
317
- {se bugs descobertos:}
318
- **Corrigir bugs descobertos:** `/expresso corrigir as {N} falhas de teste descobertas na fase ${phase_number}`
319
-
320
- {se testes bloqueados:}
321
- **Resolver bloqueios de teste:** {descrição do que é necessário}
322
-
323
- {caso contrário:}
324
- **Todos os testes passando!** Fase ${phase_number} está totalmente testada.
325
-
326
- ---
327
-
328
- **Também disponível:**
329
- - `/adicionar-testes {próxima_fase}` — testar outra fase
330
- - `/verificar-trabalho {phase_number}` — executar verificação UAT
331
-
332
- ---
333
- ```
334
- </step>
335
-
336
- </process>
337
-
338
- <success_criteria>
339
- - [ ] Artefatos de fase carregados (SUMMARY.md, CONTEXT.md, opcionalmente VERIFICATION.md)
340
- - [ ] Todos os arquivos alterados classificados nas categorias TDD/E2E/Skip
341
- - [ ] Classificação apresentada ao usuário e aprovada
342
- - [ ] Estrutura de testes do projeto descoberta (diretórios, convenções, runners)
343
- - [ ] Plano de testes apresentado ao usuário e aprovado
344
- - [ ] Testes TDD gerados com estrutura arrange/act/assert
345
- - [ ] Testes E2E gerados direcionados a cenários de usuário
346
- - [ ] Todos os testes executados — nenhum teste não executado marcado como passando
347
- - [ ] Bugs descobertos pelos testes sinalizados (não corrigidos)
348
- - [ ] Arquivos de teste commitados com mensagem adequada
349
- - [ ] Lacunas de cobertura documentadas
350
- - [ ] Próximos passos apresentados ao usuário
351
- </success_criteria>
1
+ <purpose>
2
+ Gerar testes unitários e E2E para uma fase concluída com base em seu SUMMARY.md, CONTEXT.md e implementação. Classifica cada arquivo alterado nas categorias TDD (unitário), E2E (navegador) ou Skip, apresenta um plano de testes para aprovação do usuário, então gera testes seguindo as convenções RED-GREEN.
3
+
4
+ Os usuários atualmente criam prompts `/expresso` manualmente para geração de testes após cada fase. Este workflow padroniza o processo com classificação adequada, portões de qualidade e relatório de lacunas.
5
+ </purpose>
6
+
7
+ <required_reading>
8
+ Leia todos os arquivos referenciados pelo execution_context do prompt que invocou antes de começar.
9
+ </required_reading>
10
+
11
+ <process>
12
+
13
+ <step name="parse_arguments">
14
+ Analisar `$ARGUMENTS` para:
15
+ - Número de fase (inteiro, decimal ou sufixo de letra) → armazenar como `$PHASE_ARG`
16
+ - Texto restante após o número da fase → armazenar como `$EXTRA_INSTRUCTIONS` (opcional)
17
+
18
+ Exemplo: `/adicionar-testes 12 focar nos casos extremos` → `$PHASE_ARG=12`, `$EXTRA_INSTRUCTIONS="focar nos casos extremos"`
19
+
20
+ Se nenhum argumento de fase fornecido:
21
+
22
+ ```
23
+ ERRO: Número de fase obrigatório
24
+ Uso: /adicionar-testes <fase> [instruções adicionais]
25
+ Exemplo: /adicionar-testes 12
26
+ Exemplo: /adicionar-testes 12 focar nos casos extremos no módulo de preços
27
+ ```
28
+
29
+ Sair.
30
+ </step>
31
+
32
+ <step name="init_context">
33
+ Carregar contexto de operação de fase:
34
+
35
+ ```bash
36
+ INIT=$(node "./.claude/framework/bin/tools.cjs" init phase-op "${PHASE_ARG}")
37
+ if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
38
+ ```
39
+
40
+ Extrair do JSON de init: `phase_dir`, `phase_number`, `phase_name`.
41
+
42
+ Verificar se o diretório de fase existe. Se não:
43
+ ```
44
+ ERRO: Diretório de fase não encontrado para a fase ${PHASE_ARG}
45
+ Certifique-se de que a fase existe em .planning/phases/
46
+ ```
47
+ Sair.
48
+
49
+ Ler os artefatos da fase (em ordem de prioridade):
50
+ 1. `${phase_dir}/*-SUMMARY.md` — o que foi implementado, arquivos alterados
51
+ 2. `${phase_dir}/CONTEXT.md` — critérios de aceitação, decisões
52
+ 3. `${phase_dir}/*-VERIFICATION.md` — cenários verificados pelo usuário (se UAT foi feito)
53
+
54
+ Se nenhum SUMMARY.md existir:
55
+ ```
56
+ ERRO: Nenhum SUMMARY.md encontrado para a fase ${PHASE_ARG}
57
+ Este comando funciona em fases concluídas. Execute /executar-fase primeiro.
58
+ ```
59
+ Sair.
60
+
61
+ Apresentar banner:
62
+ ```
63
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
64
+ framework ► ADICIONAR TESTES — Fase ${phase_number}: ${phase_name}
65
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
66
+ ```
67
+ </step>
68
+
69
+ <step name="analyze_implementation">
70
+ Extrair a lista de arquivos modificados pela fase do SUMMARY.md (seção "Files Changed" ou equivalente).
71
+
72
+ Para cada arquivo, classificar em uma das três categorias:
73
+
74
+ | Categoria | Critérios | Tipo de Teste |
75
+ |-----------|-----------|---------------|
76
+ | **TDD** | Funções puras onde `expect(fn(input)).toBe(output)` é escrevível | Testes unitários |
77
+ | **E2E** | Comportamento de UI verificável por automação de navegador | Testes Playwright/E2E |
78
+ | **Skip** | Não testável de forma significativa ou já coberto | Nenhum |
79
+
80
+ **Classificação TDD — aplicar quando:**
81
+ - Lógica de negócio: cálculos, preços, regras fiscais, validação
82
+ - Transformações de dados: mapeamento, filtragem, agregação, formatação
83
+ - Parsers: CSV, JSON, XML, análise de formato personalizado
84
+ - Validadores: validação de input, validação de schema, regras de negócio
85
+ - Máquinas de estado: transições de status, etapas de workflow
86
+ - Utilitários: manipulação de strings, tratamento de datas, formatação de números
87
+
88
+ **Classificação E2E — aplicar quando:**
89
+ - Atalhos de teclado: keybindings, teclas modificadoras, sequências de accordes
90
+ - Navegação: transições de página, roteamento, breadcrumbs, voltar/avançar
91
+ - Interações de formulário: envio, erros de validação, foco de campo, autocomplete
92
+ - Seleção: seleção de linha, multi-seleção, intervalos com shift-click
93
+ - Arrastar e soltar: reordenação, mover entre contêineres
94
+ - Diálogos modais: abrir, fechar, confirmar, cancelar
95
+ - Grids de dados: ordenação, filtragem, edição inline, redimensionamento de coluna
96
+
97
+ **Classificação Skip — aplicar quando:**
98
+ - Layout/estilo de UI: classes CSS, aparência visual, breakpoints responsivos
99
+ - Configuração: arquivos de config, variáveis de ambiente, feature flags
100
+ - Código de cola: configuração de injeção de dependência, registro de middleware, tabelas de roteamento
101
+ - Migrations: migrations de banco de dados, mudanças de schema
102
+ - CRUD simples: create/read/update/delete básico sem lógica de negócio
103
+ - Definições de tipo: records, DTOs, interfaces sem lógica
104
+
105
+ Ler cada arquivo para verificar a classificação. Não classificar apenas pelo nome do arquivo.
106
+ </step>
107
+
108
+ <step name="present_classification">
109
+ Apresentar a classificação ao usuário para confirmação antes de prosseguir:
110
+
111
+ ```
112
+ AskUserQuestion(
113
+ header: "Classificação de Testes",
114
+ question: |
115
+ ## Arquivos classificados para teste
116
+
117
+ ### TDD (Testes Unitários) — {N} arquivos
118
+ {lista de arquivos com breve motivo}
119
+
120
+ ### E2E (Testes de Navegador) — {M} arquivos
121
+ {lista de arquivos com breve motivo}
122
+
123
+ ### Skip — {K} arquivos
124
+ {lista de arquivos com breve motivo}
125
+
126
+ {se $EXTRA_INSTRUCTIONS: "Instruções adicionais: ${EXTRA_INSTRUCTIONS}"}
127
+
128
+ Como você gostaria de prosseguir?
129
+ options:
130
+ - "Aprovar e gerar plano de testes"
131
+ - "Ajustar classificação (vou especificar mudanças)"
132
+ - "Cancelar"
133
+ )
134
+ ```
135
+
136
+ Se o usuário selecionar "Ajustar classificação": aplicar as mudanças e reapresentar.
137
+ Se o usuário selecionar "Cancelar": sair graciosamente.
138
+ </step>
139
+
140
+ <step name="discover_test_structure">
141
+ Antes de gerar o plano de testes, descobrir a estrutura de testes existente do projeto:
142
+
143
+ ```bash
144
+ # Encontrar diretórios de testes existentes
145
+ find . -type d -name "*test*" -o -name "*spec*" -o -name "*__tests__*" 2>/dev/null | head -20
146
+ # Encontrar arquivos de teste existentes para correspondência de convenções
147
+ find . -type f \( -name "*.test.*" -o -name "*.spec.*" -o -name "*Tests.fs" -o -name "*Test.fs" \) 2>/dev/null | head -20
148
+ # Verificar runners de teste
149
+ ls package.json *.sln 2>/dev/null || true
150
+ ```
151
+
152
+ Identificar:
153
+ - Estrutura de diretórios de teste (onde ficam testes unitários, onde ficam testes E2E)
154
+ - Convenções de nomenclatura (`.test.ts`, `.spec.ts`, `*Tests.fs`, etc.)
155
+ - Comandos do runner de testes (como executar testes unitários, como executar testes E2E)
156
+ - Framework de testes (xUnit, NUnit, Jest, Playwright, etc.)
157
+
158
+ Se a estrutura de testes for ambígua, perguntar ao usuário:
159
+ ```
160
+ AskUserQuestion(
161
+ header: "Estrutura de Testes",
162
+ question: "Encontrei múltiplos locais de testes. Onde devo criar os testes?",
163
+ options: [listar locais descobertos]
164
+ )
165
+ ```
166
+ </step>
167
+
168
+ <step name="generate_test_plan">
169
+ Para cada arquivo aprovado, criar um plano de testes detalhado.
170
+
171
+ **Para arquivos TDD**, planejar testes seguindo RED-GREEN-REFACTOR:
172
+ 1. Identificar funções/métodos testáveis no arquivo
173
+ 2. Para cada função: listar cenários de input, outputs esperados, casos extremos
174
+ 3. Nota: como o código já existe, os testes podem passar imediatamente — isso é OK, mas verificar que eles testam o comportamento CORRETO
175
+
176
+ **Para arquivos E2E**, planejar testes seguindo portões RED-GREEN:
177
+ 1. Identificar cenários de usuário do CONTEXT.md/VERIFICATION.md
178
+ 2. Para cada cenário: descrever a ação do usuário, resultado esperado, asserções
179
+ 3. Nota: portão RED significa confirmar que o teste falharia se a funcionalidade estivesse quebrada
180
+
181
+ Apresentar o plano completo de testes:
182
+
183
+ ```
184
+ AskUserQuestion(
185
+ header: "Plano de Testes",
186
+ question: |
187
+ ## Plano de Geração de Testes
188
+
189
+ ### Testes Unitários ({N} testes em {M} arquivos)
190
+ {para cada arquivo: caminho do arquivo de teste, lista de casos de teste}
191
+
192
+ ### Testes E2E ({P} testes em {Q} arquivos)
193
+ {para cada arquivo: caminho do arquivo de teste, lista de cenários de teste}
194
+
195
+ ### Comandos de Teste
196
+ - Unitários: {comando de teste descoberto}
197
+ - E2E: {comando e2e descoberto}
198
+
199
+ Pronto para gerar?
200
+ options:
201
+ - "Gerar todos"
202
+ - "Escolher individualmente (vou especificar quais)"
203
+ - "Ajustar plano"
204
+ )
205
+ ```
206
+
207
+ Se "Escolher individualmente": perguntar ao usuário quais testes incluir.
208
+ Se "Ajustar plano": aplicar mudanças e reapresentar.
209
+ </step>
210
+
211
+ <step name="execute_tdd_generation">
212
+ Para cada teste TDD aprovado:
213
+
214
+ 1. **Criar arquivo de teste** seguindo as convenções do projeto descobertas (diretório, nomenclatura, imports)
215
+
216
+ 2. **Escrever teste** com estrutura clara arrange/act/assert:
217
+ ```
218
+ // Arrange — configurar inputs e outputs esperados
219
+ // Act — chamar a função sob teste
220
+ // Assert — verificar que o output corresponde às expectativas
221
+ ```
222
+
223
+ 3. **Executar o teste**:
224
+ ```bash
225
+ {comando de teste descoberto}
226
+ ```
227
+
228
+ 4. **Avaliar resultado:**
229
+ - **Teste passa**: Bom — a implementação satisfaz o teste. Verificar que o teste testa comportamento significativo (não apenas que compila).
230
+ - **Teste falha com erro de asserção**: Isso pode ser um bug genuíno descoberto pelo teste. Sinalizar:
231
+ ```
232
+ ⚠️ Bug potencial encontrado: {nome do teste}
233
+ Esperado: {esperado}
234
+ Atual: {atual}
235
+ Arquivo: {arquivo de implementação}
236
+ ```
237
+ NÃO corrigir a implementação — este é um comando de geração de testes, não de correção. Registrar o achado.
238
+ - **Teste falha com erro (import, sintaxe, etc.)**: Este é um erro de teste. Corrigir o teste e re-executar.
239
+ </step>
240
+
241
+ <step name="execute_e2e_generation">
242
+ Para cada teste E2E aprovado:
243
+
244
+ 1. **Verificar testes existentes** cobrindo o mesmo cenário:
245
+ ```bash
246
+ grep -r "{palavra-chave do cenário}" {diretório de testes e2e} 2>/dev/null || true
247
+ ```
248
+ Se encontrado, estender em vez de duplicar.
249
+
250
+ 2. **Criar arquivo de teste** direcionado ao cenário de usuário do CONTEXT.md/VERIFICATION.md
251
+
252
+ 3. **Executar o teste E2E**:
253
+ ```bash
254
+ {comando e2e descoberto}
255
+ ```
256
+
257
+ 4. **Avaliar resultado:**
258
+ - **VERDE (passa)**: Registrar sucesso
259
+ - **VERMELHO (falha)**: Determinar se é um problema de teste ou um bug genuíno de aplicação. Sinalizar bugs:
260
+ ```
261
+ ⚠️ Falha E2E: {nome do teste}
262
+ Cenário: {descrição}
263
+ Erro: {mensagem de erro}
264
+ ```
265
+ - **Não pode executar**: Reportar bloqueio. NÃO marcar como concluído.
266
+ ```
267
+ 🛑 Bloqueio E2E: {motivo pelo qual os testes não podem ser executados}
268
+ ```
269
+
270
+ **Regra sem-pular:** Se os testes E2E não puderem ser executados (dependências ausentes, problemas de ambiente), reportar o bloqueio e marcar o teste como incompleto. Nunca marcar sucesso sem realmente executar o teste.
271
+ </step>
272
+
273
+ <step name="summary_and_commit">
274
+ Criar um relatório de cobertura de testes e apresentar ao usuário:
275
+
276
+ ```
277
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
278
+ framework ► GERAÇÃO DE TESTES CONCLUÍDA
279
+ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
280
+
281
+ ## Resultados
282
+
283
+ | Categoria | Gerados | Passando | Falhando | Bloqueados |
284
+ |-----------|---------|----------|----------|------------|
285
+ | Unitários | {N} | {n1} | {n2} | {n3} |
286
+ | E2E | {M} | {m1} | {m2} | {m3} |
287
+
288
+ ## Arquivos Criados/Modificados
289
+ {lista de arquivos de teste com caminhos}
290
+
291
+ ## Lacunas de Cobertura
292
+ {áreas que não puderam ser testadas e por quê}
293
+
294
+ ## Bugs Descobertos
295
+ {quaisquer falhas de asserção que indicam bugs de implementação}
296
+ ```
297
+
298
+ Registrar geração de testes no estado do projeto:
299
+ ```bash
300
+ node "./.claude/framework/bin/tools.cjs" state-snapshot
301
+ ```
302
+
303
+ Se houver testes passando para commitar:
304
+
305
+ ```bash
306
+ git add {arquivos de teste}
307
+ git commit -m "test(phase-${phase_number}): adicionar testes unitários e E2E do comando adicionar-testes"
308
+ ```
309
+
310
+ Apresentar próximos passos:
311
+
312
+ ```
313
+ ---
314
+
315
+ ## ▶ Próximo Passo
316
+
317
+ {se bugs descobertos:}
318
+ **Corrigir bugs descobertos:** `/expresso corrigir as {N} falhas de teste descobertas na fase ${phase_number}`
319
+
320
+ {se testes bloqueados:}
321
+ **Resolver bloqueios de teste:** {descrição do que é necessário}
322
+
323
+ {caso contrário:}
324
+ **Todos os testes passando!** Fase ${phase_number} está totalmente testada.
325
+
326
+ ---
327
+
328
+ **Também disponível:**
329
+ - `/adicionar-testes {próxima_fase}` — testar outra fase
330
+ - `/verificar-trabalho {phase_number}` — executar verificação UAT
331
+
332
+ ---
333
+ ```
334
+ </step>
335
+
336
+ </process>
337
+
338
+ <success_criteria>
339
+ - [ ] Artefatos de fase carregados (SUMMARY.md, CONTEXT.md, opcionalmente VERIFICATION.md)
340
+ - [ ] Todos os arquivos alterados classificados nas categorias TDD/E2E/Skip
341
+ - [ ] Classificação apresentada ao usuário e aprovada
342
+ - [ ] Estrutura de testes do projeto descoberta (diretórios, convenções, runners)
343
+ - [ ] Plano de testes apresentado ao usuário e aprovado
344
+ - [ ] Testes TDD gerados com estrutura arrange/act/assert
345
+ - [ ] Testes E2E gerados direcionados a cenários de usuário
346
+ - [ ] Todos os testes executados — nenhum teste não executado marcado como passando
347
+ - [ ] Bugs descobertos pelos testes sinalizados (não corrigidos)
348
+ - [ ] Arquivos de teste commitados com mensagem adequada
349
+ - [ ] Lacunas de cobertura documentadas
350
+ - [ ] Próximos passos apresentados ao usuário
351
+ </success_criteria>