@girardelli/architect-agents 8.1.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 (258) hide show
  1. package/dist/src/core/agent-generator/context-enricher.d.ts +17 -0
  2. package/dist/src/core/agent-generator/context-enricher.js +51 -0
  3. package/dist/src/core/agent-generator/context-enricher.js.map +1 -0
  4. package/dist/src/core/agent-generator/detectors/base-detector.d.ts +8 -0
  5. package/dist/src/core/agent-generator/detectors/base-detector.js +12 -0
  6. package/dist/src/core/agent-generator/detectors/base-detector.js.map +1 -0
  7. package/dist/src/core/agent-generator/detectors/dart-detector.d.ts +5 -0
  8. package/dist/src/core/agent-generator/detectors/dart-detector.js +16 -0
  9. package/dist/src/core/agent-generator/detectors/dart-detector.js.map +1 -0
  10. package/dist/src/core/agent-generator/detectors/framework-registry.d.ts +5 -0
  11. package/dist/src/core/agent-generator/detectors/framework-registry.js +81 -0
  12. package/dist/src/core/agent-generator/detectors/framework-registry.js.map +1 -0
  13. package/dist/src/core/agent-generator/detectors/go-detector.d.ts +5 -0
  14. package/dist/src/core/agent-generator/detectors/go-detector.js +25 -0
  15. package/dist/src/core/agent-generator/detectors/go-detector.js.map +1 -0
  16. package/dist/src/core/agent-generator/detectors/java-detector.d.ts +5 -0
  17. package/dist/src/core/agent-generator/detectors/java-detector.js +44 -0
  18. package/dist/src/core/agent-generator/detectors/java-detector.js.map +1 -0
  19. package/dist/src/core/agent-generator/detectors/node-detector.d.ts +5 -0
  20. package/dist/src/core/agent-generator/detectors/node-detector.js +28 -0
  21. package/dist/src/core/agent-generator/detectors/node-detector.js.map +1 -0
  22. package/dist/src/core/agent-generator/detectors/php-detector.d.ts +5 -0
  23. package/dist/src/core/agent-generator/detectors/php-detector.js +28 -0
  24. package/dist/src/core/agent-generator/detectors/php-detector.js.map +1 -0
  25. package/dist/src/core/agent-generator/detectors/python-detector.d.ts +7 -0
  26. package/dist/src/core/agent-generator/detectors/python-detector.js +116 -0
  27. package/dist/src/core/agent-generator/detectors/python-detector.js.map +1 -0
  28. package/dist/src/core/agent-generator/detectors/ruby-detector.d.ts +5 -0
  29. package/dist/src/core/agent-generator/detectors/ruby-detector.js +23 -0
  30. package/dist/src/core/agent-generator/detectors/ruby-detector.js.map +1 -0
  31. package/dist/src/core/agent-generator/detectors/rust-detector.d.ts +5 -0
  32. package/dist/src/core/agent-generator/detectors/rust-detector.js +18 -0
  33. package/dist/src/core/agent-generator/detectors/rust-detector.js.map +1 -0
  34. package/dist/src/core/agent-generator/detectors/structure-detector.d.ts +4 -0
  35. package/dist/src/core/agent-generator/detectors/structure-detector.js +35 -0
  36. package/dist/src/core/agent-generator/detectors/structure-detector.js.map +1 -0
  37. package/dist/src/core/agent-generator/detectors/toolchain-detector.d.ts +5 -0
  38. package/dist/src/core/agent-generator/detectors/toolchain-detector.js +164 -0
  39. package/dist/src/core/agent-generator/detectors/toolchain-detector.js.map +1 -0
  40. package/dist/src/core/agent-generator/domain-inferrer.d.ts +51 -0
  41. package/dist/src/core/agent-generator/domain-inferrer.js +585 -0
  42. package/dist/src/core/agent-generator/domain-inferrer.js.map +1 -0
  43. package/dist/src/core/agent-generator/engines/audit-engine.d.ts +8 -0
  44. package/dist/src/core/agent-generator/engines/audit-engine.js +84 -0
  45. package/dist/src/core/agent-generator/engines/audit-engine.js.map +1 -0
  46. package/dist/src/core/agent-generator/engines/context-builder.d.ts +12 -0
  47. package/dist/src/core/agent-generator/engines/context-builder.js +84 -0
  48. package/dist/src/core/agent-generator/engines/context-builder.js.map +1 -0
  49. package/dist/src/core/agent-generator/engines/generation-engine.d.ts +7 -0
  50. package/dist/src/core/agent-generator/engines/generation-engine.js +160 -0
  51. package/dist/src/core/agent-generator/engines/generation-engine.js.map +1 -0
  52. package/dist/src/core/agent-generator/engines/generation-engine_deps.d.ts +21 -0
  53. package/dist/src/core/agent-generator/engines/generation-engine_deps.js +17 -0
  54. package/dist/src/core/agent-generator/engines/generation-engine_deps.js.map +1 -0
  55. package/dist/src/core/agent-generator/engines/suggestion-engine.d.ts +13 -0
  56. package/dist/src/core/agent-generator/engines/suggestion-engine.js +171 -0
  57. package/dist/src/core/agent-generator/engines/suggestion-engine.js.map +1 -0
  58. package/dist/src/core/agent-generator/engines/suggestion-engine_deps.d.ts +8 -0
  59. package/dist/src/core/agent-generator/engines/suggestion-engine_deps.js +5 -0
  60. package/dist/src/core/agent-generator/engines/suggestion-engine_deps.js.map +1 -0
  61. package/dist/src/core/agent-generator/enrichers/analysis-helpers.d.ts +9 -0
  62. package/dist/src/core/agent-generator/enrichers/analysis-helpers.js +51 -0
  63. package/dist/src/core/agent-generator/enrichers/analysis-helpers.js.map +1 -0
  64. package/dist/src/core/agent-generator/enrichers/description-generator.d.ts +4 -0
  65. package/dist/src/core/agent-generator/enrichers/description-generator.js +82 -0
  66. package/dist/src/core/agent-generator/enrichers/description-generator.js.map +1 -0
  67. package/dist/src/core/agent-generator/enrichers/endpoint-extractor.d.ts +7 -0
  68. package/dist/src/core/agent-generator/enrichers/endpoint-extractor.js +90 -0
  69. package/dist/src/core/agent-generator/enrichers/endpoint-extractor.js.map +1 -0
  70. package/dist/src/core/agent-generator/enrichers/layer-classifier.d.ts +12 -0
  71. package/dist/src/core/agent-generator/enrichers/layer-classifier.js +152 -0
  72. package/dist/src/core/agent-generator/enrichers/layer-classifier.js.map +1 -0
  73. package/dist/src/core/agent-generator/enrichers/module-extractor.d.ts +10 -0
  74. package/dist/src/core/agent-generator/enrichers/module-extractor.js +173 -0
  75. package/dist/src/core/agent-generator/enrichers/module-extractor.js.map +1 -0
  76. package/dist/src/core/agent-generator/framework-detector.d.ts +17 -0
  77. package/dist/src/core/agent-generator/framework-detector.js +56 -0
  78. package/dist/src/core/agent-generator/framework-detector.js.map +1 -0
  79. package/dist/src/core/agent-generator/index.d.ts +25 -0
  80. package/dist/src/core/agent-generator/index.js +37 -0
  81. package/dist/src/core/agent-generator/index.js.map +1 -0
  82. package/dist/src/core/agent-generator/stack-detector.d.ts +13 -0
  83. package/dist/src/core/agent-generator/stack-detector.js +124 -0
  84. package/dist/src/core/agent-generator/stack-detector.js.map +1 -0
  85. package/dist/src/core/agent-generator/templates/core/agents.d.ts +9 -0
  86. package/dist/src/core/agent-generator/templates/core/agents.js +1127 -0
  87. package/dist/src/core/agent-generator/templates/core/agents.js.map +1 -0
  88. package/dist/src/core/agent-generator/templates/core/architecture-rules.d.ts +6 -0
  89. package/dist/src/core/agent-generator/templates/core/architecture-rules.js +275 -0
  90. package/dist/src/core/agent-generator/templates/core/architecture-rules.js.map +1 -0
  91. package/dist/src/core/agent-generator/templates/core/general-rules.d.ts +7 -0
  92. package/dist/src/core/agent-generator/templates/core/general-rules.js +301 -0
  93. package/dist/src/core/agent-generator/templates/core/general-rules.js.map +1 -0
  94. package/dist/src/core/agent-generator/templates/core/hooks-generator.d.ts +20 -0
  95. package/dist/src/core/agent-generator/templates/core/hooks-generator.js +235 -0
  96. package/dist/src/core/agent-generator/templates/core/hooks-generator.js.map +1 -0
  97. package/dist/src/core/agent-generator/templates/core/index-md.d.ts +6 -0
  98. package/dist/src/core/agent-generator/templates/core/index-md.js +247 -0
  99. package/dist/src/core/agent-generator/templates/core/index-md.js.map +1 -0
  100. package/dist/src/core/agent-generator/templates/core/orchestrator.d.ts +7 -0
  101. package/dist/src/core/agent-generator/templates/core/orchestrator.js +423 -0
  102. package/dist/src/core/agent-generator/templates/core/orchestrator.js.map +1 -0
  103. package/dist/src/core/agent-generator/templates/core/preflight.d.ts +7 -0
  104. package/dist/src/core/agent-generator/templates/core/preflight.js +213 -0
  105. package/dist/src/core/agent-generator/templates/core/preflight.js.map +1 -0
  106. package/dist/src/core/agent-generator/templates/core/quality-gates.d.ts +10 -0
  107. package/dist/src/core/agent-generator/templates/core/quality-gates.js +255 -0
  108. package/dist/src/core/agent-generator/templates/core/quality-gates.js.map +1 -0
  109. package/dist/src/core/agent-generator/templates/core/security-rules.d.ts +6 -0
  110. package/dist/src/core/agent-generator/templates/core/security-rules.js +529 -0
  111. package/dist/src/core/agent-generator/templates/core/security-rules.js.map +1 -0
  112. package/dist/src/core/agent-generator/templates/core/skills-generator.d.ts +18 -0
  113. package/dist/src/core/agent-generator/templates/core/skills-generator.js +547 -0
  114. package/dist/src/core/agent-generator/templates/core/skills-generator.js.map +1 -0
  115. package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.d.ts +6 -0
  116. package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.js +238 -0
  117. package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.js.map +1 -0
  118. package/dist/src/core/agent-generator/templates/core/workflow-new-feature.d.ts +7 -0
  119. package/dist/src/core/agent-generator/templates/core/workflow-new-feature.js +321 -0
  120. package/dist/src/core/agent-generator/templates/core/workflow-new-feature.js.map +1 -0
  121. package/dist/src/core/agent-generator/templates/core/workflow-review.d.ts +6 -0
  122. package/dist/src/core/agent-generator/templates/core/workflow-review.js +105 -0
  123. package/dist/src/core/agent-generator/templates/core/workflow-review.js.map +1 -0
  124. package/dist/src/core/agent-generator/templates/domain/index.d.ts +21 -0
  125. package/dist/src/core/agent-generator/templates/domain/index.js +1179 -0
  126. package/dist/src/core/agent-generator/templates/domain/index.js.map +1 -0
  127. package/dist/src/core/agent-generator/templates/helpers/base-helpers.d.ts +10 -0
  128. package/dist/src/core/agent-generator/templates/helpers/base-helpers.js +20 -0
  129. package/dist/src/core/agent-generator/templates/helpers/base-helpers.js.map +1 -0
  130. package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts +2 -0
  131. package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.js +77 -0
  132. package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.js.map +1 -0
  133. package/dist/src/core/agent-generator/templates/helpers/security-helpers.d.ts +2 -0
  134. package/dist/src/core/agent-generator/templates/helpers/security-helpers.js +182 -0
  135. package/dist/src/core/agent-generator/templates/helpers/security-helpers.js.map +1 -0
  136. package/dist/src/core/agent-generator/templates/helpers/stack-helpers.d.ts +4 -0
  137. package/dist/src/core/agent-generator/templates/helpers/stack-helpers.js +69 -0
  138. package/dist/src/core/agent-generator/templates/helpers/stack-helpers.js.map +1 -0
  139. package/dist/src/core/agent-generator/templates/helpers/structure-helpers.d.ts +2 -0
  140. package/dist/src/core/agent-generator/templates/helpers/structure-helpers.js +275 -0
  141. package/dist/src/core/agent-generator/templates/helpers/structure-helpers.js.map +1 -0
  142. package/dist/src/core/agent-generator/templates/helpers/summary-helpers.d.ts +6 -0
  143. package/dist/src/core/agent-generator/templates/helpers/summary-helpers.js +56 -0
  144. package/dist/src/core/agent-generator/templates/helpers/summary-helpers.js.map +1 -0
  145. package/dist/src/core/agent-generator/templates/stack/index.d.ts +7 -0
  146. package/dist/src/core/agent-generator/templates/stack/index.js +695 -0
  147. package/dist/src/core/agent-generator/templates/stack/index.js.map +1 -0
  148. package/dist/src/core/agent-generator/templates/template-helpers.d.ts +11 -0
  149. package/dist/src/core/agent-generator/templates/template-helpers.js +12 -0
  150. package/dist/src/core/agent-generator/templates/template-helpers.js.map +1 -0
  151. package/dist/src/core/agent-generator/types/agent.d.ts +39 -0
  152. package/dist/src/core/agent-generator/types/agent.js +27 -0
  153. package/dist/src/core/agent-generator/types/agent.js.map +1 -0
  154. package/dist/src/core/agent-generator/types/domain.d.ts +58 -0
  155. package/dist/src/core/agent-generator/types/domain.js +2 -0
  156. package/dist/src/core/agent-generator/types/domain.js.map +1 -0
  157. package/dist/src/core/agent-generator/types/stack.d.ts +36 -0
  158. package/dist/src/core/agent-generator/types/stack.js +2 -0
  159. package/dist/src/core/agent-generator/types/stack.js.map +1 -0
  160. package/dist/src/core/agent-generator/types/template.d.ts +29 -0
  161. package/dist/src/core/agent-generator/types/template.js +2 -0
  162. package/dist/src/core/agent-generator/types/template.js.map +1 -0
  163. package/dist/src/core/agent-runtime/ai-provider.d.ts +33 -0
  164. package/dist/src/core/agent-runtime/ai-provider.js +146 -0
  165. package/dist/src/core/agent-runtime/ai-provider.js.map +1 -0
  166. package/dist/src/core/agent-runtime/executor.d.ts +13 -0
  167. package/dist/src/core/agent-runtime/executor.js +138 -0
  168. package/dist/src/core/agent-runtime/executor.js.map +1 -0
  169. package/dist/src/core/agent-runtime/human-gate.d.ts +16 -0
  170. package/dist/src/core/agent-runtime/human-gate.js +70 -0
  171. package/dist/src/core/agent-runtime/human-gate.js.map +1 -0
  172. package/dist/tests/agent-generator.test.d.ts +1 -0
  173. package/dist/tests/agent-generator.test.js +349 -0
  174. package/dist/tests/agent-generator.test.js.map +1 -0
  175. package/dist/tests/agent-runtime.test.d.ts +1 -0
  176. package/dist/tests/agent-runtime.test.js +107 -0
  177. package/dist/tests/agent-runtime.test.js.map +1 -0
  178. package/dist/tests/context-enricher.test.d.ts +1 -0
  179. package/dist/tests/context-enricher.test.js +875 -0
  180. package/dist/tests/context-enricher.test.js.map +1 -0
  181. package/dist/tests/framework-detector.test.d.ts +1 -0
  182. package/dist/tests/framework-detector.test.js +882 -0
  183. package/dist/tests/framework-detector.test.js.map +1 -0
  184. package/dist/tests/stack-detector.test.d.ts +1 -0
  185. package/dist/tests/stack-detector.test.js +183 -0
  186. package/dist/tests/stack-detector.test.js.map +1 -0
  187. package/dist/tests/template-generation.test.d.ts +1 -0
  188. package/dist/tests/template-generation.test.js +571 -0
  189. package/dist/tests/template-generation.test.js.map +1 -0
  190. package/dist/tests/template-helpers.test.d.ts +1 -0
  191. package/dist/tests/template-helpers.test.js +967 -0
  192. package/dist/tests/template-helpers.test.js.map +1 -0
  193. package/package.json +24 -0
  194. package/src/core/agent-generator/context-enricher.ts +67 -0
  195. package/src/core/agent-generator/detectors/base-detector.ts +18 -0
  196. package/src/core/agent-generator/detectors/dart-detector.ts +17 -0
  197. package/src/core/agent-generator/detectors/framework-registry.ts +82 -0
  198. package/src/core/agent-generator/detectors/go-detector.ts +26 -0
  199. package/src/core/agent-generator/detectors/java-detector.ts +46 -0
  200. package/src/core/agent-generator/detectors/node-detector.ts +28 -0
  201. package/src/core/agent-generator/detectors/php-detector.ts +28 -0
  202. package/src/core/agent-generator/detectors/python-detector.ts +125 -0
  203. package/src/core/agent-generator/detectors/ruby-detector.ts +24 -0
  204. package/src/core/agent-generator/detectors/rust-detector.ts +19 -0
  205. package/src/core/agent-generator/detectors/structure-detector.ts +38 -0
  206. package/src/core/agent-generator/detectors/toolchain-detector.ts +181 -0
  207. package/src/core/agent-generator/domain-inferrer.ts +630 -0
  208. package/src/core/agent-generator/engines/audit-engine.ts +98 -0
  209. package/src/core/agent-generator/engines/context-builder.ts +96 -0
  210. package/src/core/agent-generator/engines/generation-engine.ts +184 -0
  211. package/src/core/agent-generator/engines/generation-engine_deps.ts +21 -0
  212. package/src/core/agent-generator/engines/suggestion-engine.ts +202 -0
  213. package/src/core/agent-generator/engines/suggestion-engine_deps.ts +8 -0
  214. package/src/core/agent-generator/enrichers/analysis-helpers.ts +58 -0
  215. package/src/core/agent-generator/enrichers/description-generator.ts +91 -0
  216. package/src/core/agent-generator/enrichers/endpoint-extractor.ts +114 -0
  217. package/src/core/agent-generator/enrichers/layer-classifier.ts +156 -0
  218. package/src/core/agent-generator/enrichers/module-extractor.ts +203 -0
  219. package/src/core/agent-generator/framework-detector.ts +66 -0
  220. package/src/core/agent-generator/index.ts +55 -0
  221. package/src/core/agent-generator/stack-detector.ts +115 -0
  222. package/src/core/agent-generator/templates/core/agents.ts +1168 -0
  223. package/src/core/agent-generator/templates/core/architecture-rules.ts +288 -0
  224. package/src/core/agent-generator/templates/core/general-rules.ts +306 -0
  225. package/src/core/agent-generator/templates/core/hooks-generator.ts +244 -0
  226. package/src/core/agent-generator/templates/core/index-md.ts +261 -0
  227. package/src/core/agent-generator/templates/core/orchestrator.ts +462 -0
  228. package/src/core/agent-generator/templates/core/preflight.ts +216 -0
  229. package/src/core/agent-generator/templates/core/quality-gates.ts +257 -0
  230. package/src/core/agent-generator/templates/core/security-rules.ts +544 -0
  231. package/src/core/agent-generator/templates/core/skills-generator.ts +586 -0
  232. package/src/core/agent-generator/templates/core/workflow-fix-bug.ts +240 -0
  233. package/src/core/agent-generator/templates/core/workflow-new-feature.ts +323 -0
  234. package/src/core/agent-generator/templates/core/workflow-review.ts +107 -0
  235. package/src/core/agent-generator/templates/domain/index.ts +1204 -0
  236. package/src/core/agent-generator/templates/helpers/base-helpers.ts +33 -0
  237. package/src/core/agent-generator/templates/helpers/cross-ref-helpers.ts +79 -0
  238. package/src/core/agent-generator/templates/helpers/security-helpers.ts +198 -0
  239. package/src/core/agent-generator/templates/helpers/stack-helpers.ts +80 -0
  240. package/src/core/agent-generator/templates/helpers/structure-helpers.ts +293 -0
  241. package/src/core/agent-generator/templates/helpers/summary-helpers.ts +67 -0
  242. package/src/core/agent-generator/templates/stack/index.ts +705 -0
  243. package/src/core/agent-generator/templates/template-helpers.ts +12 -0
  244. package/src/core/agent-generator/types/agent.ts +65 -0
  245. package/src/core/agent-generator/types/domain.ts +63 -0
  246. package/src/core/agent-generator/types/stack.ts +38 -0
  247. package/src/core/agent-generator/types/template.ts +31 -0
  248. package/src/core/agent-runtime/ai-provider.ts +178 -0
  249. package/src/core/agent-runtime/executor.ts +148 -0
  250. package/src/core/agent-runtime/human-gate.ts +69 -0
  251. package/tests/agent-generator.test.ts +428 -0
  252. package/tests/agent-runtime.test.ts +125 -0
  253. package/tests/context-enricher.test.ts +972 -0
  254. package/tests/framework-detector.test.ts +1172 -0
  255. package/tests/stack-detector.test.ts +241 -0
  256. package/tests/template-generation.test.ts +709 -0
  257. package/tests/template-helpers.test.ts +1130 -0
  258. package/tsconfig.json +14 -0
