@luanpdd/kit-mcp 0.2.1 → 0.3.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.
- package/kit/COMANDOS.md +123 -0
- package/kit/agents/advisor-researcher.md +121 -0
- package/kit/agents/assumptions-analyzer.md +122 -0
- package/kit/agents/codebase-mapper.md +787 -0
- package/kit/agents/debugger.md +796 -0
- package/kit/agents/executor.md +516 -0
- package/kit/agents/integration-checker.md +217 -0
- package/kit/agents/nyquist-auditor.md +195 -0
- package/kit/agents/phase-researcher.md +715 -0
- package/kit/agents/plan-checker.md +289 -0
- package/kit/agents/planner.md +1373 -0
- package/kit/agents/project-researcher.md +671 -0
- package/kit/agents/research-synthesizer.md +259 -0
- package/kit/agents/roadmapper.md +696 -0
- package/kit/agents/ui-auditor.md +458 -0
- package/kit/agents/ui-checker.md +319 -0
- package/kit/agents/ui-researcher.md +374 -0
- package/kit/agents/user-profiler.md +183 -0
- package/kit/agents/verifier.md +719 -0
- package/kit/commands/adicionar-backlog.md +76 -0
- package/kit/commands/adicionar-fase.md +43 -0
- package/kit/commands/adicionar-tarefa.md +47 -0
- package/kit/commands/adicionar-testes.md +41 -0
- package/kit/commands/ajuda.md +22 -0
- package/kit/commands/atualizar.md +37 -0
- package/kit/commands/auditar-marco.md +36 -0
- package/kit/commands/auditar-uat.md +24 -0
- package/kit/commands/autonomo.md +41 -0
- package/kit/commands/branch-pr.md +25 -0
- package/kit/commands/concluir-marco.md +136 -0
- package/kit/commands/configuracoes.md +36 -0
- package/kit/commands/definir-perfil.md +12 -0
- package/kit/commands/depurar.md +173 -0
- package/kit/commands/discutir-fase.md +64 -0
- package/kit/commands/entrar-discord.md +18 -0
- package/kit/commands/estatisticas.md +18 -0
- package/kit/commands/executar-fase.md +59 -0
- package/kit/commands/expresso.md +47 -0
- package/kit/commands/fase-ui.md +34 -0
- package/kit/commands/fazer.md +30 -0
- package/kit/commands/fio.md +126 -0
- package/kit/commands/fluxos-trabalho.md +64 -0
- package/kit/commands/forense.md +56 -0
- package/kit/commands/gerenciador.md +39 -0
- package/kit/commands/inserir-fase.md +32 -0
- package/kit/commands/limpeza.md +18 -0
- package/kit/commands/listar-hipoteses-fase.md +46 -0
- package/kit/commands/listar-workspaces.md +19 -0
- package/kit/commands/mapear-codebase.md +71 -0
- package/kit/commands/nota.md +34 -0
- package/kit/commands/novo-marco.md +44 -0
- package/kit/commands/novo-projeto.md +42 -0
- package/kit/commands/novo-workspace.md +44 -0
- package/kit/commands/pausar-trabalho.md +38 -0
- package/kit/commands/perfil-usuario.md +46 -0
- package/kit/commands/pesquisar-fase.md +195 -0
- package/kit/commands/planejar-fase.md +47 -0
- package/kit/commands/planejar-lacunas.md +34 -0
- package/kit/commands/plantar-ideia.md +26 -0
- package/kit/commands/progresso.md +24 -0
- package/kit/commands/proximo.md +24 -0
- package/kit/commands/publicar.md +370 -0
- package/kit/commands/rapido.md +30 -0
- package/kit/commands/reaplicar-patches.md +124 -0
- package/kit/commands/relatorio-sessao.md +19 -0
- package/kit/commands/remover-fase.md +31 -0
- package/kit/commands/remover-workspace.md +26 -0
- package/kit/commands/resumo-marco.md +51 -0
- package/kit/commands/retomar-trabalho.md +40 -0
- package/kit/commands/revisar-backlog.md +60 -0
- package/kit/commands/revisar-ui.md +32 -0
- package/kit/commands/revisar.md +37 -0
- package/kit/commands/saude.md +22 -0
- package/kit/commands/setup-notion.md +93 -0
- package/kit/commands/sync-main.md +68 -0
- package/kit/commands/validar-fase.md +35 -0
- package/kit/commands/verificar-tarefas.md +45 -0
- package/kit/commands/verificar-trabalho.md +38 -0
- package/kit/file-manifest.json +219 -0
- package/kit/framework/VERSION +1 -0
- package/kit/framework/bin/lib/commands.cjs +959 -0
- package/kit/framework/bin/lib/config.cjs +442 -0
- package/kit/framework/bin/lib/core.cjs +1230 -0
- package/kit/framework/bin/lib/frontmatter.cjs +336 -0
- package/kit/framework/bin/lib/init.cjs +1442 -0
- package/kit/framework/bin/lib/milestone.cjs +252 -0
- package/kit/framework/bin/lib/model-profiles.cjs +68 -0
- package/kit/framework/bin/lib/phase.cjs +888 -0
- package/kit/framework/bin/lib/profile-output.cjs +952 -0
- package/kit/framework/bin/lib/profile-pipeline.cjs +539 -0
- package/kit/framework/bin/lib/roadmap.cjs +329 -0
- package/kit/framework/bin/lib/security.cjs +382 -0
- package/kit/framework/bin/lib/state.cjs +1031 -0
- package/kit/framework/bin/lib/template.cjs +222 -0
- package/kit/framework/bin/lib/uat.cjs +282 -0
- package/kit/framework/bin/lib/verify.cjs +888 -0
- package/kit/framework/bin/lib/workstream.cjs +491 -0
- package/kit/framework/bin/tools.cjs +918 -0
- package/kit/framework/commands/workstreams.md +63 -0
- package/kit/framework/references/checkpoints.md +778 -0
- package/kit/framework/references/continuation-format.md +249 -0
- package/kit/framework/references/decimal-phase-calculation.md +64 -0
- package/kit/framework/references/git-integration.md +295 -0
- package/kit/framework/references/git-planning-commit.md +38 -0
- package/kit/framework/references/model-profile-resolution.md +36 -0
- package/kit/framework/references/model-profiles.md +139 -0
- package/kit/framework/references/phase-argument-parsing.md +61 -0
- package/kit/framework/references/planning-config.md +202 -0
- package/kit/framework/references/questioning.md +162 -0
- package/kit/framework/references/tdd.md +263 -0
- package/kit/framework/references/ui-brand.md +160 -0
- package/kit/framework/references/user-profiling.md +657 -0
- package/kit/framework/references/verification-patterns.md +612 -0
- package/kit/framework/references/workstream-flag.md +58 -0
- package/kit/framework/templates/DEBUG.md +164 -0
- package/kit/framework/templates/UAT.md +265 -0
- package/kit/framework/templates/UI-SPEC.md +100 -0
- package/kit/framework/templates/VALIDATION.md +76 -0
- package/kit/framework/templates/claude-md.md +122 -0
- package/kit/framework/templates/codebase/architecture.md +185 -0
- package/kit/framework/templates/codebase/concerns.md +205 -0
- package/kit/framework/templates/codebase/conventions.md +204 -0
- package/kit/framework/templates/codebase/integrations.md +192 -0
- package/kit/framework/templates/codebase/stack.md +158 -0
- package/kit/framework/templates/codebase/structure.md +199 -0
- package/kit/framework/templates/codebase/testing.md +301 -0
- package/kit/framework/templates/config.json +44 -0
- package/kit/framework/templates/context.md +352 -0
- package/kit/framework/templates/continue-here.md +78 -0
- package/kit/framework/templates/copilot-instructions.md +7 -0
- package/kit/framework/templates/debug-subagent-prompt.md +91 -0
- package/kit/framework/templates/dev-preferences.md +20 -0
- package/kit/framework/templates/discovery.md +146 -0
- package/kit/framework/templates/discussion-log.md +63 -0
- package/kit/framework/templates/milestone-archive.md +123 -0
- package/kit/framework/templates/milestone.md +115 -0
- package/kit/framework/templates/phase-prompt.md +610 -0
- package/kit/framework/templates/planner-subagent-prompt.md +117 -0
- package/kit/framework/templates/project.md +186 -0
- package/kit/framework/templates/requirements.md +231 -0
- package/kit/framework/templates/research-project/ARCHITECTURE.md +204 -0
- package/kit/framework/templates/research-project/FEATURES.md +147 -0
- package/kit/framework/templates/research-project/PITFALLS.md +200 -0
- package/kit/framework/templates/research-project/STACK.md +120 -0
- package/kit/framework/templates/research-project/SUMMARY.md +170 -0
- package/kit/framework/templates/research.md +419 -0
- package/kit/framework/templates/retrospective.md +54 -0
- package/kit/framework/templates/roadmap.md +202 -0
- package/kit/framework/templates/state.md +176 -0
- package/kit/framework/templates/summary-complex.md +59 -0
- package/kit/framework/templates/summary-minimal.md +41 -0
- package/kit/framework/templates/summary-standard.md +48 -0
- package/kit/framework/templates/summary.md +209 -0
- package/kit/framework/templates/user-profile.md +146 -0
- package/kit/framework/templates/user-setup.md +256 -0
- package/kit/framework/templates/verification-report.md +258 -0
- package/kit/framework/workflows/add-phase.md +112 -0
- package/kit/framework/workflows/add-tests.md +351 -0
- package/kit/framework/workflows/add-todo.md +158 -0
- package/kit/framework/workflows/audit-milestone.md +340 -0
- package/kit/framework/workflows/audit-uat.md +109 -0
- package/kit/framework/workflows/autonomous.md +891 -0
- package/kit/framework/workflows/check-todos.md +177 -0
- package/kit/framework/workflows/cleanup.md +152 -0
- package/kit/framework/workflows/complete-milestone.md +696 -0
- package/kit/framework/workflows/diagnose-issues.md +231 -0
- package/kit/framework/workflows/discovery-phase.md +289 -0
- package/kit/framework/workflows/discuss-phase-assumptions.md +653 -0
- package/kit/framework/workflows/discuss-phase.md +1049 -0
- package/kit/framework/workflows/do.md +104 -0
- package/kit/framework/workflows/execute-phase.md +838 -0
- package/kit/framework/workflows/execute-plan.md +510 -0
- package/kit/framework/workflows/fast.md +102 -0
- package/kit/framework/workflows/forensics.md +265 -0
- package/kit/framework/workflows/health.md +181 -0
- package/kit/framework/workflows/help.md +606 -0
- package/kit/framework/workflows/insert-phase.md +130 -0
- package/kit/framework/workflows/list-phase-assumptions.md +178 -0
- package/kit/framework/workflows/list-workspaces.md +56 -0
- package/kit/framework/workflows/manager.md +362 -0
- package/kit/framework/workflows/map-codebase.md +377 -0
- package/kit/framework/workflows/milestone-summary.md +223 -0
- package/kit/framework/workflows/new-milestone.md +486 -0
- package/kit/framework/workflows/new-project.md +1250 -0
- package/kit/framework/workflows/new-workspace.md +237 -0
- package/kit/framework/workflows/next.md +97 -0
- package/kit/framework/workflows/node-repair.md +92 -0
- package/kit/framework/workflows/note.md +156 -0
- package/kit/framework/workflows/pause-work.md +176 -0
- package/kit/framework/workflows/plan-milestone-gaps.md +273 -0
- package/kit/framework/workflows/plan-phase.md +859 -0
- package/kit/framework/workflows/plant-seed.md +169 -0
- package/kit/framework/workflows/pr-branch.md +129 -0
- package/kit/framework/workflows/profile-user.md +450 -0
- package/kit/framework/workflows/progress.md +507 -0
- package/kit/framework/workflows/quick.md +757 -0
- package/kit/framework/workflows/remove-phase.md +155 -0
- package/kit/framework/workflows/remove-workspace.md +90 -0
- package/kit/framework/workflows/research-phase.md +82 -0
- package/kit/framework/workflows/resume-project.md +326 -0
- package/kit/framework/workflows/review.md +228 -0
- package/kit/framework/workflows/session-report.md +146 -0
- package/kit/framework/workflows/settings.md +283 -0
- package/kit/framework/workflows/ship.md +228 -0
- package/kit/framework/workflows/stats.md +60 -0
- package/kit/framework/workflows/transition.md +671 -0
- package/kit/framework/workflows/ui-phase.md +302 -0
- package/kit/framework/workflows/ui-review.md +165 -0
- package/kit/framework/workflows/update.md +323 -0
- package/kit/framework/workflows/validate-phase.md +174 -0
- package/kit/framework/workflows/verify-phase.md +252 -0
- package/kit/framework/workflows/verify-work.md +637 -0
- package/kit/hooks/check-update.js +114 -0
- package/kit/hooks/context-monitor.js +156 -0
- package/kit/hooks/prompt-guard.js +96 -0
- package/kit/hooks/statusline.js +119 -0
- package/kit/hooks/workflow-guard.js +94 -0
- package/kit/settings.json +45 -0
- package/package.json +1 -1
|
@@ -0,0 +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>
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
<purpose>
|
|
2
|
+
Capturar uma ideia, tarefa ou problema que surge durante uma sessão framework como um todo estruturado para trabalho futuro. Permite o fluxo "pensamento → captura → continuar" sem perder contexto.
|
|
3
|
+
</purpose>
|
|
4
|
+
|
|
5
|
+
<required_reading>
|
|
6
|
+
Leia todos os arquivos referenciados pelo execution_context do prompt que invocou antes de começar.
|
|
7
|
+
</required_reading>
|
|
8
|
+
|
|
9
|
+
<process>
|
|
10
|
+
|
|
11
|
+
<step name="init_context">
|
|
12
|
+
Carregar contexto de todos:
|
|
13
|
+
|
|
14
|
+
```bash
|
|
15
|
+
INIT=$(node "./.claude/framework/bin/tools.cjs" init todos)
|
|
16
|
+
if [[ "$INIT" == @file:* ]]; then INIT=$(cat "${INIT#@file:}"); fi
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
Extrair do JSON de init: `commit_docs`, `date`, `timestamp`, `todo_count`, `todos`, `pending_dir`, `todos_dir_exists`.
|
|
20
|
+
|
|
21
|
+
Garantir que os diretórios existam:
|
|
22
|
+
```bash
|
|
23
|
+
mkdir -p .planning/todos/pending .planning/todos/done
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
Anotar áreas existentes do array de todos para consistência no passo infer_area.
|
|
27
|
+
</step>
|
|
28
|
+
|
|
29
|
+
<step name="extract_content">
|
|
30
|
+
**Com argumentos:** Use como título/foco.
|
|
31
|
+
- `/adicionar-tarefa Adicionar refresh de token auth` → título = "Adicionar refresh de token auth"
|
|
32
|
+
|
|
33
|
+
**Sem argumentos:** Analise a conversa recente para extrair:
|
|
34
|
+
- O problema específico, ideia ou tarefa discutida
|
|
35
|
+
- Caminhos de arquivo relevantes mencionados
|
|
36
|
+
- Detalhes técnicos (mensagens de erro, números de linha, restrições)
|
|
37
|
+
|
|
38
|
+
Formular:
|
|
39
|
+
- `title`: Título descritivo de 3-10 palavras (verbo de ação preferido)
|
|
40
|
+
- `problem`: O que está errado ou por que isso é necessário
|
|
41
|
+
- `solution`: Dicas de abordagem ou "TBD" se for apenas uma ideia
|
|
42
|
+
- `files`: Caminhos relevantes com números de linha da conversa
|
|
43
|
+
</step>
|
|
44
|
+
|
|
45
|
+
<step name="infer_area">
|
|
46
|
+
Inferir área a partir dos caminhos de arquivo:
|
|
47
|
+
|
|
48
|
+
| Padrão de caminho | Área |
|
|
49
|
+
|-------------------|------|
|
|
50
|
+
| `src/api/*`, `api/*` | `api` |
|
|
51
|
+
| `src/components/*`, `src/ui/*` | `ui` |
|
|
52
|
+
| `src/auth/*`, `auth/*` | `auth` |
|
|
53
|
+
| `src/db/*`, `database/*` | `database` |
|
|
54
|
+
| `tests/*`, `__tests__/*` | `testing` |
|
|
55
|
+
| `docs/*` | `docs` |
|
|
56
|
+
| `.planning/*` | `planning` |
|
|
57
|
+
| `scripts/*`, `bin/*` | `tooling` |
|
|
58
|
+
| Sem arquivos ou incerto | `general` |
|
|
59
|
+
|
|
60
|
+
Use a área existente do passo 2 se houver correspondência similar.
|
|
61
|
+
</step>
|
|
62
|
+
|
|
63
|
+
<step name="check_duplicates">
|
|
64
|
+
```bash
|
|
65
|
+
# Buscar palavras-chave do título em todos existentes
|
|
66
|
+
grep -l -i "[palavras-chave do título]" .planning/todos/pending/*.md 2>/dev/null || true
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
Se encontrar duplicata potencial:
|
|
70
|
+
1. Leia o todo existente
|
|
71
|
+
2. Compare o escopo
|
|
72
|
+
|
|
73
|
+
Se houver sobreposição, use AskUserQuestion:
|
|
74
|
+
- header: "Duplicata?"
|
|
75
|
+
- question: "Todo similar existe: [título]. O que você gostaria de fazer?"
|
|
76
|
+
- options:
|
|
77
|
+
- "Ignorar" — manter todo existente
|
|
78
|
+
- "Substituir" — atualizar existente com novo contexto
|
|
79
|
+
- "Adicionar mesmo assim" — criar como todo separado
|
|
80
|
+
</step>
|
|
81
|
+
|
|
82
|
+
<step name="create_file">
|
|
83
|
+
Use valores do contexto de init: `timestamp` e `date` já estão disponíveis.
|
|
84
|
+
|
|
85
|
+
Gerar slug para o título:
|
|
86
|
+
```bash
|
|
87
|
+
slug=$(node "./.claude/framework/bin/tools.cjs" generate-slug "$title" --raw)
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
Escrever em `.planning/todos/pending/${date}-${slug}.md`:
|
|
91
|
+
|
|
92
|
+
```markdown
|
|
93
|
+
---
|
|
94
|
+
created: [timestamp]
|
|
95
|
+
title: [título]
|
|
96
|
+
area: [área]
|
|
97
|
+
files:
|
|
98
|
+
- [arquivo:linhas]
|
|
99
|
+
---
|
|
100
|
+
|
|
101
|
+
## Problema
|
|
102
|
+
|
|
103
|
+
[descrição do problema - contexto suficiente para Claude futuro entender semanas depois]
|
|
104
|
+
|
|
105
|
+
## Solução
|
|
106
|
+
|
|
107
|
+
[dicas de abordagem ou "TBD"]
|
|
108
|
+
```
|
|
109
|
+
</step>
|
|
110
|
+
|
|
111
|
+
<step name="update_state">
|
|
112
|
+
Se `.planning/STATE.md` existir:
|
|
113
|
+
|
|
114
|
+
1. Use `todo_count` do contexto de init (ou re-execute `init todos` se a contagem mudou)
|
|
115
|
+
2. Atualize "### Pending Todos" em "## Accumulated Context"
|
|
116
|
+
</step>
|
|
117
|
+
|
|
118
|
+
<step name="git_commit">
|
|
119
|
+
Commitar o todo e qualquer estado atualizado:
|
|
120
|
+
|
|
121
|
+
```bash
|
|
122
|
+
node "./.claude/framework/bin/tools.cjs" commit "docs: capture todo - [título]" --files .planning/todos/pending/[filename] .planning/STATE.md
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
A ferramenta respeita a configuração `commit_docs` e gitignore automaticamente.
|
|
126
|
+
|
|
127
|
+
Confirmar: "Commitado: docs: capture todo - [título]"
|
|
128
|
+
</step>
|
|
129
|
+
|
|
130
|
+
<step name="confirm">
|
|
131
|
+
```
|
|
132
|
+
Todo salvo: .planning/todos/pending/[filename]
|
|
133
|
+
|
|
134
|
+
[título]
|
|
135
|
+
Área: [área]
|
|
136
|
+
Arquivos: [contagem] referenciados
|
|
137
|
+
|
|
138
|
+
---
|
|
139
|
+
|
|
140
|
+
Deseja:
|
|
141
|
+
|
|
142
|
+
1. Continuar com o trabalho atual
|
|
143
|
+
2. Adicionar outro todo
|
|
144
|
+
3. Ver todos os todos (/verificar-tarefas)
|
|
145
|
+
```
|
|
146
|
+
</step>
|
|
147
|
+
|
|
148
|
+
</process>
|
|
149
|
+
|
|
150
|
+
<success_criteria>
|
|
151
|
+
- [ ] Estrutura de diretórios existe
|
|
152
|
+
- [ ] Arquivo de todo criado com frontmatter válido
|
|
153
|
+
- [ ] Seção de problema tem contexto suficiente para o Claude futuro
|
|
154
|
+
- [ ] Sem duplicatas (verificado e resolvido)
|
|
155
|
+
- [ ] Área consistente com todos existentes
|
|
156
|
+
- [ ] STATE.md atualizado se existir
|
|
157
|
+
- [ ] Todo e estado commitados no git
|
|
158
|
+
</success_criteria>
|