@girardelli/architect 2.2.0 → 4.0.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/README.md +105 -116
- package/__test_agent_output__/INDEX.md +1 -0
- package/__test_agent_output__/agents/AGENT-ORCHESTRATOR.md +1 -0
- package/__test_agent_output__/agents/DATABASE-ENGINEER.md +174 -0
- package/__test_agent_output__/agents/QA-TEST-ENGINEER.md +138 -0
- package/__test_agent_output__/agents/SECURITY-AUDITOR.md +106 -0
- package/__test_agent_output__/agents/TECH-DEBT-CONTROLLER.md +104 -0
- package/__test_agent_output__/agents/TYPESCRIPT-BACKEND-DEVELOPER.md +135 -0
- package/__test_agent_output__/guards/CODE-REVIEW-CHECKLIST.md +95 -0
- package/__test_agent_output__/guards/PREFLIGHT.md +200 -0
- package/__test_agent_output__/guards/QUALITY-GATES.md +1 -0
- package/__test_agent_output__/rules/00-general.md +229 -0
- package/__test_agent_output__/rules/01-architecture.md +191 -0
- package/__test_agent_output__/rules/02-security.md +402 -0
- package/__test_agent_output__/rules/03-nestjs.md +124 -0
- package/__test_agent_output__/templates/ADR.md +95 -0
- package/__test_agent_output__/templates/BDD.md +58 -0
- package/__test_agent_output__/templates/C4.md +68 -0
- package/__test_agent_output__/templates/TDD.md +86 -0
- package/__test_agent_output__/templates/THREAT-MODEL.md +82 -0
- package/__test_agent_output__/workflows/fix-bug.md +228 -0
- package/__test_agent_output__/workflows/new-feature.md +311 -0
- package/__test_agent_output__/workflows/review.md +95 -0
- package/__test_context_7RvUrO/src/modules/empty/empty.ts +0 -0
- package/__test_context_Rf5fNJ/src/modules/mixed/mixed.ts +5 -0
- package/__test_context_WRCnYH/src/modules/test/test.ts +10 -0
- package/__test_context_YsnVS3/src/modules/test/test.ts +10 -0
- package/__test_context_w7XZeH/src/modules/mixed/mixed.ts +5 -0
- package/__test_context_y5noh6/src/modules/empty/empty.ts +0 -0
- package/__test_framework__24OjAu/package.json +1 -0
- package/__test_framework__3ZDZsx/pyproject.toml +8 -0
- package/__test_framework__4T54Jn/package.json +1 -0
- package/__test_framework__4tlXu9/pyproject.toml +8 -0
- package/__test_framework__6boWqQ/Pipfile +6 -0
- package/__test_framework__6gygMU/pom.xml +10 -0
- package/__test_framework__6kxj0N/go.mod +8 -0
- package/__test_framework__7CEoXw/pom.xml +10 -0
- package/__test_framework__85DDz0/Pipfile +6 -0
- package/__test_framework__9WrRIr/pom.xml +7 -0
- package/__test_framework__ANqGKl/Gemfile +5 -0
- package/__test_framework__BCXTEM/go.mod +3 -0
- package/__test_framework__BHiPNq/setup.py +2 -0
- package/__test_framework__BqkiKv/package.json +1 -0
- package/__test_framework__C5yd8X/Pipfile.lock +1 -0
- package/__test_framework__C5yd8X/requirements.txt +1 -0
- package/__test_framework__C87d3a/manage.py +1 -0
- package/__test_framework__C87d3a/requirements.txt +2 -0
- package/__test_framework__DXNwc5/build.gradle +7 -0
- package/__test_framework__GhHSt3/build.gradle.kts +4 -0
- package/__test_framework__GzklJP/Cargo.toml +7 -0
- package/__test_framework__H4hd13/go.mod +8 -0
- package/__test_framework__HKjOXO/composer.json +1 -0
- package/__test_framework__HaDN45/Gemfile +3 -0
- package/__test_framework__IBO7YG/pyproject.toml +9 -0
- package/__test_framework__JwSOyF/pyproject.toml +6 -0
- package/__test_framework__K6HrCr/build.gradle +2 -0
- package/__test_framework__KzRPlh/pubspec.yaml +9 -0
- package/__test_framework__L6uIym/pyproject.toml +6 -0
- package/__test_framework__LOdoGK/requirements.txt +4 -0
- package/__test_framework__LgHzss/package.json +1 -0
- package/__test_framework__M76M6q/Gemfile +5 -0
- package/__test_framework__Mr9vWW/composer.json +1 -0
- package/__test_framework__N03Gnv/package.json +1 -0
- package/__test_framework__Num4UE/requirements +1 -0
- package/__test_framework__OAGw3Y/build.gradle +7 -0
- package/__test_framework__OQc8yG/pubspec.yaml +9 -0
- package/__test_framework__OwKZcd/requirements.txt +3 -0
- package/__test_framework__P0gFv7/requirements +1 -0
- package/__test_framework__PN55Rq/package.json +1 -0
- package/__test_framework__PQiqX8/pubspec.yaml +3 -0
- package/__test_framework__RBHsg7/composer.json +1 -0
- package/__test_framework__RHxif4/Cargo.toml +7 -0
- package/__test_framework__T0v0p1/Cargo.toml +4 -0
- package/__test_framework__Tu0clt/Pipfile.lock +1 -0
- package/__test_framework__Tu0clt/requirements.txt +1 -0
- package/__test_framework__TwDj9P/Cargo.toml +4 -0
- package/__test_framework__VQJNC4/pom.xml +7 -0
- package/__test_framework__W6sm05/package.json +1 -0
- package/__test_framework__W7vBLy/pyproject.toml +4 -0
- package/__test_framework__WNJOWT/setup.py +2 -0
- package/__test_framework__WSJs7U/package.json +1 -0
- package/__test_framework__YQ5VpA/build.gradle.kts +4 -0
- package/__test_framework__ZNEUEs/package.json +1 -0
- package/__test_framework__Znt922/pom.xml +7 -0
- package/__test_framework__azyg0h/pom.xml +7 -0
- package/__test_framework__c6otLr/package.json +1 -0
- package/__test_framework__cl9S9G/build.gradle +2 -0
- package/__test_framework__eilvV4/composer.json +1 -0
- package/__test_framework__gQZxXO/manage.py +1 -0
- package/__test_framework__gQZxXO/requirements.txt +2 -0
- package/__test_framework__ghvl26/poetry.lock +1 -0
- package/__test_framework__ghvl26/pyproject.toml +2 -0
- package/__test_framework__hR7b9U/Makefile +11 -0
- package/__test_framework__iESVsi/composer.json +1 -0
- package/__test_framework__jm6TJy/package.json +1 -0
- package/__test_framework__kBUpjs/pyproject.toml +9 -0
- package/__test_framework__kqoZrw/requirements.txt +4 -0
- package/__test_framework__lWkoyO/pyproject.toml +4 -0
- package/__test_framework__mTKnUO/package.json +1 -0
- package/__test_framework__nCeZwe/Makefile +11 -0
- package/__test_framework__oljsU0/package.json +1 -0
- package/__test_framework__osRG4q/go.mod +3 -0
- package/__test_framework__pCHH4F/package.json +1 -0
- package/__test_framework__pExx6E/Gemfile +3 -0
- package/__test_framework__pyBoGd/pyproject.toml +5 -0
- package/__test_framework__qw16VQ/package.json +1 -0
- package/__test_framework__rRayrG/package.json +1 -0
- package/__test_framework__s82zO5/package.json +1 -0
- package/__test_framework__tp8MFK/pyproject.toml +5 -0
- package/__test_framework__w44k4w/composer.json +1 -0
- package/__test_framework__yefPZY/poetry.lock +1 -0
- package/__test_framework__yefPZY/pyproject.toml +2 -0
- package/__test_framework__zCiyDT/requirements.txt +3 -0
- package/__test_framework__zGZN3j/pubspec.yaml +3 -0
- package/__test_framework__zXpnxL/package.json +1 -0
- package/architect-run.sh +431 -0
- package/assets/banner-v3.html +561 -0
- package/dist/agent-generator/context-enricher.d.ts +58 -0
- package/dist/agent-generator/context-enricher.d.ts.map +1 -0
- package/dist/agent-generator/context-enricher.js +581 -0
- package/dist/agent-generator/context-enricher.js.map +1 -0
- package/dist/agent-generator/domain-inferrer.d.ts +52 -0
- package/dist/agent-generator/domain-inferrer.d.ts.map +1 -0
- package/dist/agent-generator/domain-inferrer.js +575 -0
- package/dist/agent-generator/domain-inferrer.js.map +1 -0
- package/dist/agent-generator/framework-detector.d.ts +40 -0
- package/dist/agent-generator/framework-detector.d.ts.map +1 -0
- package/dist/agent-generator/framework-detector.js +611 -0
- package/dist/agent-generator/framework-detector.js.map +1 -0
- package/dist/agent-generator/index.d.ts +33 -0
- package/dist/agent-generator/index.d.ts.map +1 -0
- package/dist/agent-generator/index.js +477 -0
- package/dist/agent-generator/index.js.map +1 -0
- package/dist/agent-generator/stack-detector.d.ts +12 -0
- package/dist/agent-generator/stack-detector.d.ts.map +1 -0
- package/dist/agent-generator/stack-detector.js +128 -0
- package/dist/agent-generator/stack-detector.js.map +1 -0
- package/dist/agent-generator/templates/core/agents.d.ts +17 -0
- package/dist/agent-generator/templates/core/agents.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/agents.js +1252 -0
- package/dist/agent-generator/templates/core/agents.js.map +1 -0
- package/dist/agent-generator/templates/core/architecture-rules.d.ts +7 -0
- package/dist/agent-generator/templates/core/architecture-rules.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/architecture-rules.js +274 -0
- package/dist/agent-generator/templates/core/architecture-rules.js.map +1 -0
- package/dist/agent-generator/templates/core/general-rules.d.ts +8 -0
- package/dist/agent-generator/templates/core/general-rules.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/general-rules.js +301 -0
- package/dist/agent-generator/templates/core/general-rules.js.map +1 -0
- package/dist/agent-generator/templates/core/index-md.d.ts +7 -0
- package/dist/agent-generator/templates/core/index-md.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/index-md.js +246 -0
- package/dist/agent-generator/templates/core/index-md.js.map +1 -0
- package/dist/agent-generator/templates/core/orchestrator.d.ts +8 -0
- package/dist/agent-generator/templates/core/orchestrator.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/orchestrator.js +422 -0
- package/dist/agent-generator/templates/core/orchestrator.js.map +1 -0
- package/dist/agent-generator/templates/core/preflight.d.ts +8 -0
- package/dist/agent-generator/templates/core/preflight.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/preflight.js +213 -0
- package/dist/agent-generator/templates/core/preflight.js.map +1 -0
- package/dist/agent-generator/templates/core/quality-gates.d.ts +11 -0
- package/dist/agent-generator/templates/core/quality-gates.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/quality-gates.js +254 -0
- package/dist/agent-generator/templates/core/quality-gates.js.map +1 -0
- package/dist/agent-generator/templates/core/security-rules.d.ts +7 -0
- package/dist/agent-generator/templates/core/security-rules.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/security-rules.js +528 -0
- package/dist/agent-generator/templates/core/security-rules.js.map +1 -0
- package/dist/agent-generator/templates/core/skills-generator.d.ts +6 -0
- package/dist/agent-generator/templates/core/skills-generator.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/skills-generator.js +207 -0
- package/dist/agent-generator/templates/core/skills-generator.js.map +1 -0
- package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts +7 -0
- package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/workflow-fix-bug.js +237 -0
- package/dist/agent-generator/templates/core/workflow-fix-bug.js.map +1 -0
- package/dist/agent-generator/templates/core/workflow-new-feature.d.ts +8 -0
- package/dist/agent-generator/templates/core/workflow-new-feature.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/workflow-new-feature.js +321 -0
- package/dist/agent-generator/templates/core/workflow-new-feature.js.map +1 -0
- package/dist/agent-generator/templates/core/workflow-review.d.ts +7 -0
- package/dist/agent-generator/templates/core/workflow-review.d.ts.map +1 -0
- package/dist/agent-generator/templates/core/workflow-review.js +104 -0
- package/dist/agent-generator/templates/core/workflow-review.js.map +1 -0
- package/dist/agent-generator/templates/domain/index.d.ts +22 -0
- package/dist/agent-generator/templates/domain/index.d.ts.map +1 -0
- package/dist/agent-generator/templates/domain/index.js +1176 -0
- package/dist/agent-generator/templates/domain/index.js.map +1 -0
- package/dist/agent-generator/templates/stack/index.d.ts +8 -0
- package/dist/agent-generator/templates/stack/index.d.ts.map +1 -0
- package/dist/agent-generator/templates/stack/index.js +695 -0
- package/dist/agent-generator/templates/stack/index.js.map +1 -0
- package/dist/agent-generator/templates/template-helpers.d.ts +75 -0
- package/dist/agent-generator/templates/template-helpers.d.ts.map +1 -0
- package/dist/agent-generator/templates/template-helpers.js +726 -0
- package/dist/agent-generator/templates/template-helpers.js.map +1 -0
- package/dist/agent-generator/types.d.ts +196 -0
- package/dist/agent-generator/types.d.ts.map +1 -0
- package/dist/agent-generator/types.js +27 -0
- package/dist/agent-generator/types.js.map +1 -0
- package/dist/analyzer.d.ts +5 -0
- package/dist/analyzer.d.ts.map +1 -1
- package/dist/analyzer.js +35 -4
- package/dist/analyzer.js.map +1 -1
- package/dist/analyzers/forecast.d.ts +85 -0
- package/dist/analyzers/forecast.d.ts.map +1 -0
- package/dist/analyzers/forecast.js +337 -0
- package/dist/analyzers/forecast.js.map +1 -0
- package/dist/analyzers/git-cache.d.ts +7 -0
- package/dist/analyzers/git-cache.d.ts.map +1 -0
- package/dist/analyzers/git-cache.js +41 -0
- package/dist/analyzers/git-cache.js.map +1 -0
- package/dist/analyzers/git-history.d.ts +113 -0
- package/dist/analyzers/git-history.d.ts.map +1 -0
- package/dist/analyzers/git-history.js +333 -0
- package/dist/analyzers/git-history.js.map +1 -0
- package/dist/analyzers/index.d.ts +10 -0
- package/dist/analyzers/index.d.ts.map +1 -0
- package/dist/analyzers/index.js +7 -0
- package/dist/analyzers/index.js.map +1 -0
- package/dist/analyzers/temporal-scorer.d.ts +72 -0
- package/dist/analyzers/temporal-scorer.d.ts.map +1 -0
- package/dist/analyzers/temporal-scorer.js +140 -0
- package/dist/analyzers/temporal-scorer.js.map +1 -0
- package/dist/cli.d.ts +2 -3
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +275 -113
- package/dist/cli.js.map +1 -1
- package/dist/html-reporter.d.ts +3 -1
- package/dist/html-reporter.d.ts.map +1 -1
- package/dist/html-reporter.js +248 -12
- package/dist/html-reporter.js.map +1 -1
- package/dist/index.d.ts +16 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +63 -4
- package/dist/index.js.map +1 -1
- package/dist/project-summarizer.d.ts +18 -0
- package/dist/project-summarizer.d.ts.map +1 -0
- package/dist/project-summarizer.js +306 -0
- package/dist/project-summarizer.js.map +1 -0
- package/dist/refactor-reporter.js +1 -1
- package/dist/types.d.ts +13 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +12 -3
- package/src/agent-generator/context-enricher.ts +643 -0
- package/src/agent-generator/domain-inferrer.ts +625 -0
- package/src/agent-generator/framework-detector.ts +669 -0
- package/src/agent-generator/index.ts +555 -0
- package/src/agent-generator/stack-detector.ts +103 -0
- package/src/agent-generator/templates/core/agents.ts +1293 -0
- package/src/agent-generator/templates/core/architecture-rules.ts +287 -0
- package/src/agent-generator/templates/core/general-rules.ts +306 -0
- package/src/agent-generator/templates/core/index-md.ts +260 -0
- package/src/agent-generator/templates/core/orchestrator.ts +459 -0
- package/src/agent-generator/templates/core/preflight.ts +215 -0
- package/src/agent-generator/templates/core/quality-gates.ts +256 -0
- package/src/agent-generator/templates/core/security-rules.ts +543 -0
- package/src/agent-generator/templates/core/skills-generator.ts +236 -0
- package/src/agent-generator/templates/core/workflow-fix-bug.ts +239 -0
- package/src/agent-generator/templates/core/workflow-new-feature.ts +323 -0
- package/src/agent-generator/templates/core/workflow-review.ts +106 -0
- package/src/agent-generator/templates/domain/index.ts +1201 -0
- package/src/agent-generator/templates/stack/index.ts +705 -0
- package/src/agent-generator/templates/template-helpers.ts +776 -0
- package/src/agent-generator/types.ts +232 -0
- package/src/analyzer.ts +38 -4
- package/src/analyzers/forecast.ts +496 -0
- package/src/analyzers/git-cache.ts +52 -0
- package/src/analyzers/git-history.ts +488 -0
- package/src/analyzers/index.ts +33 -0
- package/src/analyzers/temporal-scorer.ts +227 -0
- package/src/cli.ts +316 -117
- package/src/html-reporter.ts +263 -13
- package/src/index.ts +92 -9
- package/src/project-summarizer.ts +347 -0
- package/src/refactor-reporter.ts +1 -1
- package/src/types.ts +10 -0
- package/tests/agent-generator.test.ts +411 -0
- package/tests/analyzers-integration.test.ts +174 -0
- package/tests/architect-adapter-enrichment.test.ts +9 -0
- package/tests/context-enricher.test.ts +971 -0
- package/tests/forecast.test.ts +509 -0
- package/tests/framework-detector.test.ts +1172 -0
- package/tests/git-history.test.ts +254 -0
- package/tests/scanner.test.ts +7 -8
- package/tests/scorer.test.ts +588 -0
- package/tests/stack-detector.test.ts +241 -0
- package/tests/template-generation.test.ts +706 -0
- package/tests/template-helpers.test.ts +1152 -0
- package/tests/temporal-scorer.test.ts +307 -0
- package/dist/agent-generator.d.ts +0 -106
- package/dist/agent-generator.d.ts.map +0 -1
- package/dist/agent-generator.js +0 -1398
- package/dist/agent-generator.js.map +0 -1
- package/src/agent-generator.ts +0 -1526
|
@@ -0,0 +1,323 @@
|
|
|
1
|
+
import { TemplateContext } from '../../types.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Generates enterprise-grade new-feature.md workflow.
|
|
5
|
+
* 10 steps with approval gates, mockup-first, backend-first order,
|
|
6
|
+
* integration doc, coverage gate, user story/task templates.
|
|
7
|
+
*/
|
|
8
|
+
export function generateNewFeatureWorkflow(ctx: TemplateContext): string {
|
|
9
|
+
const { stack, projectName, config, report } = ctx;
|
|
10
|
+
|
|
11
|
+
return `---
|
|
12
|
+
antigravity:
|
|
13
|
+
trigger: 'on_demand'
|
|
14
|
+
description: 'Workflow completo para nova feature em ${projectName}'
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
# 🚀 Workflow: Nova Feature
|
|
18
|
+
|
|
19
|
+
> **Este workflow é OBRIGATÓRIO para qualquer nova funcionalidade.**
|
|
20
|
+
> Cada step tem um gate de aprovação. Pular steps é violação do protocolo.
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
## Pré-requisitos
|
|
25
|
+
|
|
26
|
+
\`\`\`
|
|
27
|
+
□ Li INDEX.md e entendi a estrutura do framework
|
|
28
|
+
□ Li 00-general.md (Regras de Ouro)
|
|
29
|
+
□ Li PREFLIGHT.md e completei TODAS as fases
|
|
30
|
+
□ Li QUALITY-GATES.md e sei quais métricas atender
|
|
31
|
+
□ Estou em uma branch feature/ (NUNCA main/develop)
|
|
32
|
+
\`\`\`
|
|
33
|
+
|
|
34
|
+
---
|
|
35
|
+
|
|
36
|
+
## FASE 0: AÇÃO ZERO — Diagnóstico
|
|
37
|
+
|
|
38
|
+
> **ANTES de qualquer coisa, fazer diagnóstico do estado atual.**
|
|
39
|
+
|
|
40
|
+
\`\`\`bash
|
|
41
|
+
# Estado do projeto
|
|
42
|
+
git branch --show-current
|
|
43
|
+
git status
|
|
44
|
+
|
|
45
|
+
# Build e testes ANTES de começar
|
|
46
|
+
${stack.packageManager === 'npm' ? 'npm run build && npm run test' : stack.testFramework === 'pytest' ? 'python -m pytest' : stack.testFramework === 'flutter_test' ? 'flutter test' : 'make test'}
|
|
47
|
+
|
|
48
|
+
# Score atual
|
|
49
|
+
npx @girardelli/architect score .
|
|
50
|
+
|
|
51
|
+
# Ler lições aprendidas (se existir)
|
|
52
|
+
cat LESSONS-LEARNED.md 2>/dev/null || echo "Sem lessons learned"
|
|
53
|
+
|
|
54
|
+
# Regras de negócio (se existir)
|
|
55
|
+
cat BUSINESS-RULES.md 2>/dev/null || echo "Sem business rules"
|
|
56
|
+
\`\`\`
|
|
57
|
+
|
|
58
|
+
\`\`\`
|
|
59
|
+
□ Build passando ✓
|
|
60
|
+
□ Testes passando ✓
|
|
61
|
+
□ Score anotado: ___/100 (não pode regredir)
|
|
62
|
+
□ Lessons learned lidos
|
|
63
|
+
\`\`\`
|
|
64
|
+
|
|
65
|
+
---
|
|
66
|
+
|
|
67
|
+
## FASE 1: Diagnóstico da Feature
|
|
68
|
+
|
|
69
|
+
\`\`\`
|
|
70
|
+
Quero implementar [NOME DA FEATURE].
|
|
71
|
+
|
|
72
|
+
Contexto:
|
|
73
|
+
- Quem usa: [usuário / admin / sistema externo / ...]
|
|
74
|
+
- Tem UI: [sim/não]
|
|
75
|
+
- Tem API: [sim/não]
|
|
76
|
+
- Tem banco: [sim/não]
|
|
77
|
+
- Repo: [${ctx.projectName} / monorepo path / ...]
|
|
78
|
+
|
|
79
|
+
Descrição:
|
|
80
|
+
[2-3 frases do ponto de vista do usuário]
|
|
81
|
+
|
|
82
|
+
Critérios de aceite:
|
|
83
|
+
- CA1: [critério mensurável]
|
|
84
|
+
- CA2: [critério mensurável]
|
|
85
|
+
- CA3: [critério mensurável]
|
|
86
|
+
\`\`\`
|
|
87
|
+
|
|
88
|
+
---
|
|
89
|
+
|
|
90
|
+
## Step 1: MOCKUP ${stack.hasFrontend || stack.hasMobile ? '(OBRIGATÓRIO)' : '(se tem UI)'}
|
|
91
|
+
|
|
92
|
+
> **Gate 1 — Primeiro artefato. Nada começa sem mockup aprovado (quando tem UI).**
|
|
93
|
+
|
|
94
|
+
\`\`\`
|
|
95
|
+
╔══════════════════════════════════════════════════════╗
|
|
96
|
+
║ O MOCKUP DEVE CONTER: ║
|
|
97
|
+
║ ║
|
|
98
|
+
║ ✓ TODAS as telas/páginas envolvidas ║
|
|
99
|
+
║ ✓ Estado: com dados (normal) ║
|
|
100
|
+
║ ✓ Estado: vazio (empty state) ║
|
|
101
|
+
║ ✓ Estado: carregando (loading) ║
|
|
102
|
+
║ ✓ Estado: erro (error state) ║
|
|
103
|
+
║ ✓ TODOS os modais / dialogs ║
|
|
104
|
+
║ ✓ Mensagens de sucesso ║
|
|
105
|
+
║ ✓ Mensagens de erro ║
|
|
106
|
+
║ ✓ Fluxo completo (passo a passo) ║
|
|
107
|
+
║ ✓ Padrão visual do sistema (cores, fontes, layout) ║
|
|
108
|
+
${stack.hasFrontend ? '║ ✓ Responsividade (desktop + mobile se web) ║\n' : ''}${stack.hasMobile ? '║ ✓ Padrão do app (navegação, header, bottom bar) ║\n' : ''}║ ║
|
|
109
|
+
║ Formato: HTML interativo ou imagens anotadas ║
|
|
110
|
+
╚══════════════════════════════════════════════════════╝
|
|
111
|
+
\`\`\`
|
|
112
|
+
|
|
113
|
+
**Apresentar ao humano → Aguardar \`/approved\`**
|
|
114
|
+
|
|
115
|
+
---
|
|
116
|
+
|
|
117
|
+
## Step 2: User Stories
|
|
118
|
+
|
|
119
|
+
> **Gate 2 — Histórias de usuário com critérios de aceite mensuráveis.**
|
|
120
|
+
|
|
121
|
+
Formato:
|
|
122
|
+
|
|
123
|
+
\`\`\`markdown
|
|
124
|
+
## US-001: [Título]
|
|
125
|
+
|
|
126
|
+
**Como** [ator],
|
|
127
|
+
**Quero** [ação],
|
|
128
|
+
**Para** [benefício].
|
|
129
|
+
|
|
130
|
+
### Critérios de Aceite
|
|
131
|
+
- CA1: [critério mensurável]
|
|
132
|
+
- CA2: [critério mensurável]
|
|
133
|
+
|
|
134
|
+
### Regras de Negócio
|
|
135
|
+
- RN1: [regra]
|
|
136
|
+
|
|
137
|
+
### Exceções
|
|
138
|
+
- E1: Se [condição], então [comportamento]
|
|
139
|
+
\`\`\`
|
|
140
|
+
|
|
141
|
+
**Apresentar ao humano → Aguardar \`/approved\`**
|
|
142
|
+
|
|
143
|
+
---
|
|
144
|
+
|
|
145
|
+
## Step 3: Arquitetura (C4)
|
|
146
|
+
|
|
147
|
+
> **Gate 3 — Visão técnica da implementação.**
|
|
148
|
+
|
|
149
|
+
Usar template [C4.md](../templates/C4.md):
|
|
150
|
+
|
|
151
|
+
\`\`\`
|
|
152
|
+
Nível 1 — Contexto: Quem são os atores e sistemas externos?
|
|
153
|
+
Nível 2 — Container: Quais serviços/apps são afetados?
|
|
154
|
+
Nível 3 — Componente: Quais módulos/classes são criados/modificados?
|
|
155
|
+
Nível 4 — Código: Interfaces, DTOs, entidades (se complexo)
|
|
156
|
+
\`\`\`
|
|
157
|
+
|
|
158
|
+
Se a decisão é significativa → criar ADR (template [ADR.md](../templates/ADR.md))
|
|
159
|
+
|
|
160
|
+
**Apresentar ao humano → Aguardar \`/approved\`**
|
|
161
|
+
|
|
162
|
+
---
|
|
163
|
+
|
|
164
|
+
## Step 4: Task Breakdown
|
|
165
|
+
|
|
166
|
+
> **Gate 4 — Lista de tarefas com estimativa.**
|
|
167
|
+
|
|
168
|
+
Formato:
|
|
169
|
+
|
|
170
|
+
\`\`\`markdown
|
|
171
|
+
## TASK-001: [Título]
|
|
172
|
+
- **US:** US-001
|
|
173
|
+
- **Camada:** Backend / Frontend / App / Database
|
|
174
|
+
- **Estimativa:** XS / S / M / L / XL
|
|
175
|
+
- **Agente:** [quem executa]
|
|
176
|
+
- **Deps:** [depende de TASK-XXX, se houver]
|
|
177
|
+
\`\`\`
|
|
178
|
+
|
|
179
|
+
Ordenar por dependência. Backend SEMPRE primeiro.
|
|
180
|
+
|
|
181
|
+
**Apresentar ao humano → Aguardar \`/approved\`**
|
|
182
|
+
|
|
183
|
+
---
|
|
184
|
+
|
|
185
|
+
## Step 5: BDD (Cenários)
|
|
186
|
+
|
|
187
|
+
> **Gate 5 — Cenários de comportamento para cada critério de aceite.**
|
|
188
|
+
|
|
189
|
+
Formato (Gherkin):
|
|
190
|
+
|
|
191
|
+
\`\`\`gherkin
|
|
192
|
+
Feature: [Nome da Feature]
|
|
193
|
+
|
|
194
|
+
Scenario: [cenário happy path]
|
|
195
|
+
Given [contexto]
|
|
196
|
+
When [ação do usuário]
|
|
197
|
+
Then [resultado esperado]
|
|
198
|
+
|
|
199
|
+
Scenario: [cenário de erro]
|
|
200
|
+
Given [contexto]
|
|
201
|
+
When [ação inválida]
|
|
202
|
+
Then [mensagem de erro esperada]
|
|
203
|
+
|
|
204
|
+
Scenario: [cenário edge case]
|
|
205
|
+
Given [contexto específico]
|
|
206
|
+
When [ação]
|
|
207
|
+
Then [comportamento esperado]
|
|
208
|
+
\`\`\`
|
|
209
|
+
|
|
210
|
+
**Apresentar ao humano → Aguardar \`/approved\`**
|
|
211
|
+
|
|
212
|
+
---
|
|
213
|
+
|
|
214
|
+
## Step 6: TDD (Casos de Teste)
|
|
215
|
+
|
|
216
|
+
> **Gate 6 — Casos de teste ANTES do código.**
|
|
217
|
+
|
|
218
|
+
\`\`\`
|
|
219
|
+
Para cada TASK:
|
|
220
|
+
1. Listar os testes que serão escritos
|
|
221
|
+
2. Descrever input → output esperado
|
|
222
|
+
3. Incluir testes de erro/exceção
|
|
223
|
+
4. Incluir testes de boundary
|
|
224
|
+
|
|
225
|
+
Meta: Cobertura ≥ ${config.coverageMinimum}% (INEGOCIÁVEL)
|
|
226
|
+
\`\`\`
|
|
227
|
+
|
|
228
|
+
**Apresentar ao humano → Aguardar \`/approved\`**
|
|
229
|
+
|
|
230
|
+
---
|
|
231
|
+
|
|
232
|
+
## Step 7: Implementação — Backend
|
|
233
|
+
|
|
234
|
+
> **SOMENTE após TODOS os 6 gates aprovados.**
|
|
235
|
+
|
|
236
|
+
\`\`\`
|
|
237
|
+
□ Criar/modificar entities e DTOs
|
|
238
|
+
□ Criar/modificar services (lógica de negócio)
|
|
239
|
+
□ Criar/modificar controllers (endpoints)
|
|
240
|
+
□ Criar migrations (se houver alteração de banco)
|
|
241
|
+
□ Escrever testes (RED → GREEN → REFACTOR)
|
|
242
|
+
□ Rodar: build ✓ + tests ✓ + coverage ≥ ${config.coverageMinimum}% ✓
|
|
243
|
+
\`\`\`
|
|
244
|
+
|
|
245
|
+
---
|
|
246
|
+
|
|
247
|
+
## Step 8: Documento de Integração
|
|
248
|
+
|
|
249
|
+
> **OBRIGATÓRIO se tem frontend/app. Gerado APÓS backend completo.**
|
|
250
|
+
|
|
251
|
+
\`\`\`markdown
|
|
252
|
+
# Documento de Integração: [Feature]
|
|
253
|
+
|
|
254
|
+
## Endpoints
|
|
255
|
+
|
|
256
|
+
### [METHOD] /api/v1/[recurso]
|
|
257
|
+
|
|
258
|
+
**Request:**
|
|
259
|
+
\\\`\\\`\\\`json
|
|
260
|
+
{
|
|
261
|
+
"campo": "tipo — descrição"
|
|
262
|
+
}
|
|
263
|
+
\\\`\\\`\\\`
|
|
264
|
+
|
|
265
|
+
**Response (200):**
|
|
266
|
+
\\\`\\\`\\\`json
|
|
267
|
+
{
|
|
268
|
+
"campo": "tipo — descrição"
|
|
269
|
+
}
|
|
270
|
+
\\\`\\\`\\\`
|
|
271
|
+
|
|
272
|
+
**Erros:**
|
|
273
|
+
| Código | Mensagem | Quando |
|
|
274
|
+
|--------|----------|--------|
|
|
275
|
+
| 400 | Validation error | Input inválido |
|
|
276
|
+
| 404 | Not found | Recurso inexistente |
|
|
277
|
+
|
|
278
|
+
## Regras
|
|
279
|
+
- [regra 1]
|
|
280
|
+
- [regra 2]
|
|
281
|
+
\`\`\`
|
|
282
|
+
|
|
283
|
+
---
|
|
284
|
+
|
|
285
|
+
## Step 9: Implementação — Frontend / App
|
|
286
|
+
|
|
287
|
+
> **Baseado no Documento de Integração.**
|
|
288
|
+
|
|
289
|
+
\`\`\`
|
|
290
|
+
□ Criar/modificar componentes (seguir mockup)
|
|
291
|
+
□ Implementar state management
|
|
292
|
+
□ Integrar com endpoints (conforme doc de integração)
|
|
293
|
+
□ Implementar TODOS os estados (loading, error, empty, data)
|
|
294
|
+
□ Escrever testes (unitários + e2e se aplicável)
|
|
295
|
+
□ Rodar: build ✓ + tests ✓ + coverage ≥ ${config.coverageMinimum}% ✓
|
|
296
|
+
\`\`\`
|
|
297
|
+
|
|
298
|
+
---
|
|
299
|
+
|
|
300
|
+
## Step 10: Verificação Final
|
|
301
|
+
|
|
302
|
+
\`\`\`
|
|
303
|
+
╔════════════════════════════════════════════════╗
|
|
304
|
+
║ CHECKLIST FINAL — TODOS devem ser ✓ ║
|
|
305
|
+
║ ║
|
|
306
|
+
║ □ Build compila sem erros ║
|
|
307
|
+
║ □ TODOS os testes passam ║
|
|
308
|
+
║ □ Cobertura ≥ ${String(config.coverageMinimum).padEnd(3)}% ║
|
|
309
|
+
║ □ Score ≥ ${String(config.scoreThreshold).padEnd(3)}/100 (sem regressão) ║
|
|
310
|
+
║ □ Lint sem errors ║
|
|
311
|
+
║ □ Zero anti-patterns CRITICAL novos ║
|
|
312
|
+
║ □ Todos os critérios de aceite cobertos ║
|
|
313
|
+
║ □ Documentação atualizada ║
|
|
314
|
+
║ □ LESSONS-LEARNED atualizado (se aplicável) ║
|
|
315
|
+
║ □ PR criado com descrição completa ║
|
|
316
|
+
╚════════════════════════════════════════════════╝
|
|
317
|
+
\`\`\`
|
|
318
|
+
|
|
319
|
+
---
|
|
320
|
+
|
|
321
|
+
**Gerado por Architect v3.1 · Score: ${report.score.overall}/100 · ${new Date().toISOString().split('T')[0]}**
|
|
322
|
+
`;
|
|
323
|
+
}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { TemplateContext } from '../../types.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Generates enterprise-grade review.md workflow.
|
|
5
|
+
* Structured code review with checklist per dimension.
|
|
6
|
+
*/
|
|
7
|
+
export function generateReviewWorkflow(ctx: TemplateContext): string {
|
|
8
|
+
const { stack, projectName, config, report } = ctx;
|
|
9
|
+
|
|
10
|
+
return `---
|
|
11
|
+
antigravity:
|
|
12
|
+
trigger: 'on_demand'
|
|
13
|
+
description: 'Workflow de code review estruturado para ${projectName}'
|
|
14
|
+
---
|
|
15
|
+
|
|
16
|
+
# 🔍 Workflow: Code Review
|
|
17
|
+
|
|
18
|
+
> **Code review não é "LGTM".**
|
|
19
|
+
> É uma verificação sistemática em 6 dimensões.
|
|
20
|
+
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
## Dimensão 1: Correção Funcional
|
|
24
|
+
|
|
25
|
+
\`\`\`
|
|
26
|
+
□ O código faz o que a US/task pede?
|
|
27
|
+
□ Todos os critérios de aceite estão cobertos?
|
|
28
|
+
□ Edge cases foram tratados?
|
|
29
|
+
□ Erros são tratados adequadamente?
|
|
30
|
+
□ Regras de negócio estão corretas?
|
|
31
|
+
\`\`\`
|
|
32
|
+
|
|
33
|
+
## Dimensão 2: Qualidade de Código
|
|
34
|
+
|
|
35
|
+
\`\`\`
|
|
36
|
+
□ Código legível sem comentários explicativos?
|
|
37
|
+
□ Naming é descritivo e consistente?
|
|
38
|
+
□ Sem duplicação (DRY)?
|
|
39
|
+
□ Funções/métodos com responsabilidade única?
|
|
40
|
+
□ Sem magic numbers (extrair para constantes)?
|
|
41
|
+
□ Tipos corretos (sem \`any\` / \`type: ignore\` injustificado)?
|
|
42
|
+
□ Sem código morto / comentado?
|
|
43
|
+
\`\`\`
|
|
44
|
+
|
|
45
|
+
## Dimensão 3: Testes
|
|
46
|
+
|
|
47
|
+
\`\`\`
|
|
48
|
+
□ Testes existem para o novo código?
|
|
49
|
+
□ Cobertura ≥ ${config.coverageMinimum}%?
|
|
50
|
+
□ Testes são significativos (não apenas \`expect(true).toBe(true)\`)?
|
|
51
|
+
□ Happy path coberto?
|
|
52
|
+
□ Error path coberto?
|
|
53
|
+
□ Edge cases cobertos?
|
|
54
|
+
□ Nenhum teste com .skip() injustificado?
|
|
55
|
+
\`\`\`
|
|
56
|
+
|
|
57
|
+
## Dimensão 4: Segurança
|
|
58
|
+
|
|
59
|
+
\`\`\`
|
|
60
|
+
□ Sem secrets hardcoded?
|
|
61
|
+
□ Input validado e sanitizado?
|
|
62
|
+
□ SQL injection prevenido (parameterized queries)?
|
|
63
|
+
□ XSS prevenido (output encoding)?
|
|
64
|
+
□ Autenticação/autorização verificada?
|
|
65
|
+
□ Dados sensíveis não logados?
|
|
66
|
+
□ Rate limiting em endpoints novos?
|
|
67
|
+
\`\`\`
|
|
68
|
+
|
|
69
|
+
## Dimensão 5: Performance
|
|
70
|
+
|
|
71
|
+
\`\`\`
|
|
72
|
+
□ Sem N+1 queries?
|
|
73
|
+
□ Queries com índice adequado?
|
|
74
|
+
□ Sem loops desnecessários sobre coleções grandes?
|
|
75
|
+
□ Lazy loading onde aplicável?
|
|
76
|
+
□ Sem memory leaks óbvios (subscriptions, listeners)?
|
|
77
|
+
□ Caching considerado onde faz sentido?
|
|
78
|
+
\`\`\`
|
|
79
|
+
|
|
80
|
+
## Dimensão 6: Arquitetura
|
|
81
|
+
|
|
82
|
+
\`\`\`
|
|
83
|
+
□ Segue os padrões do projeto (rules/)?
|
|
84
|
+
□ Camada correta (controller ≠ service ≠ entity)?
|
|
85
|
+
□ Sem violações de layer (data layer acessando UI)?
|
|
86
|
+
□ Score não regrediu: architect score ≥ ${config.scoreThreshold}/100
|
|
87
|
+
□ Sem novos anti-patterns CRITICAL?
|
|
88
|
+
□ Imports organizados, sem circulares?
|
|
89
|
+
\`\`\`
|
|
90
|
+
|
|
91
|
+
---
|
|
92
|
+
|
|
93
|
+
## Resultado do Review
|
|
94
|
+
|
|
95
|
+
| Resultado | Ação |
|
|
96
|
+
|-----------|------|
|
|
97
|
+
| ✅ Aprovado | Merge permitido |
|
|
98
|
+
| ⚠️ Aprovado com observações | Merge permitido, fix no próximo PR |
|
|
99
|
+
| ❌ Mudanças necessárias | Bloquear merge até resolver |
|
|
100
|
+
| 🔴 Bloqueado | Issue de segurança ou regressão — resolver imediatamente |
|
|
101
|
+
|
|
102
|
+
---
|
|
103
|
+
|
|
104
|
+
**Gerado por Architect v3.1 · Score: ${report.score.overall}/100 · ${new Date().toISOString().split('T')[0]}**
|
|
105
|
+
`;
|
|
106
|
+
}
|