@@ -0,0 +1,238 @@
1
+ /**
2
+ * Generates enterprise-grade fix-bug.md workflow.
3
+ * 10 steps: diagnosis → localization → root cause → RED test → fix → regression → docs.
4
+ */
5
+ export function generateFixBugWorkflow(ctx) {
6
+ // @ts-ignore - Audit cleanup unused variable
7
+ const { stack, projectName, config, report } = ctx;
8
+ return `---
9
+ antigravity:
10
+ trigger: 'on_demand'
11
+ description: 'Workflow completo para correção de bug em ${projectName}'
12
+ ---
13
+
14
+ # 🐛 Workflow: Fix Bug
15
+
16
+ > **Bugs não se corrigem por tentativa e erro.**
17
+ > Diagnóstico rigoroso → reprodução → root cause → teste RED → fix → regressão.
18
+
19
+ ---
20
+
21
+ ## Pré-requisitos
22
+
23
+ \`\`\`
24
+ □ Li INDEX.md e PREFLIGHT.md
25
+ □ Li LESSONS-LEARNED.md (se existir) — talvez esse bug já aconteceu
26
+ □ Li ERROR-PATTERNS.md (se existir) — talvez é um padrão conhecido
27
+ □ Estou em uma branch fix/ ou hotfix/ (NUNCA main/develop)
28
+ □ Build e testes passando ANTES da minha alteração
29
+ \`\`\`
30
+
31
+ ---
32
+
33
+ ## Step 1: Diagnóstico Inicial
34
+
35
+ \`\`\`
36
+ Bug: [descrição clara do problema]
37
+ Reportado por: [quem reportou]
38
+ Ambiente: [produção / staging / dev]
39
+ Severidade: [CRITICAL / HIGH / MEDIUM / LOW]
40
+
41
+ Comportamento atual: [o que acontece]
42
+ Comportamento esperado: [o que deveria acontecer]
43
+ Como reproduzir:
44
+ 1. [passo 1]
45
+ 2. [passo 2]
46
+ 3. [resultado errado]
47
+ \`\`\`
48
+
49
+ ---
50
+
51
+ ## Step 2: Leitura de Contexto
52
+
53
+ \`\`\`bash
54
+ # Verificar LESSONS-LEARNED para bugs similares
55
+ grep -i "[termo do bug]" LESSONS-LEARNED.md 2>/dev/null
56
+
57
+ # Verificar ERROR-PATTERNS
58
+ grep -i "[termo do bug]" ERROR-PATTERNS.md 2>/dev/null
59
+
60
+ # Verificar regras de negócio relevantes
61
+ grep -i "[domínio do bug]" BUSINESS-RULES.md 2>/dev/null
62
+
63
+ # Histórico de commits na área afetada
64
+ git log --oneline -20 -- [arquivo ou diretório afetado]
65
+ \`\`\`
66
+
67
+ ---
68
+
69
+ ## Step 3: Localização do Problema
70
+
71
+ \`\`\`bash
72
+ # Buscar no código
73
+ grep -rn "[termo do erro]" --include="*.${stack.primary === 'Python' ? 'py' : stack.primary === 'Dart' ? 'dart' : 'ts'}" src/
74
+
75
+ # Verificar logs (se disponível)
76
+ # Verificar stack trace
77
+
78
+ # Mapear o fluxo de dados:
79
+ # Input → [onde entra] → [como transforma] → [onde sai] → Output
80
+ \`\`\`
81
+
82
+ \`\`\`
83
+ Arquivo(s) suspeito(s): _______________
84
+ Função/método suspeito: _______________
85
+ Linha(s) suspeita(s): _______________
86
+ \`\`\`
87
+
88
+ ---
89
+
90
+ ## Step 4: Root Cause — Identificação da Causa Raiz
91
+
92
+ \`\`\`
93
+ ╔══════════════════════════════════════════════╗
94
+ ║ NUNCA corrigir o SINTOMA. ║
95
+ ║ SEMPRE encontrar a CAUSA RAIZ. ║
96
+ ║ ║
97
+ ║ Técnica dos 5 Porquês: ║
98
+ ║ 1. Por que o bug acontece? → porque... ║
99
+ ║ 2. Por que isso? → porque... ║
100
+ ║ 3. Por que isso? → porque... ║
101
+ ║ 4. Por que isso? → porque... ║
102
+ ║ 5. Por que isso? → CAUSA RAIZ ║
103
+ ╚══════════════════════════════════════════════╝
104
+ \`\`\`
105
+
106
+ \`\`\`
107
+ Causa raiz: _______________
108
+ Confiança: [ ] Alta (reproduzi) [ ] Média (hipótese forte) [ ] Baixa (preciso investigar mais)
109
+ \`\`\`
110
+
111
+ > **Se confiança é Baixa → PARAR e investigar mais. Não chutar.**
112
+
113
+ ---
114
+
115
+ ## Step 5: Verificar Testes Existentes
116
+
117
+ \`\`\`bash
118
+ # Testes que cobrem a área afetada
119
+ grep -rn "[nome da função/classe]" --include="*.test.*" --include="*.spec.*" tests/ src/
120
+
121
+ # Rodar testes existentes
122
+ ${stack.testFramework === 'pytest' ? 'pytest -v -k "[nome do módulo]"' : stack.testFramework === 'flutter_test' ? 'flutter test test/[modulo]_test.dart' : 'npx jest --testPathPattern="[modulo]"'}
123
+ \`\`\`
124
+
125
+ \`\`\`
126
+ □ Existem testes para a área afetada? [sim/não]
127
+ □ Os testes passam? [sim/não]
128
+ □ Os testes cobrem o cenário do bug? [sim/não — se não, criar no Step 6]
129
+ \`\`\`
130
+
131
+ ---
132
+
133
+ ## Step 6: Criar Teste RED
134
+
135
+ > **PRIMEIRO criar um teste que FALHA reproduzindo o bug.**
136
+ > Só depois corrigir o código.
137
+
138
+ \`\`\`
139
+ Teste: [nome descritivo do teste]
140
+ Input: [dados que reproduzem o bug]
141
+ Expected: [resultado correto]
142
+ Actual: [resultado errado — o teste deve FALHAR]
143
+ \`\`\`
144
+
145
+ \`\`\`bash
146
+ # Rodar e confirmar que FALHA (RED)
147
+ ${stack.testFramework === 'pytest' ? 'pytest -v -k "[nome do teste]"' : 'npx jest --testNamePattern="[nome do teste]"'}
148
+ # DEVE FALHAR ❌
149
+ \`\`\`
150
+
151
+ ---
152
+
153
+ ## Step 7: Correção Mínima
154
+
155
+ \`\`\`
156
+ ╔══════════════════════════════════════════════╗
157
+ ║ REGRA: Correção MÍNIMA. ║
158
+ ║ ║
159
+ ║ ✓ Corrigir APENAS a causa raiz ║
160
+ ║ ✓ Menor quantidade de linhas possível ║
161
+ ║ ✗ NÃO refatorar código adjacente ║
162
+ ║ ✗ NÃO "aproveitar" para melhorar outra coisa║
163
+ ║ ✗ NÃO adicionar features junto com o fix ║
164
+ ╚══════════════════════════════════════════════╝
165
+ \`\`\`
166
+
167
+ Após corrigir:
168
+ \`\`\`bash
169
+ # Rodar o teste do Step 6 — agora deve PASSAR (GREEN)
170
+ ${stack.testFramework === 'pytest' ? 'pytest -v -k "[nome do teste]"' : 'npx jest --testNamePattern="[nome do teste]"'}
171
+ # DEVE PASSAR ✅
172
+ \`\`\`
173
+
174
+ ---
175
+
176
+ ## Step 8: Teste de Regressão
177
+
178
+ \`\`\`bash
179
+ # Rodar TODOS os testes (não só o novo)
180
+ ${stack.testFramework === 'pytest' ? 'pytest' : stack.testFramework === 'flutter_test' ? 'flutter test' : 'npm run test'}
181
+
182
+ # Build completo
183
+ ${stack.packageManager === 'npm' ? 'npm run build' : 'make build'}
184
+
185
+ # Score
186
+ npx @girardelli/architect score .
187
+ \`\`\`
188
+
189
+ \`\`\`
190
+ □ Teste do bug passa (GREEN) ✓
191
+ □ TODOS os outros testes passam ✓
192
+ □ Build compila ✓
193
+ □ Score não regrediu ✓
194
+ \`\`\`
195
+
196
+ ---
197
+
198
+ ## Step 9: Verificação de Fluxos Existentes
199
+
200
+ \`\`\`
201
+ □ Verifiquei que features dependentes não foram afetadas
202
+ □ Verifiquei edge cases relacionados
203
+ □ Se o bug era em API → verifiquei clientes da API
204
+ □ Se o bug era em banco → verifiquei migrations e seeds
205
+ \`\`\`
206
+
207
+ ---
208
+
209
+ ## Step 10: Documentação
210
+
211
+ \`\`\`
212
+ □ Atualizar LESSONS-LEARNED.md:
213
+ - O que aconteceu
214
+ - Causa raiz
215
+ - Como foi corrigido
216
+ - Como prevenir no futuro
217
+
218
+ □ Atualizar ERROR-PATTERNS.md (se é um padrão novo):
219
+ - Padrão do erro
220
+ - Sintomas
221
+ - Solução
222
+
223
+ □ Commit com mensagem semântica:
224
+ fix: [descrição clara do que foi corrigido]
225
+
226
+ □ PR criado com:
227
+ - Descrição do bug
228
+ - Causa raiz
229
+ - Solução aplicada
230
+ - Testes adicionados
231
+ \`\`\`
232
+
233
+ ---
234
+
235
+ **Gerado por Architect v8.1 · Score: ${report.score.overall}/100 · ${new Date().toISOString().split('T')[0]}**
236
+ `;
237
+ }
238
+ //# sourceMappingURL=workflow-fix-bug.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-fix-bug.js","sourceRoot":"","sources":["../../../../../../src/core/agent-generator/templates/core/workflow-fix-bug.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CAAC,GAAoB;IACvD,6CAA6C;IAC/C,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC;IAEnD,OAAO;;;4DAGmD,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CA8D7B,KAAK,CAAC,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAiDpH,KAAK,CAAC,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,KAAK,cAAc,CAAC,CAAC,CAAC,sCAAsC,CAAC,CAAC,CAAC,uCAAuC;;;;;;;;;;;;;;;;;;;;;;;;;EAyBhM,KAAK,CAAC,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC,8CAA8C;;;;;;;;;;;;;;;;;;;;;;;EAuBpH,KAAK,CAAC,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC,8CAA8C;;;;;;;;;;EAUpH,KAAK,CAAC,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,KAAK,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc;;;EAGtH,KAAK,CAAC,cAAc,KAAK,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAoD1B,MAAM,CAAC,KAAK,CAAC,OAAO,UAAU,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1G,CAAC;AACF,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { TemplateContext } from '@girardelli/architect-agents/src/core/agent-generator/types/template.js';
2
+ /**
3
+ * Generates enterprise-grade new-feature.md workflow.
4
+ * 10 steps with approval gates, mockup-first, backend-first order,
5
+ * integration doc, coverage gate, user story/task templates.
6
+ */
7
+ export declare function generateNewFeatureWorkflow(ctx: TemplateContext): string;
@@ -0,0 +1,321 @@
1
+ /**
2
+ * Generates enterprise-grade new-feature.md workflow.
3
+ * 10 steps with approval gates, mockup-first, backend-first order,
4
+ * integration doc, coverage gate, user story/task templates.
5
+ */
6
+ export function generateNewFeatureWorkflow(ctx) {
7
+ const { stack, projectName, config, report } = ctx;
8
+ return `---
9
+ antigravity:
10
+ trigger: 'on_demand'
11
+ description: 'Workflow completo para nova feature em ${projectName}'
12
+ ---
13
+
14
+ # 🚀 Workflow: Nova Feature
15
+
16
+ > **Este workflow é OBRIGATÓRIO para qualquer nova funcionalidade.**
17
+ > Cada step tem um gate de aprovação. Pular steps é violação do protocolo.
18
+
19
+ ---
20
+
21
+ ## Pré-requisitos
22
+
23
+ \`\`\`
24
+ □ Li INDEX.md e entendi a estrutura do framework
25
+ □ Li 00-general.md (Regras de Ouro)
26
+ □ Li PREFLIGHT.md e completei TODAS as fases
27
+ □ Li QUALITY-GATES.md e sei quais métricas atender
28
+ □ Estou em uma branch feature/ (NUNCA main/develop)
29
+ \`\`\`
30
+
31
+ ---
32
+
33
+ ## FASE 0: AÇÃO ZERO — Diagnóstico
34
+
35
+ > **ANTES de qualquer coisa, fazer diagnóstico do estado atual.**
36
+
37
+ \`\`\`bash
38
+ # Estado do projeto
39
+ git branch --show-current
40
+ git status
41
+
42
+ # Build e testes ANTES de começar
43
+ ${stack.packageManager === 'npm' ? 'npm run build && npm run test' : stack.testFramework === 'pytest' ? 'python -m pytest' : stack.testFramework === 'flutter_test' ? 'flutter test' : 'make test'}
44
+
45
+ # Score atual
46
+ npx @girardelli/architect score .
47
+
48
+ # Ler lições aprendidas (se existir)
49
+ cat LESSONS-LEARNED.md 2>/dev/null || echo "Sem lessons learned"
50
+
51
+ # Regras de negócio (se existir)
52
+ cat BUSINESS-RULES.md 2>/dev/null || echo "Sem business rules"
53
+ \`\`\`
54
+
55
+ \`\`\`
56
+ □ Build passando ✓
57
+ □ Testes passando ✓
58
+ □ Score anotado: ___/100 (não pode regredir)
59
+ □ Lessons learned lidos
60
+ \`\`\`
61
+
62
+ ---
63
+
64
+ ## FASE 1: Diagnóstico da Feature
65
+
66
+ \`\`\`
67
+ Quero implementar [NOME DA FEATURE].
68
+
69
+ Contexto:
70
+ - Quem usa: [usuário / admin / sistema externo / ...]
71
+ - Tem UI: [sim/não]
72
+ - Tem API: [sim/não]
73
+ - Tem banco: [sim/não]
74
+ - Repo: [${ctx.projectName} / monorepo path / ...]
75
+
76
+ Descrição:
77
+ [2-3 frases do ponto de vista do usuário]
78
+
79
+ Critérios de aceite:
80
+ - CA1: [critério mensurável]
81
+ - CA2: [critério mensurável]
82
+ - CA3: [critério mensurável]
83
+ \`\`\`
84
+
85
+ ---
86
+
87
+ ## Step 1: MOCKUP ${stack.hasFrontend || stack.hasMobile ? '(OBRIGATÓRIO)' : '(se tem UI)'}
88
+
89
+ > **Gate 1 — Primeiro artefato. Nada começa sem mockup aprovado (quando tem UI).**
90
+
91
+ \`\`\`
92
+ ╔══════════════════════════════════════════════════════╗
93
+ ║ O MOCKUP DEVE CONTER: ║
94
+ ║ ║
95
+ ║ ✓ TODAS as telas/páginas envolvidas ║
96
+ ║ ✓ Estado: com dados (normal) ║
97
+ ║ ✓ Estado: vazio (empty state) ║
98
+ ║ ✓ Estado: carregando (loading) ║
99
+ ║ ✓ Estado: erro (error state) ║
100
+ ║ ✓ TODOS os modais / dialogs ║
101
+ ║ ✓ Mensagens de sucesso ║
102
+ ║ ✓ Mensagens de erro ║
103
+ ║ ✓ Fluxo completo (passo a passo) ║
104
+ ║ ✓ Padrão visual do sistema (cores, fontes, layout) ║
105
+ ${stack.hasFrontend ? '║ ✓ Responsividade (desktop + mobile se web) ║\n' : ''}${stack.hasMobile ? '║ ✓ Padrão do app (navegação, header, bottom bar) ║\n' : ''}║ ║
106
+ ║ Formato: HTML interativo ou imagens anotadas ║
107
+ ╚══════════════════════════════════════════════════════╝
108
+ \`\`\`
109
+
110
+ **Apresentar ao humano → Aguardar \`/approved\`**
111
+
112
+ ---
113
+
114
+ ## Step 2: User Stories
115
+
116
+ > **Gate 2 — Histórias de usuário com critérios de aceite mensuráveis.**
117
+
118
+ Formato:
119
+
120
+ \`\`\`markdown
121
+ ## US-001: [Título]
122
+
123
+ **Como** [ator],
124
+ **Quero** [ação],
125
+ **Para** [benefício].
126
+
127
+ ### Critérios de Aceite
128
+ - CA1: [critério mensurável]
129
+ - CA2: [critério mensurável]
130
+
131
+ ### Regras de Negócio
132
+ - RN1: [regra]
133
+
134
+ ### Exceções
135
+ - E1: Se [condição], então [comportamento]
136
+ \`\`\`
137
+
138
+ **Apresentar ao humano → Aguardar \`/approved\`**
139
+
140
+ ---
141
+
142
+ ## Step 3: Arquitetura (C4)
143
+
144
+ > **Gate 3 — Visão técnica da implementação.**
145
+
146
+ Usar template [C4.md](../templates/C4.md):
147
+
148
+ \`\`\`
149
+ Nível 1 — Contexto: Quem são os atores e sistemas externos?
150
+ Nível 2 — Container: Quais serviços/apps são afetados?
151
+ Nível 3 — Componente: Quais módulos/classes são criados/modificados?
152
+ Nível 4 — Código: Interfaces, DTOs, entidades (se complexo)
153
+ \`\`\`
154
+
155
+ Se a decisão é significativa → criar ADR (template [ADR.md](../templates/ADR.md))
156
+
157
+ **Apresentar ao humano → Aguardar \`/approved\`**
158
+
159
+ ---
160
+
161
+ ## Step 4: Task Breakdown
162
+
163
+ > **Gate 4 — Lista de tarefas com estimativa.**
164
+
165
+ Formato:
166
+
167
+ \`\`\`markdown
168
+ ## TASK-001: [Título]
169
+ - **US:** US-001
170
+ - **Camada:** Backend / Frontend / App / Database
171
+ - **Estimativa:** XS / S / M / L / XL
172
+ - **Agente:** [quem executa]
173
+ - **Deps:** [depende de TASK-XXX, se houver]
174
+ \`\`\`
175
+
176
+ Ordenar por dependência. Backend SEMPRE primeiro.
177
+
178
+ **Apresentar ao humano → Aguardar \`/approved\`**
179
+
180
+ ---
181
+
182
+ ## Step 5: BDD (Cenários)
183
+
184
+ > **Gate 5 — Cenários de comportamento para cada critério de aceite.**
185
+
186
+ Formato (Gherkin):
187
+
188
+ \`\`\`gherkin
189
+ Feature: [Nome da Feature]
190
+
191
+ Scenario: [cenário happy path]
192
+ Given [contexto]
193
+ When [ação do usuário]
194
+ Then [resultado esperado]
195
+
196
+ Scenario: [cenário de erro]
197
+ Given [contexto]
198
+ When [ação inválida]
199
+ Then [mensagem de erro esperada]
200
+
201
+ Scenario: [cenário edge case]
202
+ Given [contexto específico]
203
+ When [ação]
204
+ Then [comportamento esperado]
205
+ \`\`\`
206
+
207
+ **Apresentar ao humano → Aguardar \`/approved\`**
208
+
209
+ ---
210
+
211
+ ## Step 6: TDD (Casos de Teste)
212
+
213
+ > **Gate 6 — Casos de teste ANTES do código.**
214
+
215
+ \`\`\`
216
+ Para cada TASK:
217
+ 1. Listar os testes que serão escritos
218
+ 2. Descrever input → output esperado
219
+ 3. Incluir testes de erro/exceção
220
+ 4. Incluir testes de boundary
221
+
222
+ Meta: Cobertura ≥ ${config.coverageMinimum}% (INEGOCIÁVEL)
223
+ \`\`\`
224
+
225
+ **Apresentar ao humano → Aguardar \`/approved\`**
226
+
227
+ ---
228
+
229
+ ## Step 7: Implementação — Backend
230
+
231
+ > **SOMENTE após TODOS os 6 gates aprovados.**
232
+
233
+ \`\`\`
234
+ □ Criar/modificar entities e DTOs
235
+ □ Criar/modificar services (lógica de negócio)
236
+ □ Criar/modificar controllers (endpoints)
237
+ □ Criar migrations (se houver alteração de banco)
238
+ □ Escrever testes (RED → GREEN → REFACTOR)
239
+ □ Rodar: build ✓ + tests ✓ + coverage ≥ ${config.coverageMinimum}% ✓
240
+ \`\`\`
241
+
242
+ ---
243
+
244
+ ## Step 8: Documento de Integração
245
+
246
+ > **OBRIGATÓRIO se tem frontend/app. Gerado APÓS backend completo.**
247
+
248
+ \`\`\`markdown
249
+ # Documento de Integração: [Feature]
250
+
251
+ ## Endpoints
252
+
253
+ ### [METHOD] /api/v1/[recurso]
254
+
255
+ **Request:**
256
+ \\\`\\\`\\\`json
257
+ {
258
+ "campo": "tipo — descrição"
259
+ }
260
+ \\\`\\\`\\\`
261
+
262
+ **Response (200):**
263
+ \\\`\\\`\\\`json
264
+ {
265
+ "campo": "tipo — descrição"
266
+ }
267
+ \\\`\\\`\\\`
268
+
269
+ **Erros:**
270
+ | Código | Mensagem | Quando |
271
+ |--------|----------|--------|
272
+ | 400 | Validation error | Input inválido |
273
+ | 404 | Not found | Recurso inexistente |
274
+
275
+ ## Regras
276
+ - [regra 1]
277
+ - [regra 2]
278
+ \`\`\`
279
+
280
+ ---
281
+
282
+ ## Step 9: Implementação — Frontend / App
283
+
284
+ > **Baseado no Documento de Integração.**
285
+
286
+ \`\`\`
287
+ □ Criar/modificar componentes (seguir mockup)
288
+ □ Implementar state management
289
+ □ Integrar com endpoints (conforme doc de integração)
290
+ □ Implementar TODOS os estados (loading, error, empty, data)
291
+ □ Escrever testes (unitários + e2e se aplicável)
292
+ □ Rodar: build ✓ + tests ✓ + coverage ≥ ${config.coverageMinimum}% ✓
293
+ \`\`\`
294
+
295
+ ---
296
+
297
+ ## Step 10: Verificação Final
298
+
299
+ \`\`\`
300
+ ╔════════════════════════════════════════════════╗
301
+ ║ CHECKLIST FINAL — TODOS devem ser ✓ ║
302
+ ║ ║
303
+ ║ □ Build compila sem erros ║
304
+ ║ □ TODOS os testes passam ║
305
+ ║ □ Cobertura ≥ ${String(config.coverageMinimum).padEnd(3)}% ║
306
+ ║ □ Score ≥ ${String(config.scoreThreshold).padEnd(3)}/100 (sem regressão) ║
307
+ ║ □ Lint sem errors ║
308
+ ║ □ Zero anti-patterns CRITICAL novos ║
309
+ ║ □ Todos os critérios de aceite cobertos ║
310
+ ║ □ Documentação atualizada ║
311
+ ║ □ LESSONS-LEARNED atualizado (se aplicável) ║
312
+ ║ □ PR criado com descrição completa ║
313
+ ╚════════════════════════════════════════════════╝
314
+ \`\`\`
315
+
316
+ ---
317
+
318
+ **Gerado por Architect v8.1 · Score: ${report.score.overall}/100 · ${new Date().toISOString().split('T')[0]}**
319
+ `;
320
+ }
321
+ //# sourceMappingURL=workflow-new-feature.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-new-feature.js","sourceRoot":"","sources":["../../../../../../src/core/agent-generator/templates/core/workflow-new-feature.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,MAAM,UAAU,0BAA0B,CAAC,GAAoB;IAC7D,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC;IAEnD,OAAO;;;yDAGgD,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgClE,KAAK,CAAC,cAAc,KAAK,KAAK,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,KAAK,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WA+BvL,GAAG,CAAC,WAAW;;;;;;;;;;;;;oBAaN,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,aAAa;;;;;;;;;;;;;;;;;;EAkBxF,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,4DAA4D,CAAC,CAAC,CAAC,EAAE,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,4DAA4D,CAAC,CAAC,CAAC,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oBAqHzJ,MAAM,CAAC,eAAe;;;;;;;;;;;;;;;;;0CAiBA,MAAM,CAAC,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAqDtB,MAAM,CAAC,eAAe;;;;;;;;;;;;;mBAa7C,MAAM,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;eAC5C,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;;;;;;;;;;;;uCAYf,MAAM,CAAC,KAAK,CAAC,OAAO,UAAU,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1G,CAAC;AACF,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { TemplateContext } from '@girardelli/architect-agents/src/core/agent-generator/types/template.js';
2
+ /**
3
+ * Generates enterprise-grade review.md workflow.
4
+ * Structured code review with checklist per dimension.
5
+ */
6
+ export declare function generateReviewWorkflow(ctx: TemplateContext): string;
@@ -0,0 +1,105 @@
1
+ /**
2
+ * Generates enterprise-grade review.md workflow.
3
+ * Structured code review with checklist per dimension.
4
+ */
5
+ export function generateReviewWorkflow(ctx) {
6
+ // @ts-ignore - Audit cleanup unused variable
7
+ const { stack, projectName, config, report } = ctx;
8
+ return `---
9
+ antigravity:
10
+ trigger: 'on_demand'
11
+ description: 'Workflow de code review estruturado para ${projectName}'
12
+ ---
13
+
14
+ # 🔍 Workflow: Code Review
15
+
16
+ > **Code review não é "LGTM".**
17
+ > É uma verificação sistemática em 6 dimensões.
18
+
19
+ ---
20
+
21
+ ## Dimensão 1: Correção Funcional
22
+
23
+ \`\`\`
24
+ □ O código faz o que a US/task pede?
25
+ □ Todos os critérios de aceite estão cobertos?
26
+ □ Edge cases foram tratados?
27
+ □ Erros são tratados adequadamente?
28
+ □ Regras de negócio estão corretas?
29
+ \`\`\`
30
+
31
+ ## Dimensão 2: Qualidade de Código
32
+
33
+ \`\`\`
34
+ □ Código legível sem comentários explicativos?
35
+ □ Naming é descritivo e consistente?
36
+ □ Sem duplicação (DRY)?
37
+ □ Funções/métodos com responsabilidade única?
38
+ □ Sem magic numbers (extrair para constantes)?
39
+ □ Tipos corretos (sem \`any\` / \`type: ignore\` injustificado)?
40
+ □ Sem código morto / comentado?
41
+ \`\`\`
42
+
43
+ ## Dimensão 3: Testes
44
+
45
+ \`\`\`
46
+ □ Testes existem para o novo código?
47
+ □ Cobertura ≥ ${config.coverageMinimum}%?
48
+ □ Testes são significativos (não apenas \`expect(true).toBe(true)\`)?
49
+ □ Happy path coberto?
50
+ □ Error path coberto?
51
+ □ Edge cases cobertos?
52
+ □ Nenhum teste com .skip() injustificado?
53
+ \`\`\`
54
+
55
+ ## Dimensão 4: Segurança
56
+
57
+ \`\`\`
58
+ □ Sem secrets hardcoded?
59
+ □ Input validado e sanitizado?
60
+ □ SQL injection prevenido (parameterized queries)?
61
+ □ XSS prevenido (output encoding)?
62
+ □ Autenticação/autorização verificada?
63
+ □ Dados sensíveis não logados?
64
+ □ Rate limiting em endpoints novos?
65
+ \`\`\`
66
+
67
+ ## Dimensão 5: Performance
68
+
69
+ \`\`\`
70
+ □ Sem N+1 queries?
71
+ □ Queries com índice adequado?
72
+ □ Sem loops desnecessários sobre coleções grandes?
73
+ □ Lazy loading onde aplicável?
74
+ □ Sem memory leaks óbvios (subscriptions, listeners)?
75
+ □ Caching considerado onde faz sentido?
76
+ \`\`\`
77
+
78
+ ## Dimensão 6: Arquitetura
79
+
80
+ \`\`\`
81
+ □ Segue os padrões do projeto (rules/)?
82
+ □ Camada correta (controller ≠ service ≠ entity)?
83
+ □ Sem violações de layer (data layer acessando UI)?
84
+ □ Score não regrediu: architect score ≥ ${config.scoreThreshold}/100
85
+ □ Sem novos anti-patterns CRITICAL?
86
+ □ Imports organizados, sem circulares?
87
+ \`\`\`
88
+
89
+ ---
90
+
91
+ ## Resultado do Review
92
+
93
+ | Resultado | Ação |
94
+ |-----------|------|
95
+ | ✅ Aprovado | Merge permitido |
96
+ | ⚠️ Aprovado com observações | Merge permitido, fix no próximo PR |
97
+ | ❌ Mudanças necessárias | Bloquear merge até resolver |
98
+ | 🔴 Bloqueado | Issue de segurança ou regressão — resolver imediatamente |
99
+
100
+ ---
101
+
102
+ **Gerado por Architect v8.1 · Score: ${report.score.overall}/100 · ${new Date().toISOString().split('T')[0]}**
103
+ `;
104
+ }
105
+ //# sourceMappingURL=workflow-review.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-review.js","sourceRoot":"","sources":["../../../../../../src/core/agent-generator/templates/core/workflow-review.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CAAC,GAAoB;IACvD,6CAA6C;IAC/C,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC;IAEnD,OAAO;;;2DAGkD,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAoCtD,MAAM,CAAC,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAqCI,MAAM,CAAC,cAAc;;;;;;;;;;;;;;;;;;uCAkBxB,MAAM,CAAC,KAAK,CAAC,OAAO,UAAU,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAC1G,CAAC;AACF,CAAC"}