context-first-cli 2.3.2 → 2.3.5
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/README.md +108 -6
- package/dist/commands/feature.d.ts.map +1 -1
- package/dist/commands/feature.js +25 -26
- package/dist/commands/feature.js.map +1 -1
- package/package.json +1 -1
- package/dist/templates/commands/pt-BR/commands/engineer/plan.md +0 -301
- package/dist/templates/commands/pt-BR/commands/engineer/pr.md +0 -194
- package/dist/templates/commands/pt-BR/commands/engineer/pre-pr.md +0 -325
- package/dist/templates/commands/pt-BR/commands/engineer/start.md +0 -285
- package/dist/templates/commands/pt-BR/commands/engineer/work.md +0 -256
- package/dist/templates/commands/pt-BR/commands/products/check.md +0 -237
- package/dist/templates/commands/pt-BR/commands/products/collect.md +0 -170
- package/dist/templates/commands/pt-BR/commands/products/refine.md +0 -231
- package/dist/templates/commands/pt-BR/commands/products/spec.md +0 -271
- package/dist/templates/commands/pt-BR/commands/quality/metrics.md +0 -266
- package/dist/templates/commands/pt-BR/commands/quality/observe.md +0 -172
- package/dist/templates/commands/pt-BR/commands/warm-up.md +0 -59
|
@@ -1,271 +0,0 @@
|
|
|
1
|
-
# Criação de Especificação (PRD)
|
|
2
|
-
|
|
3
|
-
Este comando cria a especificação completa (Product Requirements Document) da feature.
|
|
4
|
-
|
|
5
|
-
## ⚠️ IMPORTANTE: Este Comando NÃO Implementa Código
|
|
6
|
-
|
|
7
|
-
**Este comando é APENAS para documentação de requisitos:**
|
|
8
|
-
- ✅ Criar PRD (Product Requirements Document)
|
|
9
|
-
- ✅ Atualizar issue no task manager via MCP
|
|
10
|
-
- ✅ **LER** arquivos dos repositórios principais (read-only)
|
|
11
|
-
- ❌ **NÃO implementar código**
|
|
12
|
-
- ❌ **NÃO fazer edits em arquivos de código**
|
|
13
|
-
- ❌ **NÃO fazer checkout de branches nos repositórios principais**
|
|
14
|
-
- ❌ **NÃO fazer commits**
|
|
15
|
-
|
|
16
|
-
**Próximo passo**: `/start` para iniciar o desenvolvimento.
|
|
17
|
-
|
|
18
|
-
---
|
|
19
|
-
|
|
20
|
-
## Configuração
|
|
21
|
-
|
|
22
|
-
Leia `context-manifest.json` e `ai.properties.md` do orchestrator para obter repositórios, base_path e task_management_system.
|
|
23
|
-
|
|
24
|
-
## Pré-requisitos
|
|
25
|
-
|
|
26
|
-
- Issue refinada via `/refine`
|
|
27
|
-
- Aprovação para prosseguir com a feature
|
|
28
|
-
|
|
29
|
-
## 📚 Carregar MetaSpecs
|
|
30
|
-
|
|
31
|
-
**Localizar MetaSpecs automaticamente**:
|
|
32
|
-
1. Leia `context-manifest.json` do orchestrator
|
|
33
|
-
2. Encontre o repositório com `"role": "metaspecs"`
|
|
34
|
-
3. Leia `ai.properties.md` para obter o `base_path`
|
|
35
|
-
4. O metaspecs está em: `{base_path}/{metaspecs-repo-id}/`
|
|
36
|
-
5. Leia os arquivos `index.md` relevantes para garantir conformidade com:
|
|
37
|
-
- Arquitetura do sistema
|
|
38
|
-
- Padrões de design
|
|
39
|
-
- Restrições técnicas
|
|
40
|
-
- Convenções do projeto
|
|
41
|
-
|
|
42
|
-
## 🎯 Objetivo
|
|
43
|
-
|
|
44
|
-
Criar um PRD completo que servirá como fonte única de verdade para a implementação.
|
|
45
|
-
|
|
46
|
-
## 📝 Estrutura do PRD
|
|
47
|
-
|
|
48
|
-
### 1. Visão Geral
|
|
49
|
-
|
|
50
|
-
```markdown
|
|
51
|
-
# [Título da Feature]
|
|
52
|
-
|
|
53
|
-
## Contexto
|
|
54
|
-
[Por que estamos construindo isso? Qual problema resolve?]
|
|
55
|
-
|
|
56
|
-
## Objetivo
|
|
57
|
-
[O que queremos alcançar com esta feature?]
|
|
58
|
-
|
|
59
|
-
## Métricas de Sucesso
|
|
60
|
-
- [Métrica 1]: [Como medir]
|
|
61
|
-
- [Métrica 2]: [Como medir]
|
|
62
|
-
```
|
|
63
|
-
|
|
64
|
-
### 2. Requisitos Funcionais
|
|
65
|
-
|
|
66
|
-
```markdown
|
|
67
|
-
## Requisitos Funcionais
|
|
68
|
-
|
|
69
|
-
### RF-01: [Nome do Requisito]
|
|
70
|
-
**Descrição**: [Descrição detalhada]
|
|
71
|
-
**Prioridade**: Must Have / Should Have / Could Have
|
|
72
|
-
**Repositórios**: [repos afetados]
|
|
73
|
-
|
|
74
|
-
### RF-02: [Nome do Requisito]
|
|
75
|
-
**Descrição**: [Descrição detalhada]
|
|
76
|
-
**Prioridade**: Must Have / Should Have / Could Have
|
|
77
|
-
**Repositórios**: [repos afetados]
|
|
78
|
-
```
|
|
79
|
-
|
|
80
|
-
### 3. Requisitos Não-Funcionais
|
|
81
|
-
|
|
82
|
-
```markdown
|
|
83
|
-
## Requisitos Não-Funcionais
|
|
84
|
-
|
|
85
|
-
### Performance
|
|
86
|
-
- [Requisito de performance]
|
|
87
|
-
|
|
88
|
-
### Segurança
|
|
89
|
-
- [Requisito de segurança]
|
|
90
|
-
|
|
91
|
-
### Acessibilidade
|
|
92
|
-
- [Requisito de acessibilidade]
|
|
93
|
-
|
|
94
|
-
### Escalabilidade
|
|
95
|
-
- [Requisito de escalabilidade]
|
|
96
|
-
```
|
|
97
|
-
|
|
98
|
-
### 4. Fluxos de Usuário
|
|
99
|
-
|
|
100
|
-
```markdown
|
|
101
|
-
## Fluxos de Usuário
|
|
102
|
-
|
|
103
|
-
### Fluxo Principal
|
|
104
|
-
1. [Passo 1]
|
|
105
|
-
2. [Passo 2]
|
|
106
|
-
3. [Passo 3]
|
|
107
|
-
|
|
108
|
-
### Fluxos Alternativos
|
|
109
|
-
**Cenário**: [Nome do cenário]
|
|
110
|
-
1. [Passo 1]
|
|
111
|
-
2. [Passo 2]
|
|
112
|
-
|
|
113
|
-
### Tratamento de Erros
|
|
114
|
-
**Erro**: [Tipo de erro]
|
|
115
|
-
**Comportamento**: [Como o sistema deve reagir]
|
|
116
|
-
```
|
|
117
|
-
|
|
118
|
-
### 5. Especificação Técnica
|
|
119
|
-
|
|
120
|
-
```markdown
|
|
121
|
-
## Especificação Técnica
|
|
122
|
-
|
|
123
|
-
### Arquitetura
|
|
124
|
-
|
|
125
|
-
#### <repo-1>
|
|
126
|
-
- **Componentes novos**: [lista]
|
|
127
|
-
- **Componentes modificados**: [lista]
|
|
128
|
-
- **APIs**: [endpoints novos/modificados]
|
|
129
|
-
|
|
130
|
-
#### <repo-2>
|
|
131
|
-
- **Componentes novos**: [lista]
|
|
132
|
-
- **Componentes modificados**: [lista]
|
|
133
|
-
- **APIs**: [endpoints novos/modificados]
|
|
134
|
-
|
|
135
|
-
### Integrações
|
|
136
|
-
- **Entre repos**: [como os repos se comunicam]
|
|
137
|
-
- **Externas**: [APIs externas, se houver]
|
|
138
|
-
|
|
139
|
-
### Modelo de Dados
|
|
140
|
-
[Descreva mudanças no modelo de dados, se houver]
|
|
141
|
-
```
|
|
142
|
-
|
|
143
|
-
### 6. Critérios de Aceitação
|
|
144
|
-
|
|
145
|
-
```markdown
|
|
146
|
-
## Critérios de Aceitação
|
|
147
|
-
|
|
148
|
-
### Funcional
|
|
149
|
-
- [ ] [Critério específico e testável]
|
|
150
|
-
- [ ] [Critério específico e testável]
|
|
151
|
-
|
|
152
|
-
### Técnico
|
|
153
|
-
- [ ] Testes unitários com cobertura >= X%
|
|
154
|
-
- [ ] Testes de integração implementados
|
|
155
|
-
- [ ] Performance dentro dos requisitos
|
|
156
|
-
- [ ] Documentação atualizada
|
|
157
|
-
|
|
158
|
-
### Qualidade
|
|
159
|
-
- [ ] Code review aprovado
|
|
160
|
-
- [ ] Sem regressões
|
|
161
|
-
- [ ] Acessibilidade validada
|
|
162
|
-
```
|
|
163
|
-
|
|
164
|
-
### 7. Fora do Escopo
|
|
165
|
-
|
|
166
|
-
```markdown
|
|
167
|
-
## Fora do Escopo
|
|
168
|
-
|
|
169
|
-
Funcionalidades que NÃO serão implementadas nesta versão:
|
|
170
|
-
- [Item 1]
|
|
171
|
-
- [Item 2]
|
|
172
|
-
|
|
173
|
-
Justificativa: [Por que ficam para depois]
|
|
174
|
-
```
|
|
175
|
-
|
|
176
|
-
### 8. Riscos e Mitigações
|
|
177
|
-
|
|
178
|
-
```markdown
|
|
179
|
-
## Riscos e Mitigações
|
|
180
|
-
|
|
181
|
-
### Risco 1: [Descrição]
|
|
182
|
-
- **Probabilidade**: Alta / Média / Baixa
|
|
183
|
-
- **Impacto**: Alto / Médio / Baixo
|
|
184
|
-
- **Mitigação**: [Como mitigar]
|
|
185
|
-
|
|
186
|
-
### Risco 2: [Descrição]
|
|
187
|
-
- **Probabilidade**: Alta / Média / Baixa
|
|
188
|
-
- **Impacto**: Alto / Médio / Baixo
|
|
189
|
-
- **Mitigação**: [Como mitigar]
|
|
190
|
-
```
|
|
191
|
-
|
|
192
|
-
### 9. Dependências
|
|
193
|
-
|
|
194
|
-
```markdown
|
|
195
|
-
## Dependências
|
|
196
|
-
|
|
197
|
-
### Técnicas
|
|
198
|
-
- [Dependência técnica 1]
|
|
199
|
-
- [Dependência técnica 2]
|
|
200
|
-
|
|
201
|
-
### De Negócio
|
|
202
|
-
- [Dependência de negócio 1]
|
|
203
|
-
- [Dependência de negócio 2]
|
|
204
|
-
|
|
205
|
-
### Bloqueadores
|
|
206
|
-
- [Bloqueador 1 e plano para resolver]
|
|
207
|
-
```
|
|
208
|
-
|
|
209
|
-
### 10. Plano de Testes
|
|
210
|
-
|
|
211
|
-
```markdown
|
|
212
|
-
## Plano de Testes
|
|
213
|
-
|
|
214
|
-
### Testes Unitários
|
|
215
|
-
- [Área 1 a ser testada]
|
|
216
|
-
- [Área 2 a ser testada]
|
|
217
|
-
|
|
218
|
-
### Testes de Integração
|
|
219
|
-
- [Cenário 1]
|
|
220
|
-
- [Cenário 2]
|
|
221
|
-
|
|
222
|
-
### Testes Manuais
|
|
223
|
-
- [Cenário 1]
|
|
224
|
-
- [Cenário 2]
|
|
225
|
-
```
|
|
226
|
-
|
|
227
|
-
## 📄 Salvamento do PRD
|
|
228
|
-
|
|
229
|
-
**PRIORIDADE 1: Usar MCP (Model Context Protocol)**
|
|
230
|
-
|
|
231
|
-
- Leia `ai.properties.md` do orchestrator para identificar o `task_management_system`
|
|
232
|
-
- Use o MCP apropriado para atualizar a issue com o PRD:
|
|
233
|
-
- Adicione o PRD completo como comentário na issue
|
|
234
|
-
- Ou anexe como arquivo (se o task manager suportar)
|
|
235
|
-
- Atualize status/labels (ex: "spec-ready", "ready-for-dev")
|
|
236
|
-
- Informe ao usuário: "✅ PRD adicionado à issue [ID]"
|
|
237
|
-
|
|
238
|
-
**FALLBACK: Criar arquivo .md apenas se MCP falhar**
|
|
239
|
-
|
|
240
|
-
Se o MCP não estiver disponível ou falhar:
|
|
241
|
-
- Salve em `./.sessions/<ISSUE-ID>/prd.md`
|
|
242
|
-
- Informe ao usuário: "⚠️ PRD salvo localmente em .sessions/ (task manager não disponível)"
|
|
243
|
-
|
|
244
|
-
## 🔍 Revisão e Aprovação
|
|
245
|
-
|
|
246
|
-
Antes de finalizar:
|
|
247
|
-
1. Revise o PRD com stakeholders
|
|
248
|
-
2. Valide contra metaspecs (se disponíveis)
|
|
249
|
-
3. Obtenha aprovação para iniciar implementação
|
|
250
|
-
4. **Via MCP**: Atualize a issue no task manager com status "Pronto para Desenvolvimento"
|
|
251
|
-
5. **Fallback**: Documente aprovação em `./.sessions/<ISSUE-ID>/prd.md`
|
|
252
|
-
|
|
253
|
-
---
|
|
254
|
-
|
|
255
|
-
**Argumentos fornecidos**:
|
|
256
|
-
|
|
257
|
-
```
|
|
258
|
-
#$ARGUMENTS
|
|
259
|
-
```
|
|
260
|
-
|
|
261
|
-
---
|
|
262
|
-
|
|
263
|
-
## 🎯 Próximo Passo
|
|
264
|
-
|
|
265
|
-
Após aprovação do PRD:
|
|
266
|
-
|
|
267
|
-
```bash
|
|
268
|
-
/start
|
|
269
|
-
```
|
|
270
|
-
|
|
271
|
-
Este comando iniciará o desenvolvimento da feature.
|
|
@@ -1,266 +0,0 @@
|
|
|
1
|
-
# Métricas de Qualidade
|
|
2
|
-
|
|
3
|
-
Este comando coleta e analisa métricas de qualidade do código e do processo de desenvolvimento.
|
|
4
|
-
|
|
5
|
-
## 🎯 Objetivo
|
|
6
|
-
|
|
7
|
-
Medir e documentar a qualidade da implementação através de métricas objetivas:
|
|
8
|
-
- Cobertura de testes
|
|
9
|
-
- Complexidade do código
|
|
10
|
-
- Dívida técnica
|
|
11
|
-
- Performance
|
|
12
|
-
- Conformidade com padrões
|
|
13
|
-
|
|
14
|
-
## Configuração
|
|
15
|
-
|
|
16
|
-
Leia `context-manifest.json` e `ai.properties.md` do orchestrator para obter repositórios, base_path e task_management_system.
|
|
17
|
-
|
|
18
|
-
## 📋 Pré-requisitos
|
|
19
|
-
|
|
20
|
-
- Implementação concluída (após `/work`)
|
|
21
|
-
- Testes implementados
|
|
22
|
-
- Build funcionando
|
|
23
|
-
|
|
24
|
-
## 📊 Métricas a Coletar
|
|
25
|
-
|
|
26
|
-
### 1. Cobertura de Testes
|
|
27
|
-
|
|
28
|
-
Para cada repositório modificado:
|
|
29
|
-
|
|
30
|
-
```bash
|
|
31
|
-
cd <repositório>
|
|
32
|
-
|
|
33
|
-
# Executar testes com cobertura (exemplos por stack):
|
|
34
|
-
# Node.js: npm run test:coverage / jest --coverage
|
|
35
|
-
# Python: pytest --cov=src tests/
|
|
36
|
-
# Java: mvn jacoco:report / gradle jacocoTestReport
|
|
37
|
-
# Go: go test -cover ./...
|
|
38
|
-
# Ruby: rspec --coverage
|
|
39
|
-
# Rust: cargo tarpaulin
|
|
40
|
-
# PHP: ./vendor/bin/phpunit --coverage-html coverage/
|
|
41
|
-
# C#: dotnet test /p:CollectCoverage=true
|
|
42
|
-
|
|
43
|
-
# Capturar resultados
|
|
44
|
-
```
|
|
45
|
-
|
|
46
|
-
Documente:
|
|
47
|
-
```markdown
|
|
48
|
-
## Cobertura de Testes
|
|
49
|
-
|
|
50
|
-
### <repo-1>
|
|
51
|
-
- **Cobertura Total**: X%
|
|
52
|
-
- **Statements**: X%
|
|
53
|
-
- **Branches**: X%
|
|
54
|
-
- **Functions**: X%
|
|
55
|
-
- **Lines**: X%
|
|
56
|
-
- **Arquivos não cobertos**: [lista]
|
|
57
|
-
|
|
58
|
-
### <repo-2>
|
|
59
|
-
[Mesmo formato]
|
|
60
|
-
```
|
|
61
|
-
|
|
62
|
-
### 2. Complexidade do Código
|
|
63
|
-
|
|
64
|
-
Analise a complexidade ciclomática dos arquivos modificados:
|
|
65
|
-
|
|
66
|
-
```markdown
|
|
67
|
-
## Complexidade do Código
|
|
68
|
-
|
|
69
|
-
### Arquivos com Alta Complexidade
|
|
70
|
-
- **arquivo1.ts**: Complexidade 15 (recomendado: < 10)
|
|
71
|
-
- **arquivo2.ts**: Complexidade 12
|
|
72
|
-
|
|
73
|
-
### Recomendações
|
|
74
|
-
- [Sugestão de refatoração 1]
|
|
75
|
-
- [Sugestão de refatoração 2]
|
|
76
|
-
```
|
|
77
|
-
|
|
78
|
-
### 3. Qualidade do Código
|
|
79
|
-
|
|
80
|
-
```bash
|
|
81
|
-
# Executar linting (exemplos por stack):
|
|
82
|
-
# Node.js: npm run lint / eslint .
|
|
83
|
-
# Python: flake8 . / pylint src/
|
|
84
|
-
# Java: mvn checkstyle:check
|
|
85
|
-
# Go: golangci-lint run
|
|
86
|
-
# Ruby: rubocop
|
|
87
|
-
# Rust: cargo clippy
|
|
88
|
-
|
|
89
|
-
# Verificar formatação (exemplos por stack):
|
|
90
|
-
# Node.js: prettier --check .
|
|
91
|
-
# Python: black --check .
|
|
92
|
-
# Java: mvn formatter:validate
|
|
93
|
-
# Go: gofmt -l .
|
|
94
|
-
# Ruby: rubocop --format-only
|
|
95
|
-
# Rust: cargo fmt --check
|
|
96
|
-
|
|
97
|
-
# Análise estática (exemplos por stack):
|
|
98
|
-
# Node.js: npm run analyze (se configurado)
|
|
99
|
-
# Python: mypy src/ / bandit -r src/
|
|
100
|
-
# Java: mvn pmd:check / spotbugs:check
|
|
101
|
-
# Go: go vet ./...
|
|
102
|
-
# Ruby: brakeman (para Rails)
|
|
103
|
-
# Rust: cargo audit
|
|
104
|
-
```
|
|
105
|
-
|
|
106
|
-
Documente:
|
|
107
|
-
```markdown
|
|
108
|
-
## Qualidade do Código
|
|
109
|
-
|
|
110
|
-
### Linting
|
|
111
|
-
- **Erros**: 0
|
|
112
|
-
- **Warnings**: X
|
|
113
|
-
- **Warnings Justificados**: [lista com justificativas]
|
|
114
|
-
|
|
115
|
-
### Formatação
|
|
116
|
-
- **Status**: ✅ Conforme / ⚠️ Ajustes necessários
|
|
117
|
-
|
|
118
|
-
### Análise Estática
|
|
119
|
-
- **Problemas Críticos**: 0
|
|
120
|
-
- **Problemas Médios**: X
|
|
121
|
-
- **Problemas Baixos**: Y
|
|
122
|
-
```
|
|
123
|
-
|
|
124
|
-
### 4. Performance
|
|
125
|
-
|
|
126
|
-
Se aplicável, meça performance:
|
|
127
|
-
|
|
128
|
-
```markdown
|
|
129
|
-
## Performance
|
|
130
|
-
|
|
131
|
-
### Benchmarks
|
|
132
|
-
- **Operação X**: Yms (baseline: Zms)
|
|
133
|
-
- **Operação Y**: Yms (baseline: Zms)
|
|
134
|
-
|
|
135
|
-
### Otimizações Aplicadas
|
|
136
|
-
- [Otimização 1 e impacto]
|
|
137
|
-
- [Otimização 2 e impacto]
|
|
138
|
-
|
|
139
|
-
### Gargalos Identificados
|
|
140
|
-
- [Gargalo 1 e plano de mitigação]
|
|
141
|
-
```
|
|
142
|
-
|
|
143
|
-
### 5. Tamanho e Impacto
|
|
144
|
-
|
|
145
|
-
```markdown
|
|
146
|
-
## Tamanho e Impacto
|
|
147
|
-
|
|
148
|
-
### Linhas de Código
|
|
149
|
-
- **Adicionadas**: +X linhas
|
|
150
|
-
- **Removidas**: -Y linhas
|
|
151
|
-
- **Modificadas**: Z linhas
|
|
152
|
-
|
|
153
|
-
### Arquivos
|
|
154
|
-
- **Novos**: X arquivos
|
|
155
|
-
- **Modificados**: Y arquivos
|
|
156
|
-
- **Removidos**: Z arquivos
|
|
157
|
-
|
|
158
|
-
### Dependências
|
|
159
|
-
- **Novas dependências**: [lista]
|
|
160
|
-
- **Tamanho do bundle**: +X KB
|
|
161
|
-
```
|
|
162
|
-
|
|
163
|
-
### 6. Dívida Técnica
|
|
164
|
-
|
|
165
|
-
Identifique dívida técnica introduzida ou resolvida:
|
|
166
|
-
|
|
167
|
-
```markdown
|
|
168
|
-
## Dívida Técnica
|
|
169
|
-
|
|
170
|
-
### Dívida Introduzida
|
|
171
|
-
- **Item 1**: [Descrição e justificativa]
|
|
172
|
-
- Severidade: Alta / Média / Baixa
|
|
173
|
-
- Plano de resolução: [quando e como resolver]
|
|
174
|
-
|
|
175
|
-
### Dívida Resolvida
|
|
176
|
-
- **Item 1**: [O que foi resolvido]
|
|
177
|
-
- Impacto: [melhoria obtida]
|
|
178
|
-
```
|
|
179
|
-
|
|
180
|
-
## 📄 Relatório de Métricas
|
|
181
|
-
|
|
182
|
-
Crie `./.sessions/<ISSUE-ID>/metrics.md`:
|
|
183
|
-
|
|
184
|
-
```markdown
|
|
185
|
-
# Relatório de Métricas - [ISSUE-ID]
|
|
186
|
-
|
|
187
|
-
**Data**: [data/hora]
|
|
188
|
-
**Repositórios**: [lista]
|
|
189
|
-
|
|
190
|
-
## Resumo Executivo
|
|
191
|
-
|
|
192
|
-
- **Cobertura de Testes**: X% (meta: Y%)
|
|
193
|
-
- **Qualidade do Código**: ✅ / ⚠️ / ❌
|
|
194
|
-
- **Performance**: ✅ / ⚠️ / ❌
|
|
195
|
-
- **Dívida Técnica**: Baixa / Média / Alta
|
|
196
|
-
|
|
197
|
-
## Métricas Detalhadas
|
|
198
|
-
|
|
199
|
-
[Incluir todas as seções acima]
|
|
200
|
-
|
|
201
|
-
## Comparação com Baseline
|
|
202
|
-
|
|
203
|
-
| Métrica | Antes | Depois | Variação |
|
|
204
|
-
|---------|-------|--------|----------|
|
|
205
|
-
| Cobertura | X% | Y% | +Z% |
|
|
206
|
-
| Complexidade Média | X | Y | +Z |
|
|
207
|
-
| Bundle Size | X KB | Y KB | +Z KB |
|
|
208
|
-
|
|
209
|
-
## Ações Recomendadas
|
|
210
|
-
|
|
211
|
-
1. [Ação 1 - prioridade alta]
|
|
212
|
-
2. [Ação 2 - prioridade média]
|
|
213
|
-
3. [Ação 3 - prioridade baixa]
|
|
214
|
-
|
|
215
|
-
## Aprovação para Merge
|
|
216
|
-
|
|
217
|
-
- [ ] Cobertura de testes >= meta
|
|
218
|
-
- [ ] Sem problemas críticos de qualidade
|
|
219
|
-
- [ ] Performance dentro dos requisitos
|
|
220
|
-
- [ ] Dívida técnica documentada e aprovada
|
|
221
|
-
```
|
|
222
|
-
|
|
223
|
-
## 🎯 Metas de Qualidade
|
|
224
|
-
|
|
225
|
-
Se o projeto tiver metas definidas nas metaspecs, valide:
|
|
226
|
-
|
|
227
|
-
```markdown
|
|
228
|
-
## Validação contra Metas
|
|
229
|
-
|
|
230
|
-
### Metas do Projeto
|
|
231
|
-
- **Cobertura mínima**: 80%
|
|
232
|
-
- **Complexidade máxima**: 10
|
|
233
|
-
- **Performance**: < 100ms
|
|
234
|
-
|
|
235
|
-
### Status
|
|
236
|
-
- Cobertura: ✅ 85% (meta: 80%)
|
|
237
|
-
- Complexidade: ⚠️ 12 (meta: 10) - Justificado
|
|
238
|
-
- Performance: ✅ 85ms (meta: 100ms)
|
|
239
|
-
```
|
|
240
|
-
|
|
241
|
-
## 🚨 Alertas
|
|
242
|
-
|
|
243
|
-
Se alguma métrica estiver fora do aceitável:
|
|
244
|
-
1. 🛑 **DOCUMENTE** o problema
|
|
245
|
-
2. 💬 **ALERTE** o usuário
|
|
246
|
-
3. 🔧 **PROPONHA** ações corretivas
|
|
247
|
-
4. ⏸️ **CONSIDERE** bloquear o merge até resolução
|
|
248
|
-
|
|
249
|
-
---
|
|
250
|
-
|
|
251
|
-
**Argumentos fornecidos**:
|
|
252
|
-
|
|
253
|
-
```
|
|
254
|
-
#$ARGUMENTS
|
|
255
|
-
```
|
|
256
|
-
|
|
257
|
-
---
|
|
258
|
-
|
|
259
|
-
## 🎯 Resultado
|
|
260
|
-
|
|
261
|
-
Após executar este comando, você terá:
|
|
262
|
-
- Relatório completo de métricas
|
|
263
|
-
- Comparação com baseline e metas
|
|
264
|
-
- Identificação de problemas de qualidade
|
|
265
|
-
- Recomendações de ações
|
|
266
|
-
- Base objetiva para aprovação de merge
|
|
@@ -1,172 +0,0 @@
|
|
|
1
|
-
# Observabilidade de Decisões
|
|
2
|
-
|
|
3
|
-
Este comando registra decisões importantes tomadas durante o desenvolvimento, criando um log auditável para explicabilidade e rastreabilidade.
|
|
4
|
-
|
|
5
|
-
## 🎯 Objetivo
|
|
6
|
-
|
|
7
|
-
Criar registro estruturado de decisões técnicas e de produto, garantindo:
|
|
8
|
-
- **Explicabilidade**: Por que cada decisão foi tomada
|
|
9
|
-
- **Rastreabilidade**: Quais fontes (PRD, metaspecs, ADRs) embasaram a decisão
|
|
10
|
-
- **Auditoria**: Histórico completo de escolhas para revisão futura
|
|
11
|
-
- **Aprendizado**: Documentação de trade-offs e alternativas consideradas
|
|
12
|
-
|
|
13
|
-
**IMPORTANTE**: Este comando NÃO gera decisões novas. Ele apenas REGISTRA decisões que já foram tomadas no processo de desenvolvimento.
|
|
14
|
-
|
|
15
|
-
## Configuração
|
|
16
|
-
|
|
17
|
-
Leia `context-manifest.json` e `ai.properties.md` do orchestrator para obter repositórios, base_path e task_management_system.
|
|
18
|
-
|
|
19
|
-
## 📋 Pré-requisitos
|
|
20
|
-
|
|
21
|
-
- Executou pelo menos um dos comandos que geram decisões:
|
|
22
|
-
- `/spec` - gera PRD com decisões de produto
|
|
23
|
-
- `/plan` - gera plan.md com decisões técnicas
|
|
24
|
-
- `/work` - implementação gera decisões durante desenvolvimento
|
|
25
|
-
|
|
26
|
-
## 🔍 Processo de Observação
|
|
27
|
-
|
|
28
|
-
### 1. Identificar Decisões Relevantes
|
|
29
|
-
|
|
30
|
-
Analise os arquivos da sessão (`./.sessions/<ISSUE-ID>/`) para identificar decisões:
|
|
31
|
-
|
|
32
|
-
**Após `/spec`** - Decisões de Produto:
|
|
33
|
-
- Leia `./.sessions/<ISSUE-ID>/prd.md`
|
|
34
|
-
- Identifique decisões em:
|
|
35
|
-
- Escopo (o que entra/não entra na feature)
|
|
36
|
-
- Personas atendidas (quem é o público-alvo)
|
|
37
|
-
- Métricas de sucesso (como medir resultados)
|
|
38
|
-
- Requisitos não-funcionais (performance, acessibilidade)
|
|
39
|
-
- Restrições e trade-offs
|
|
40
|
-
|
|
41
|
-
**Após `/plan`** - Decisões Técnicas:
|
|
42
|
-
- Leia `./.sessions/<ISSUE-ID>/plan.md`
|
|
43
|
-
- Identifique decisões em:
|
|
44
|
-
- Arquitetura de componentes/módulos
|
|
45
|
-
- Escolha de bibliotecas ou ferramentas
|
|
46
|
-
- Padrões de implementação
|
|
47
|
-
- Estrutura de dados
|
|
48
|
-
- Estratégia de testes
|
|
49
|
-
|
|
50
|
-
**Durante `/work`** - Decisões de Implementação:
|
|
51
|
-
- Leia `./.sessions/<ISSUE-ID>/work.md`
|
|
52
|
-
- Identifique decisões em:
|
|
53
|
-
- Refatorações realizadas
|
|
54
|
-
- Mudanças de abordagem
|
|
55
|
-
- Otimizações aplicadas
|
|
56
|
-
- Tratamento de edge cases
|
|
57
|
-
|
|
58
|
-
### 2. Documentar Cada Decisão
|
|
59
|
-
|
|
60
|
-
Para cada decisão identificada, documente:
|
|
61
|
-
|
|
62
|
-
```markdown
|
|
63
|
-
## Decisão: [Título Claro]
|
|
64
|
-
|
|
65
|
-
**Contexto**: [Por que precisamos decidir isso? Qual o problema ou necessidade?]
|
|
66
|
-
|
|
67
|
-
**Opções Consideradas**:
|
|
68
|
-
1. **Opção A**: [Descrição]
|
|
69
|
-
- Prós: [vantagens]
|
|
70
|
-
- Contras: [desvantagens]
|
|
71
|
-
2. **Opção B**: [Descrição]
|
|
72
|
-
- Prós: [vantagens]
|
|
73
|
-
- Contras: [desvantagens]
|
|
74
|
-
|
|
75
|
-
**Decisão**: [Opção escolhida]
|
|
76
|
-
|
|
77
|
-
**Justificativa**: [Por que escolhemos esta opção? Quais critérios foram mais importantes?]
|
|
78
|
-
|
|
79
|
-
**Fontes**:
|
|
80
|
-
- [PRD seção X]
|
|
81
|
-
- [Metaspec Y]
|
|
82
|
-
- [ADR-00Z]
|
|
83
|
-
|
|
84
|
-
**Trade-offs Aceitos**: [Quais desvantagens aceitamos conscientemente?]
|
|
85
|
-
|
|
86
|
-
**Reversibilidade**: Fácil / Média / Difícil
|
|
87
|
-
|
|
88
|
-
**Data**: [data da decisão]
|
|
89
|
-
```
|
|
90
|
-
|
|
91
|
-
### 3. Criar Log de Decisões
|
|
92
|
-
|
|
93
|
-
Salve em `./.sessions/<ISSUE-ID>/decisions.md`:
|
|
94
|
-
|
|
95
|
-
```markdown
|
|
96
|
-
# Log de Decisões - [ISSUE-ID]
|
|
97
|
-
|
|
98
|
-
## Resumo
|
|
99
|
-
[Breve resumo das principais decisões tomadas nesta feature]
|
|
100
|
-
|
|
101
|
-
## Decisões de Produto
|
|
102
|
-
|
|
103
|
-
### [Decisão 1]
|
|
104
|
-
[Conforme template acima]
|
|
105
|
-
|
|
106
|
-
### [Decisão 2]
|
|
107
|
-
[Conforme template acima]
|
|
108
|
-
|
|
109
|
-
## Decisões Técnicas
|
|
110
|
-
|
|
111
|
-
### [Decisão 3]
|
|
112
|
-
[Conforme template acima]
|
|
113
|
-
|
|
114
|
-
### [Decisão 4]
|
|
115
|
-
[Conforme template acima]
|
|
116
|
-
|
|
117
|
-
## Decisões de Implementação
|
|
118
|
-
|
|
119
|
-
### [Decisão 5]
|
|
120
|
-
[Conforme template acima]
|
|
121
|
-
|
|
122
|
-
## Lições Aprendidas
|
|
123
|
-
- [Lição 1]
|
|
124
|
-
- [Lição 2]
|
|
125
|
-
|
|
126
|
-
## Decisões Pendentes
|
|
127
|
-
- [Decisão que ainda precisa ser tomada]
|
|
128
|
-
```
|
|
129
|
-
|
|
130
|
-
## 📊 Análise de Impacto
|
|
131
|
-
|
|
132
|
-
Para decisões críticas, documente o impacto:
|
|
133
|
-
|
|
134
|
-
```markdown
|
|
135
|
-
## Análise de Impacto
|
|
136
|
-
|
|
137
|
-
**Repositórios Afetados**: [lista]
|
|
138
|
-
|
|
139
|
-
**Componentes Impactados**: [lista]
|
|
140
|
-
|
|
141
|
-
**Dependências Criadas**: [lista]
|
|
142
|
-
|
|
143
|
-
**Riscos Introduzidos**: [lista]
|
|
144
|
-
|
|
145
|
-
**Mitigações Aplicadas**: [lista]
|
|
146
|
-
```
|
|
147
|
-
|
|
148
|
-
## 🔄 Revisão de Decisões
|
|
149
|
-
|
|
150
|
-
Periodicamente, revise as decisões tomadas:
|
|
151
|
-
- Ainda fazem sentido?
|
|
152
|
-
- Os trade-offs se provaram corretos?
|
|
153
|
-
- Há aprendizados para documentar?
|
|
154
|
-
- Alguma decisão precisa ser revertida?
|
|
155
|
-
|
|
156
|
-
---
|
|
157
|
-
|
|
158
|
-
**Argumentos fornecidos**:
|
|
159
|
-
|
|
160
|
-
```
|
|
161
|
-
#$ARGUMENTS
|
|
162
|
-
```
|
|
163
|
-
|
|
164
|
-
---
|
|
165
|
-
|
|
166
|
-
## 🎯 Resultado
|
|
167
|
-
|
|
168
|
-
Após executar este comando, você terá:
|
|
169
|
-
- Log completo de decisões em `./.sessions/<ISSUE-ID>/decisions.md`
|
|
170
|
-
- Rastreabilidade de cada escolha feita
|
|
171
|
-
- Documentação para futuras referências
|
|
172
|
-
- Base para ADRs (se decisões forem de arquitetura)
|