@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,301 +1,301 @@
1
- # Template de Padrões de Teste
2
-
3
- Template para `.planning/codebase/TESTING.md` - captura o framework e padrões de teste.
4
-
5
- **Propósito:** Documentar como os testes são escritos e executados. Guia para adicionar testes que correspondam aos padrões existentes.
6
-
7
- ---
8
-
9
- ## Template do Arquivo
10
-
11
- ```markdown
12
- # Padrões de Teste
13
-
14
- **Data da Análise:** [AAAA-MM-DD]
15
-
16
- ## Framework de Testes
17
-
18
- **Runner:**
19
- - [Framework: ex.: "Jest 29.x", "Vitest 1.x"]
20
- - [Config: ex.: "jest.config.js na raiz do projeto"]
21
-
22
- **Biblioteca de Asserções:**
23
- - [Biblioteca: ex.: "expect built-in", "chai"]
24
- - [Matchers: ex.: "toBe, toEqual, toThrow"]
25
-
26
- **Comandos de Execução:**
27
- ```bash
28
- [ex.: "npm test" ou "npm run test"] # Executar todos os testes
29
- [ex.: "npm test -- --watch"] # Modo watch
30
- [ex.: "npm test -- path/to/file.test.ts"] # Arquivo único
31
- [ex.: "npm run test:coverage"] # Relatório de cobertura
32
- ```
33
-
34
- ## Organização dos Arquivos de Teste
35
-
36
- **Localização:**
37
- - [Padrão: ex.: "*.test.ts junto aos arquivos fonte"]
38
- - [Alternativa: ex.: "diretório __tests__/" ou "árvore tests/ separada"]
39
-
40
- **Nomenclatura:**
41
- - [Testes unitários: ex.: "nome-do-modulo.test.ts"]
42
- - [Integração: ex.: "nome-da-funcionalidade.integration.test.ts"]
43
- - [E2E: ex.: "fluxo-do-usuario.e2e.test.ts"]
44
-
45
- **Estrutura:**
46
- ```
47
- [Mostrar padrão real de diretório, ex.:
48
- src/
49
- lib/
50
- utils.ts
51
- utils.test.ts
52
- services/
53
- user-service.ts
54
- user-service.test.ts
55
- ]
56
- ```
57
-
58
- ## Estrutura dos Testes
59
-
60
- **Organização de Suites:**
61
- ```typescript
62
- [Mostrar padrão real usado, ex.:
63
-
64
- describe('NomeDoModulo', () => {
65
- describe('nomeDaFuncao', () => {
66
- it('deve tratar caso de sucesso', () => {
67
- // arrange
68
- // act
69
- // assert
70
- });
71
-
72
- it('deve tratar caso de erro', () => {
73
- // código do teste
74
- });
75
- });
76
- });
77
- ]
78
- ```
79
-
80
- **Padrões:**
81
- - [Setup: ex.: "beforeEach para setup compartilhado, evitar beforeAll"]
82
- - [Teardown: ex.: "afterEach para limpar, restaurar mocks"]
83
- - [Estrutura: ex.: "padrão arrange/act/assert obrigatório"]
84
-
85
- ## Mocking
86
-
87
- **Framework:**
88
- - [Ferramenta: ex.: "mocking built-in do Jest", "Vitest vi", "Sinon"]
89
- - [Import mocking: ex.: "vi.mock() no topo do arquivo"]
90
-
91
- **Padrões:**
92
- ```typescript
93
- [Mostrar padrão real de mocking, ex.:
94
-
95
- // Mock dependência externa
96
- vi.mock('./external-service', () => ({
97
- fetchData: vi.fn()
98
- }));
99
-
100
- // Mock no teste
101
- const mockFetch = vi.mocked(fetchData);
102
- mockFetch.mockResolvedValue({ data: 'test' });
103
- ]
104
- ```
105
-
106
- **O Que Mockar:**
107
- - [ex.: "APIs externas, sistema de arquivos, banco de dados"]
108
- - [ex.: "Tempo/datas (usar vi.useFakeTimers)"]
109
- - [ex.: "Chamadas de rede (usar mock fetch)"]
110
-
111
- **O Que NÃO Mockar:**
112
- - [ex.: "Funções puras, utilitários"]
113
- - [ex.: "Lógica de negócio interna"]
114
-
115
- ## Fixtures e Factories
116
-
117
- **Dados de Teste:**
118
- ```typescript
119
- [Mostrar padrão para criar dados de teste, ex.:
120
-
121
- // Padrão factory
122
- function createTestUser(overrides?: Partial<User>): User {
123
- return {
124
- id: 'test-id',
125
- name: 'Test User',
126
- email: 'test@example.com',
127
- ...overrides
128
- };
129
- }
130
-
131
- // Arquivo de fixture
132
- // tests/fixtures/users.ts
133
- export const mockUsers = [/* ... */];
134
- ]
135
- ```
136
-
137
- **Localização:**
138
- - [ex.: "tests/fixtures/ para fixtures compartilhadas"]
139
- - [ex.: "funções factory no arquivo de teste ou tests/factories/"]
140
-
141
- ## Cobertura
142
-
143
- **Requisitos:**
144
- - [Meta: ex.: "80% de cobertura de linhas", "sem meta específica"]
145
- - [Aplicação: ex.: "CI bloqueia <80%", "cobertura apenas para conscientização"]
146
-
147
- **Configuração:**
148
- - [Ferramenta: ex.: "cobertura built-in via flag --coverage"]
149
- - [Exclusões: ex.: "excluir *.test.ts, arquivos de config"]
150
-
151
- **Ver Cobertura:**
152
- ```bash
153
- [ex.: "npm run test:coverage"]
154
- [ex.: "open coverage/index.html"]
155
- ```
156
-
157
- ## Tipos de Testes
158
-
159
- **Testes Unitários:**
160
- - [Escopo: ex.: "testar função/classe única em isolamento"]
161
- - [Mocking: ex.: "mockar todas as dependências externas"]
162
- - [Velocidade: ex.: "deve executar em <1s por teste"]
163
-
164
- **Testes de Integração:**
165
- - [Escopo: ex.: "testar múltiplos módulos juntos"]
166
- - [Mocking: ex.: "mockar serviços externos, usar módulos internos reais"]
167
- - [Setup: ex.: "usar banco de dados de teste, seed de dados"]
168
-
169
- **Testes E2E:**
170
- - [Framework: ex.: "Playwright para E2E"]
171
- - [Escopo: ex.: "testar fluxos completos do usuário"]
172
- - [Localização: ex.: "diretório e2e/ separado dos testes unitários"]
173
-
174
- ## Padrões Comuns
175
-
176
- **Teste Async:**
177
- ```typescript
178
- [Mostrar padrão, ex.:
179
-
180
- it('deve tratar operação async', async () => {
181
- const result = await asyncFunction();
182
- expect(result).toBe('expected');
183
- });
184
- ]
185
- ```
186
-
187
- **Teste de Erro:**
188
- ```typescript
189
- [Mostrar padrão, ex.:
190
-
191
- it('deve lançar com entrada inválida', () => {
192
- expect(() => functionCall()).toThrow('mensagem de erro');
193
- });
194
-
195
- // Erro async
196
- it('deve rejeitar na falha', async () => {
197
- await expect(asyncCall()).rejects.toThrow('mensagem de erro');
198
- });
199
- ]
200
- ```
201
-
202
- **Snapshot Testing:**
203
- - [Uso: ex.: "apenas para componentes React" ou "não usado"]
204
- - [Localização: ex.: "diretório __snapshots__/"]
205
-
206
- ---
207
-
208
- *Análise de testes: [data]*
209
- *Atualizar quando padrões de teste mudarem*
210
- ```
211
-
212
- <good_examples>
213
- ```markdown
214
- # Testing Patterns
215
-
216
- **Analysis Date:** 2025-01-20
217
-
218
- ## Test Framework
219
-
220
- **Runner:**
221
- - Vitest 1.0.4
222
- - Config: vitest.config.ts in project root
223
-
224
- **Run Commands:**
225
- ```bash
226
- npm test # Run all tests
227
- npm test -- --watch # Watch mode
228
- npm run test:coverage # Coverage report
229
- ```
230
-
231
- ## Test File Organization
232
-
233
- **Location:**
234
- - *.test.ts alongside source files
235
- - No separate tests/ directory
236
-
237
- ## Test Structure
238
-
239
- **Suite Organization:**
240
- ```typescript
241
- import { describe, it, expect, beforeEach, vi } from 'vitest';
242
-
243
- describe('ModuleName', () => {
244
- it('should handle valid input', () => {
245
- // arrange
246
- const input = createTestInput();
247
- // act
248
- const result = functionName(input);
249
- // assert
250
- expect(result).toEqual(expectedOutput);
251
- });
252
- });
253
- ```
254
-
255
- ---
256
-
257
- *Testing analysis: 2025-01-20*
258
- *Update when test patterns change*
259
- ```
260
- </good_examples>
261
-
262
- <guidelines>
263
- **O que pertence ao TESTING.md:**
264
- - Framework de teste e configuração do runner
265
- - Padrões de localização e nomenclatura de arquivos de teste
266
- - Estrutura de teste (describe/it, padrões beforeEach)
267
- - Abordagem de mocking e exemplos
268
- - Padrões de fixture/factory
269
- - Requisitos de cobertura
270
- - Como executar testes (comandos)
271
- - Padrões comuns de teste no código real
272
-
273
- **O que NÃO pertence aqui:**
274
- - Casos de teste específicos (diferir para os arquivos de teste reais)
275
- - Escolhas tecnológicas (isso é STACK.md)
276
- - Setup de CI/CD (isso é docs de deployment)
277
-
278
- **Ao preencher este template:**
279
- - Verificar scripts do package.json para comandos de teste
280
- - Encontrar arquivo de config de teste (jest.config.js, vitest.config.ts)
281
- - Ler 3-5 arquivos de teste existentes para identificar padrões
282
- - Procurar utilitários de teste em tests/ ou test-utils/
283
- - Verificar configuração de cobertura
284
- - Documentar padrões realmente usados, não padrões ideais
285
-
286
- **Útil para planejamento de fases quando:**
287
- - Adicionando novas funcionalidades (escrever testes correspondentes)
288
- - Refatorando (manter padrões de teste)
289
- - Corrigindo bugs (adicionar testes de regressão)
290
- - Entendendo abordagem de verificação
291
- - Configurando infraestrutura de teste
292
-
293
- **Abordagem de análise:**
294
- - Verificar package.json para framework de teste e scripts
295
- - Ler arquivo de config de teste para cobertura, setup
296
- - Examinar organização dos arquivos de teste (colocalizados vs. separados)
297
- - Revisar 5 arquivos de teste para padrões (mocking, estrutura, asserções)
298
- - Procurar utilitários de teste, fixtures, factories
299
- - Notar quaisquer tipos de teste (unitário, integração, e2e)
300
- - Documentar comandos para executar testes
301
- </guidelines>
1
+ # Template de Padrões de Teste
2
+
3
+ Template para `.planning/codebase/TESTING.md` - captura o framework e padrões de teste.
4
+
5
+ **Propósito:** Documentar como os testes são escritos e executados. Guia para adicionar testes que correspondam aos padrões existentes.
6
+
7
+ ---
8
+
9
+ ## Template do Arquivo
10
+
11
+ ```markdown
12
+ # Padrões de Teste
13
+
14
+ **Data da Análise:** [AAAA-MM-DD]
15
+
16
+ ## Framework de Testes
17
+
18
+ **Runner:**
19
+ - [Framework: ex.: "Jest 29.x", "Vitest 1.x"]
20
+ - [Config: ex.: "jest.config.js na raiz do projeto"]
21
+
22
+ **Biblioteca de Asserções:**
23
+ - [Biblioteca: ex.: "expect built-in", "chai"]
24
+ - [Matchers: ex.: "toBe, toEqual, toThrow"]
25
+
26
+ **Comandos de Execução:**
27
+ ```bash
28
+ [ex.: "npm test" ou "npm run test"] # Executar todos os testes
29
+ [ex.: "npm test -- --watch"] # Modo watch
30
+ [ex.: "npm test -- path/to/file.test.ts"] # Arquivo único
31
+ [ex.: "npm run test:coverage"] # Relatório de cobertura
32
+ ```
33
+
34
+ ## Organização dos Arquivos de Teste
35
+
36
+ **Localização:**
37
+ - [Padrão: ex.: "*.test.ts junto aos arquivos fonte"]
38
+ - [Alternativa: ex.: "diretório __tests__/" ou "árvore tests/ separada"]
39
+
40
+ **Nomenclatura:**
41
+ - [Testes unitários: ex.: "nome-do-modulo.test.ts"]
42
+ - [Integração: ex.: "nome-da-funcionalidade.integration.test.ts"]
43
+ - [E2E: ex.: "fluxo-do-usuario.e2e.test.ts"]
44
+
45
+ **Estrutura:**
46
+ ```
47
+ [Mostrar padrão real de diretório, ex.:
48
+ src/
49
+ lib/
50
+ utils.ts
51
+ utils.test.ts
52
+ services/
53
+ user-service.ts
54
+ user-service.test.ts
55
+ ]
56
+ ```
57
+
58
+ ## Estrutura dos Testes
59
+
60
+ **Organização de Suites:**
61
+ ```typescript
62
+ [Mostrar padrão real usado, ex.:
63
+
64
+ describe('NomeDoModulo', () => {
65
+ describe('nomeDaFuncao', () => {
66
+ it('deve tratar caso de sucesso', () => {
67
+ // arrange
68
+ // act
69
+ // assert
70
+ });
71
+
72
+ it('deve tratar caso de erro', () => {
73
+ // código do teste
74
+ });
75
+ });
76
+ });
77
+ ]
78
+ ```
79
+
80
+ **Padrões:**
81
+ - [Setup: ex.: "beforeEach para setup compartilhado, evitar beforeAll"]
82
+ - [Teardown: ex.: "afterEach para limpar, restaurar mocks"]
83
+ - [Estrutura: ex.: "padrão arrange/act/assert obrigatório"]
84
+
85
+ ## Mocking
86
+
87
+ **Framework:**
88
+ - [Ferramenta: ex.: "mocking built-in do Jest", "Vitest vi", "Sinon"]
89
+ - [Import mocking: ex.: "vi.mock() no topo do arquivo"]
90
+
91
+ **Padrões:**
92
+ ```typescript
93
+ [Mostrar padrão real de mocking, ex.:
94
+
95
+ // Mock dependência externa
96
+ vi.mock('./external-service', () => ({
97
+ fetchData: vi.fn()
98
+ }));
99
+
100
+ // Mock no teste
101
+ const mockFetch = vi.mocked(fetchData);
102
+ mockFetch.mockResolvedValue({ data: 'test' });
103
+ ]
104
+ ```
105
+
106
+ **O Que Mockar:**
107
+ - [ex.: "APIs externas, sistema de arquivos, banco de dados"]
108
+ - [ex.: "Tempo/datas (usar vi.useFakeTimers)"]
109
+ - [ex.: "Chamadas de rede (usar mock fetch)"]
110
+
111
+ **O Que NÃO Mockar:**
112
+ - [ex.: "Funções puras, utilitários"]
113
+ - [ex.: "Lógica de negócio interna"]
114
+
115
+ ## Fixtures e Factories
116
+
117
+ **Dados de Teste:**
118
+ ```typescript
119
+ [Mostrar padrão para criar dados de teste, ex.:
120
+
121
+ // Padrão factory
122
+ function createTestUser(overrides?: Partial<User>): User {
123
+ return {
124
+ id: 'test-id',
125
+ name: 'Test User',
126
+ email: 'test@example.com',
127
+ ...overrides
128
+ };
129
+ }
130
+
131
+ // Arquivo de fixture
132
+ // tests/fixtures/users.ts
133
+ export const mockUsers = [/* ... */];
134
+ ]
135
+ ```
136
+
137
+ **Localização:**
138
+ - [ex.: "tests/fixtures/ para fixtures compartilhadas"]
139
+ - [ex.: "funções factory no arquivo de teste ou tests/factories/"]
140
+
141
+ ## Cobertura
142
+
143
+ **Requisitos:**
144
+ - [Meta: ex.: "80% de cobertura de linhas", "sem meta específica"]
145
+ - [Aplicação: ex.: "CI bloqueia <80%", "cobertura apenas para conscientização"]
146
+
147
+ **Configuração:**
148
+ - [Ferramenta: ex.: "cobertura built-in via flag --coverage"]
149
+ - [Exclusões: ex.: "excluir *.test.ts, arquivos de config"]
150
+
151
+ **Ver Cobertura:**
152
+ ```bash
153
+ [ex.: "npm run test:coverage"]
154
+ [ex.: "open coverage/index.html"]
155
+ ```
156
+
157
+ ## Tipos de Testes
158
+
159
+ **Testes Unitários:**
160
+ - [Escopo: ex.: "testar função/classe única em isolamento"]
161
+ - [Mocking: ex.: "mockar todas as dependências externas"]
162
+ - [Velocidade: ex.: "deve executar em <1s por teste"]
163
+
164
+ **Testes de Integração:**
165
+ - [Escopo: ex.: "testar múltiplos módulos juntos"]
166
+ - [Mocking: ex.: "mockar serviços externos, usar módulos internos reais"]
167
+ - [Setup: ex.: "usar banco de dados de teste, seed de dados"]
168
+
169
+ **Testes E2E:**
170
+ - [Framework: ex.: "Playwright para E2E"]
171
+ - [Escopo: ex.: "testar fluxos completos do usuário"]
172
+ - [Localização: ex.: "diretório e2e/ separado dos testes unitários"]
173
+
174
+ ## Padrões Comuns
175
+
176
+ **Teste Async:**
177
+ ```typescript
178
+ [Mostrar padrão, ex.:
179
+
180
+ it('deve tratar operação async', async () => {
181
+ const result = await asyncFunction();
182
+ expect(result).toBe('expected');
183
+ });
184
+ ]
185
+ ```
186
+
187
+ **Teste de Erro:**
188
+ ```typescript
189
+ [Mostrar padrão, ex.:
190
+
191
+ it('deve lançar com entrada inválida', () => {
192
+ expect(() => functionCall()).toThrow('mensagem de erro');
193
+ });
194
+
195
+ // Erro async
196
+ it('deve rejeitar na falha', async () => {
197
+ await expect(asyncCall()).rejects.toThrow('mensagem de erro');
198
+ });
199
+ ]
200
+ ```
201
+
202
+ **Snapshot Testing:**
203
+ - [Uso: ex.: "apenas para componentes React" ou "não usado"]
204
+ - [Localização: ex.: "diretório __snapshots__/"]
205
+
206
+ ---
207
+
208
+ *Análise de testes: [data]*
209
+ *Atualizar quando padrões de teste mudarem*
210
+ ```
211
+
212
+ <good_examples>
213
+ ```markdown
214
+ # Testing Patterns
215
+
216
+ **Analysis Date:** 2025-01-20
217
+
218
+ ## Test Framework
219
+
220
+ **Runner:**
221
+ - Vitest 1.0.4
222
+ - Config: vitest.config.ts in project root
223
+
224
+ **Run Commands:**
225
+ ```bash
226
+ npm test # Run all tests
227
+ npm test -- --watch # Watch mode
228
+ npm run test:coverage # Coverage report
229
+ ```
230
+
231
+ ## Test File Organization
232
+
233
+ **Location:**
234
+ - *.test.ts alongside source files
235
+ - No separate tests/ directory
236
+
237
+ ## Test Structure
238
+
239
+ **Suite Organization:**
240
+ ```typescript
241
+ import { describe, it, expect, beforeEach, vi } from 'vitest';
242
+
243
+ describe('ModuleName', () => {
244
+ it('should handle valid input', () => {
245
+ // arrange
246
+ const input = createTestInput();
247
+ // act
248
+ const result = functionName(input);
249
+ // assert
250
+ expect(result).toEqual(expectedOutput);
251
+ });
252
+ });
253
+ ```
254
+
255
+ ---
256
+
257
+ *Testing analysis: 2025-01-20*
258
+ *Update when test patterns change*
259
+ ```
260
+ </good_examples>
261
+
262
+ <guidelines>
263
+ **O que pertence ao TESTING.md:**
264
+ - Framework de teste e configuração do runner
265
+ - Padrões de localização e nomenclatura de arquivos de teste
266
+ - Estrutura de teste (describe/it, padrões beforeEach)
267
+ - Abordagem de mocking e exemplos
268
+ - Padrões de fixture/factory
269
+ - Requisitos de cobertura
270
+ - Como executar testes (comandos)
271
+ - Padrões comuns de teste no código real
272
+
273
+ **O que NÃO pertence aqui:**
274
+ - Casos de teste específicos (diferir para os arquivos de teste reais)
275
+ - Escolhas tecnológicas (isso é STACK.md)
276
+ - Setup de CI/CD (isso é docs de deployment)
277
+
278
+ **Ao preencher este template:**
279
+ - Verificar scripts do package.json para comandos de teste
280
+ - Encontrar arquivo de config de teste (jest.config.js, vitest.config.ts)
281
+ - Ler 3-5 arquivos de teste existentes para identificar padrões
282
+ - Procurar utilitários de teste em tests/ ou test-utils/
283
+ - Verificar configuração de cobertura
284
+ - Documentar padrões realmente usados, não padrões ideais
285
+
286
+ **Útil para planejamento de fases quando:**
287
+ - Adicionando novas funcionalidades (escrever testes correspondentes)
288
+ - Refatorando (manter padrões de teste)
289
+ - Corrigindo bugs (adicionar testes de regressão)
290
+ - Entendendo abordagem de verificação
291
+ - Configurando infraestrutura de teste
292
+
293
+ **Abordagem de análise:**
294
+ - Verificar package.json para framework de teste e scripts
295
+ - Ler arquivo de config de teste para cobertura, setup
296
+ - Examinar organização dos arquivos de teste (colocalizados vs. separados)
297
+ - Revisar 5 arquivos de teste para padrões (mocking, estrutura, asserções)
298
+ - Procurar utilitários de teste, fixtures, factories
299
+ - Notar quaisquer tipos de teste (unitário, integração, e2e)
300
+ - Documentar comandos para executar testes
301
+ </guidelines>