@maestro-ai/cli 1.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.
Files changed (252) hide show
  1. package/README.md +59 -0
  2. package/content/guides/Cat/303/241logo de Stacks para Cloud Moderna.md" +119 -0
  3. package/content/guides/Cat/303/241logo de Stacks para Hospedagem Compartilhada.md" +147 -0
  4. package/content/guides/Checklist Mestre de Entrega.md +68 -0
  5. package/content/guides/Gates de Qualidade.md +209 -0
  6. package/content/guides/Guia de Adi/303/247/303/243o de Novas Funcionalidades.md" +355 -0
  7. package/content/guides/Guia de Chaos Engineering.md +267 -0
  8. package/content/guides/Guia de Debugging com IA.md +135 -0
  9. package/content/guides/Guia de Estrat/303/251gias de Cache.md" +352 -0
  10. package/content/guides/Guia de Migrations Zero-Downtime.md +311 -0
  11. package/content/guides/Guia de Multi-tenancy.md +368 -0
  12. package/content/guides/Guia de Otimiza/303/247/303/243o de Custos Cloud.md" +195 -0
  13. package/content/guides/Guia de Refatora/303/247/303/243o de C/303/263digo Legado com IA.md" +162 -0
  14. package/content/guides/Guia de SLOs e Error Budgets.md +315 -0
  15. package/content/guides/M/303/251tricas de Efici/303/252ncia do Desenvolvimento com IA.md" +93 -0
  16. package/content/guides/Rules base.md +90 -0
  17. package/content/prompts/README.md +203 -0
  18. package/content/prompts/acessibilidade/analise-acessibilidade.md +257 -0
  19. package/content/prompts/apis/design-api-rest.md +303 -0
  20. package/content/prompts/apis/idempotencia.md +254 -0
  21. package/content/prompts/apis/versionamento.md +313 -0
  22. package/content/prompts/arquitetura/arquitetura-c4-completo.md +190 -0
  23. package/content/prompts/arquitetura/clean-architecture.md +151 -0
  24. package/content/prompts/arquitetura/ddd-bounded-contexts.md +183 -0
  25. package/content/prompts/arquitetura/ddd-cqrs.md +176 -0
  26. package/content/prompts/arquitetura/modelo-dominio.md +207 -0
  27. package/content/prompts/arquitetura/multi-tenancy.md +235 -0
  28. package/content/prompts/database/migrations-zero-downtime.md +192 -0
  29. package/content/prompts/database/otimizacao-queries.md +296 -0
  30. package/content/prompts/desenvolvimento/code-review.md +301 -0
  31. package/content/prompts/desenvolvimento/gerar-servico.md +271 -0
  32. package/content/prompts/devops/docker-compose.md +336 -0
  33. package/content/prompts/devops/feature-flags.md +374 -0
  34. package/content/prompts/devops/kubernetes-deploy.md +460 -0
  35. package/content/prompts/devops/pipeline-cicd.md +358 -0
  36. package/content/prompts/devops/terraform-iac.md +502 -0
  37. package/content/prompts/escalabilidade/analise-performance.md +240 -0
  38. package/content/prompts/escalabilidade/analise-performance.txt +94 -0
  39. package/content/prompts/escalabilidade/caching.md +255 -0
  40. package/content/prompts/observabilidade/chaos-testing.md +237 -0
  41. package/content/prompts/observabilidade/estrategia-observabilidade.md +263 -0
  42. package/content/prompts/observabilidade/estrategia-observabilidade.txt +134 -0
  43. package/content/prompts/observabilidade/slos.md +215 -0
  44. package/content/prompts/produto/discovery-inicial.md +203 -0
  45. package/content/prompts/produto/discovery-inicial.txt +33 -0
  46. package/content/prompts/requisitos/refinar-requisitos.md +232 -0
  47. package/content/prompts/requisitos/refinar-requisitos.txt +40 -0
  48. package/content/prompts/seguranca/analise-seguranca.md +243 -0
  49. package/content/prompts/seguranca/pentest-checklist.md +333 -0
  50. package/content/prompts/seguranca/rate-limiting.md +356 -0
  51. package/content/prompts/seguranca/revisao-lgpd.md +227 -0
  52. package/content/prompts/seguranca/threat-modeling.md +224 -0
  53. package/content/prompts/testes/contract-testing.md +340 -0
  54. package/content/prompts/testes/gerar-testes-unitarios.md +474 -0
  55. package/content/prompts/testes/testes-e2e.md +460 -0
  56. package/content/prompts/testes/testes-integracao.md +418 -0
  57. package/content/prompts/testes/testes-performance.md +458 -0
  58. package/content/prompts/ux/gerar-ui-stitch.md +151 -0
  59. package/content/skills/api-patterns/SKILL.md +81 -0
  60. package/content/skills/api-patterns/api-style.md +42 -0
  61. package/content/skills/api-patterns/auth.md +24 -0
  62. package/content/skills/api-patterns/documentation.md +26 -0
  63. package/content/skills/api-patterns/graphql.md +41 -0
  64. package/content/skills/api-patterns/rate-limiting.md +31 -0
  65. package/content/skills/api-patterns/response.md +37 -0
  66. package/content/skills/api-patterns/rest.md +40 -0
  67. package/content/skills/api-patterns/scripts/api_validator.py +211 -0
  68. package/content/skills/api-patterns/security-testing.md +122 -0
  69. package/content/skills/api-patterns/trpc.md +41 -0
  70. package/content/skills/api-patterns/versioning.md +22 -0
  71. package/content/skills/app-builder/SKILL.md +75 -0
  72. package/content/skills/app-builder/agent-coordination.md +71 -0
  73. package/content/skills/app-builder/feature-building.md +53 -0
  74. package/content/skills/app-builder/project-detection.md +34 -0
  75. package/content/skills/app-builder/scaffolding.md +118 -0
  76. package/content/skills/app-builder/tech-stack.md +40 -0
  77. package/content/skills/app-builder/templates/SKILL.md +39 -0
  78. package/content/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -0
  79. package/content/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -0
  80. package/content/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -0
  81. package/content/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -0
  82. package/content/skills/app-builder/templates/express-api/TEMPLATE.md +83 -0
  83. package/content/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -0
  84. package/content/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -0
  85. package/content/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +82 -0
  86. package/content/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +100 -0
  87. package/content/skills/app-builder/templates/nextjs-static/TEMPLATE.md +106 -0
  88. package/content/skills/app-builder/templates/nuxt-app/TEMPLATE.md +101 -0
  89. package/content/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -0
  90. package/content/skills/app-builder/templates/react-native-app/TEMPLATE.md +93 -0
  91. package/content/skills/architecture/SKILL.md +55 -0
  92. package/content/skills/architecture/context-discovery.md +43 -0
  93. package/content/skills/architecture/examples.md +94 -0
  94. package/content/skills/architecture/pattern-selection.md +68 -0
  95. package/content/skills/architecture/patterns-reference.md +50 -0
  96. package/content/skills/architecture/trade-off-analysis.md +77 -0
  97. package/content/skills/bash-linux/SKILL.md +199 -0
  98. package/content/skills/behavioral-modes/SKILL.md +242 -0
  99. package/content/skills/brainstorming/SKILL.md +163 -0
  100. package/content/skills/brainstorming/dynamic-questioning.md +350 -0
  101. package/content/skills/clean-code/SKILL.md +201 -0
  102. package/content/skills/code-review-checklist/SKILL.md +109 -0
  103. package/content/skills/database-design/SKILL.md +52 -0
  104. package/content/skills/database-design/database-selection.md +43 -0
  105. package/content/skills/database-design/indexing.md +39 -0
  106. package/content/skills/database-design/migrations.md +48 -0
  107. package/content/skills/database-design/optimization.md +36 -0
  108. package/content/skills/database-design/orm-selection.md +30 -0
  109. package/content/skills/database-design/schema-design.md +56 -0
  110. package/content/skills/database-design/scripts/schema_validator.py +172 -0
  111. package/content/skills/deployment-procedures/SKILL.md +241 -0
  112. package/content/skills/doc.md +177 -0
  113. package/content/skills/documentation-templates/SKILL.md +194 -0
  114. package/content/skills/frontend-design/SKILL.md +396 -0
  115. package/content/skills/frontend-design/animation-guide.md +331 -0
  116. package/content/skills/frontend-design/color-system.md +311 -0
  117. package/content/skills/frontend-design/decision-trees.md +418 -0
  118. package/content/skills/frontend-design/motion-graphics.md +306 -0
  119. package/content/skills/frontend-design/scripts/accessibility_checker.py +183 -0
  120. package/content/skills/frontend-design/scripts/ux_audit.py +722 -0
  121. package/content/skills/frontend-design/typography-system.md +345 -0
  122. package/content/skills/frontend-design/ux-psychology.md +541 -0
  123. package/content/skills/frontend-design/visual-effects.md +383 -0
  124. package/content/skills/game-development/2d-games/SKILL.md +119 -0
  125. package/content/skills/game-development/3d-games/SKILL.md +135 -0
  126. package/content/skills/game-development/SKILL.md +167 -0
  127. package/content/skills/game-development/game-art/SKILL.md +185 -0
  128. package/content/skills/game-development/game-audio/SKILL.md +190 -0
  129. package/content/skills/game-development/game-design/SKILL.md +129 -0
  130. package/content/skills/game-development/mobile-games/SKILL.md +108 -0
  131. package/content/skills/game-development/multiplayer/SKILL.md +132 -0
  132. package/content/skills/game-development/pc-games/SKILL.md +144 -0
  133. package/content/skills/game-development/vr-ar/SKILL.md +123 -0
  134. package/content/skills/game-development/web-games/SKILL.md +150 -0
  135. package/content/skills/geo-fundamentals/SKILL.md +156 -0
  136. package/content/skills/geo-fundamentals/scripts/geo_checker.py +289 -0
  137. package/content/skills/i18n-localization/SKILL.md +154 -0
  138. package/content/skills/i18n-localization/scripts/i18n_checker.py +241 -0
  139. package/content/skills/intelligent-routing/SKILL.md +334 -0
  140. package/content/skills/lint-and-validate/SKILL.md +45 -0
  141. package/content/skills/lint-and-validate/scripts/lint_runner.py +172 -0
  142. package/content/skills/lint-and-validate/scripts/type_coverage.py +173 -0
  143. package/content/skills/mcp-builder/SKILL.md +176 -0
  144. package/content/skills/mobile-design/SKILL.md +394 -0
  145. package/content/skills/mobile-design/decision-trees.md +516 -0
  146. package/content/skills/mobile-design/mobile-backend.md +491 -0
  147. package/content/skills/mobile-design/mobile-color-system.md +420 -0
  148. package/content/skills/mobile-design/mobile-debugging.md +122 -0
  149. package/content/skills/mobile-design/mobile-design-thinking.md +357 -0
  150. package/content/skills/mobile-design/mobile-navigation.md +458 -0
  151. package/content/skills/mobile-design/mobile-performance.md +767 -0
  152. package/content/skills/mobile-design/mobile-testing.md +356 -0
  153. package/content/skills/mobile-design/mobile-typography.md +433 -0
  154. package/content/skills/mobile-design/platform-android.md +666 -0
  155. package/content/skills/mobile-design/platform-ios.md +561 -0
  156. package/content/skills/mobile-design/scripts/mobile_audit.py +670 -0
  157. package/content/skills/mobile-design/touch-psychology.md +537 -0
  158. package/content/skills/nextjs-best-practices/SKILL.md +203 -0
  159. package/content/skills/nodejs-best-practices/SKILL.md +333 -0
  160. package/content/skills/parallel-agents/SKILL.md +175 -0
  161. package/content/skills/performance-profiling/SKILL.md +143 -0
  162. package/content/skills/performance-profiling/scripts/lighthouse_audit.py +76 -0
  163. package/content/skills/plan-writing/SKILL.md +152 -0
  164. package/content/skills/powershell-windows/SKILL.md +167 -0
  165. package/content/skills/python-patterns/SKILL.md +441 -0
  166. package/content/skills/react-patterns/SKILL.md +198 -0
  167. package/content/skills/red-team-tactics/SKILL.md +199 -0
  168. package/content/skills/seo-fundamentals/SKILL.md +129 -0
  169. package/content/skills/seo-fundamentals/scripts/seo_checker.py +219 -0
  170. package/content/skills/server-management/SKILL.md +161 -0
  171. package/content/skills/systematic-debugging/SKILL.md +109 -0
  172. package/content/skills/tailwind-patterns/SKILL.md +269 -0
  173. package/content/skills/tdd-workflow/SKILL.md +149 -0
  174. package/content/skills/testing-patterns/SKILL.md +178 -0
  175. package/content/skills/testing-patterns/scripts/test_runner.py +219 -0
  176. package/content/skills/vulnerability-scanner/SKILL.md +276 -0
  177. package/content/skills/vulnerability-scanner/checklists.md +121 -0
  178. package/content/skills/vulnerability-scanner/scripts/security_scan.py +458 -0
  179. package/content/skills/webapp-testing/SKILL.md +187 -0
  180. package/content/skills/webapp-testing/scripts/playwright_runner.py +173 -0
  181. package/content/specialists/Especialista em Acessibilidade.md +266 -0
  182. package/content/specialists/Especialista em An/303/241lise de Testes.md" +434 -0
  183. package/content/specialists/Especialista em Arquitetura Avan/303/247ada.md" +358 -0
  184. package/content/specialists/Especialista em Arquitetura de Software.md +177 -0
  185. package/content/specialists/Especialista em Banco de Dados.md +260 -0
  186. package/content/specialists/Especialista em Contrato de API.md +172 -0
  187. package/content/specialists/Especialista em Dados e Analytics com IA.md +246 -0
  188. package/content/specialists/Especialista em Debugging e Troubleshooting.md +191 -0
  189. package/content/specialists/Especialista em Desenvolvimento Frontend.md +477 -0
  190. package/content/specialists/Especialista em Desenvolvimento Mobile.md +241 -0
  191. package/content/specialists/Especialista em Desenvolvimento e Vibe Coding Estruturado.md +417 -0
  192. package/content/specialists/Especialista em DevOps e Infraestrutura.md +294 -0
  193. package/content/specialists/Especialista em Documenta/303/247/303/243o T/303/251cnica.md" +227 -0
  194. package/content/specialists/Especialista em Engenharia de Requisitos com IA.md +299 -0
  195. package/content/specialists/Especialista em Explora/303/247/303/243o de Codebase.md" +179 -0
  196. package/content/specialists/Especialista em Gest/303/243o de Produto.md" +179 -0
  197. package/content/specialists/Especialista em Migra/303/247/303/243o e Moderniza/303/247/303/243o.md" +410 -0
  198. package/content/specialists/Especialista em Modelagem e Arquitetura de Dom/303/255nio com IA.md" +248 -0
  199. package/content/specialists/Especialista em Observabilidade.md +415 -0
  200. package/content/specialists/Especialista em Performance e Escalabilidade.md +373 -0
  201. package/content/specialists/Especialista em Plano de Execu/303/247/303/243o com IA.md" +341 -0
  202. package/content/specialists/Especialista em Prototipagem R/303/241pida com Google Stitch.md" +419 -0
  203. package/content/specialists/Especialista em Seguran/303/247a da Informa/303/247/303/243o.md" +508 -0
  204. package/content/specialists/Especialista em UX Design.md +453 -0
  205. package/content/specialists/INDEX.md +43 -0
  206. package/content/templates/PRD.md +165 -0
  207. package/content/templates/README.md +65 -0
  208. package/content/templates/adr.md +103 -0
  209. package/content/templates/arquitetura.md +279 -0
  210. package/content/templates/backlog.md +185 -0
  211. package/content/templates/checklist-seguranca.md +180 -0
  212. package/content/templates/contexto.md +120 -0
  213. package/content/templates/criterios-aceite.md +99 -0
  214. package/content/templates/design-banco.md +270 -0
  215. package/content/templates/design-doc.md +240 -0
  216. package/content/templates/feature.md +88 -0
  217. package/content/templates/historia-backend.md +84 -0
  218. package/content/templates/historia-frontend.md +75 -0
  219. package/content/templates/historia-usuario.md +125 -0
  220. package/content/templates/mapa-navegacao.md +133 -0
  221. package/content/templates/matriz-rastreabilidade.md +121 -0
  222. package/content/templates/modelo-dominio.md +219 -0
  223. package/content/templates/plano-testes.md +199 -0
  224. package/content/templates/prototipo-stitch.md +138 -0
  225. package/content/templates/requisitos.md +162 -0
  226. package/content/templates/slo-sli.md +197 -0
  227. package/content/workflows/README-MCP.md +363 -0
  228. package/content/workflows/brainstorm.md +113 -0
  229. package/content/workflows/create.md +59 -0
  230. package/content/workflows/debug.md +103 -0
  231. package/content/workflows/deploy.md +176 -0
  232. package/content/workflows/enhance.md +63 -0
  233. package/content/workflows/mcp-debug.md +506 -0
  234. package/content/workflows/mcp-feature.md +385 -0
  235. package/content/workflows/mcp-gate.md +413 -0
  236. package/content/workflows/mcp-next.md +388 -0
  237. package/content/workflows/mcp-refactor.md +600 -0
  238. package/content/workflows/mcp-start.md +304 -0
  239. package/content/workflows/mcp-status.md +400 -0
  240. package/content/workflows/orchestrate.md +237 -0
  241. package/content/workflows/plan.md +89 -0
  242. package/content/workflows/preview.md +81 -0
  243. package/content/workflows/status.md +86 -0
  244. package/content/workflows/test.md +144 -0
  245. package/content/workflows/ui-ux-pro-max.md +296 -0
  246. package/dist/commands/init.d.ts +6 -0
  247. package/dist/commands/init.js +138 -0
  248. package/dist/commands/update.d.ts +5 -0
  249. package/dist/commands/update.js +50 -0
  250. package/dist/index.d.ts +2 -0
  251. package/dist/index.js +21 -0
  252. package/package.json +48 -0
@@ -0,0 +1,133 @@
1
+ # Mapa de Navegação: [Nome do Sistema]
2
+
3
+ **Versão:** 1.0
4
+ **Data:** YYYY-MM-DD
5
+ **Designer:** [Nome]
6
+ **Design Doc Relacionado:** [Link]
7
+
8
+ ---
9
+
10
+ ## 1. Diagrama de Navegação
11
+
12
+ ```mermaid
13
+ flowchart LR
14
+ subgraph Public["🌐 Área Pública"]
15
+ HOME[Home]
16
+ LOGIN[Login]
17
+ REGISTER[Cadastro]
18
+ FORGOT[Esqueci Senha]
19
+ end
20
+
21
+ subgraph Auth["🔐 Área Autenticada"]
22
+ DASH[Dashboard]
23
+ PROFILE[Perfil]
24
+ SETTINGS[Configurações]
25
+ end
26
+
27
+ subgraph Module1["📦 Módulo 1"]
28
+ M1_LIST[Lista]
29
+ M1_DETAIL[Detalhe]
30
+ M1_CREATE[Criar/Editar]
31
+ end
32
+
33
+ HOME --> LOGIN
34
+ HOME --> REGISTER
35
+ LOGIN --> FORGOT
36
+ LOGIN --> DASH
37
+ REGISTER --> DASH
38
+
39
+ DASH --> PROFILE
40
+ DASH --> SETTINGS
41
+ DASH --> M1_LIST
42
+
43
+ M1_LIST --> M1_DETAIL
44
+ M1_LIST --> M1_CREATE
45
+ M1_DETAIL --> M1_CREATE
46
+ M1_DETAIL -.->|voltar| M1_LIST
47
+ ```
48
+
49
+ ---
50
+
51
+ ## 2. Inventário de Telas
52
+
53
+ | ID | Tela | URL | Acesso | RFs Relacionados | Descrição |
54
+ |----|------|-----|--------|------------------|-----------|
55
+ | T01 | Home | `/` | Público | - | Landing page |
56
+ | T02 | Login | `/login` | Público | RF-001 | Autenticação |
57
+ | T03 | Cadastro | `/register` | Público | RF-002 | Novo usuário |
58
+ | T04 | Dashboard | `/dashboard` | Auth | RF-003 | Visão geral |
59
+ | T05 | [Módulo] Lista | `/modulo` | Auth | RF-00X | Lista de itens |
60
+ | T06 | [Módulo] Detalhe | `/modulo/:id` | Auth | RF-00X | Detalhes do item |
61
+ | T07 | [Módulo] Criar | `/modulo/new` | Auth | RF-00X | Criar novo item |
62
+
63
+ ---
64
+
65
+ ## 3. Padrões de Navegação
66
+
67
+ ### 3.1 Navegação Global
68
+
69
+ | Padrão | Telas Aplicáveis | Comportamento |
70
+ |--------|------------------|---------------|
71
+ | Header | Todas autenticadas | Logo, menu principal, avatar |
72
+ | Sidebar | Dashboard, módulos | Menu colapsável |
73
+ | Breadcrumb | Detalhes, edição | Home > Módulo > Item |
74
+ | Back Button | Detalhes, formulários | Volta para lista |
75
+
76
+ ### 3.2 Transições entre Telas
77
+
78
+ | Origem | Destino | Gatilho | Dados Passados |
79
+ |--------|---------|---------|----------------|
80
+ | Lista | Detalhe | Click no item | `id` do item |
81
+ | Detalhe | Editar | Botão "Editar" | `id` do item |
82
+ | Form | Lista | Submit sucesso | - (refresh lista) |
83
+ | Qualquer | Login | Sessão expirada | `returnUrl` |
84
+
85
+ ---
86
+
87
+ ## 4. Estados por Tela
88
+
89
+ | Tela | Loading | Empty | Error | Success |
90
+ |------|---------|-------|-------|---------|
91
+ | Lista | Skeleton table | "Nenhum item encontrado" + CTA | Toast + retry | - |
92
+ | Detalhe | Spinner central | 404 page | Toast + back | - |
93
+ | Form | Button loading | - | Inline errors | Toast + redirect |
94
+ | Dashboard | Skeleton cards | Cards com zeros | Toast | - |
95
+
96
+ ---
97
+
98
+ ## 5. Responsividade
99
+
100
+ | Breakpoint | Navegação | Layout |
101
+ |------------|-----------|--------|
102
+ | Mobile (< 768px) | Bottom nav ou hamburger | Stack vertical |
103
+ | Tablet (768-1024px) | Sidebar colapsada | 2 colunas |
104
+ | Desktop (> 1024px) | Sidebar fixa | 3+ colunas |
105
+
106
+ ---
107
+
108
+ ## 6. Acessibilidade na Navegação
109
+
110
+ - [ ] Skip links no topo de cada página
111
+ - [ ] Focus trap em modais
112
+ - [ ] Aria-current para item ativo do menu
113
+ - [ ] Landmarks (`nav`, `main`, `aside`)
114
+ - [ ] Anúncio de mudança de página para screen readers
115
+
116
+ ---
117
+
118
+ ## 7. Deep Links e Compartilhamento
119
+
120
+ | Tela | Pode Compartilhar | URL Pattern | Auth Required |
121
+ |------|-------------------|-------------|---------------|
122
+ | Detalhe | ✅ | `/modulo/:id` | Sim |
123
+ | Lista com filtros | ✅ | `/modulo?filter=x` | Sim |
124
+ | Dashboard | ❌ | - | Sim |
125
+ | Login | ❌ | - | Não |
126
+
127
+ ---
128
+
129
+ ## Changelog
130
+
131
+ | Versão | Data | Autor | Mudanças |
132
+ |--------|------|-------|----------|
133
+ | 1.0 | YYYY-MM-DD | [Nome] | Versão inicial |
@@ -0,0 +1,121 @@
1
+ # Matriz de Rastreabilidade: [Nome do Sistema]
2
+
3
+ **Versão:** 1.0
4
+ **Data:** YYYY-MM-DD
5
+ **Responsável:** [Nome]
6
+
7
+ ---
8
+
9
+ ## Objetivo
10
+
11
+ Garantir que todos os requisitos estejam cobertos por histórias de usuário e casos de teste, permitindo rastreabilidade completa do requisito até a validação.
12
+
13
+ ---
14
+
15
+ ## Matriz: Requisitos → User Stories → Testes
16
+
17
+ | ID Requisito | Descrição Resumida | User Stories | Casos de Teste | Status |
18
+ |---|---|---|---|---|
19
+ | **RF001** | [Descrição curta] | US001, US002 | TC001, TC002, TC003 | ✅ Coberto |
20
+ | **RF002** | [Descrição curta] | US003 | TC004, TC005 | ✅ Coberto |
21
+ | **RF003** | [Descrição curta] | - | - | ❌ Não coberto |
22
+ | **RF004** | [Descrição curta] | US004 | TC006 | 🔄 Em andamento |
23
+ | **RNF001** | [Performance] | - | TC-PERF-001 | ⏳ Pendente |
24
+ | **RNF002** | [Segurança] | - | TC-SEC-001 | ⏳ Pendente |
25
+
26
+ ---
27
+
28
+ ## Cobertura por Requisito
29
+
30
+ ### Requisitos Funcionais
31
+
32
+ | Status | Quantidade | % |
33
+ |---|---|---|
34
+ | ✅ Coberto (US + TC) | X | X% |
35
+ | 🔄 Parcial (só US ou só TC) | X | X% |
36
+ | ❌ Não coberto | X | X% |
37
+ | **Total** | X | 100% |
38
+
39
+ ### Requisitos Não-Funcionais
40
+
41
+ | Status | Quantidade | % |
42
+ |---|---|---|
43
+ | ✅ Coberto | X | X% |
44
+ | ⏳ Pendente | X | X% |
45
+ | **Total** | X | 100% |
46
+
47
+ ---
48
+
49
+ ## Matriz: User Stories → Código → Testes
50
+
51
+ | US ID | Módulo/Arquivo | Testes Unitários | Testes Integração | Cobertura |
52
+ |---|---|---|---|---|
53
+ | US001 | `src/modules/user/` | user.service.spec.ts | user.e2e.spec.ts | 85% |
54
+ | US002 | `src/modules/order/` | order.service.spec.ts | order.e2e.spec.ts | 78% |
55
+ | US003 | `src/modules/payment/` | - | - | 0% |
56
+
57
+ ---
58
+
59
+ ## Gaps Identificados
60
+
61
+ ### Requisitos sem Cobertura
62
+
63
+ | ID | Descrição | Ação | Responsável | Prazo |
64
+ |---|---|---|---|---|
65
+ | RF003 | [Descrição] | Criar US e TC | [Nome] | [Data] |
66
+ | RNF001 | [Performance] | Criar teste de carga | [Nome] | [Data] |
67
+
68
+ ### User Stories sem Testes
69
+
70
+ | ID | Descrição | Ação | Responsável | Prazo |
71
+ |---|---|---|---|---|
72
+ | US003 | [Descrição] | Criar testes | [Nome] | [Data] |
73
+
74
+ ---
75
+
76
+ ## Dependências entre Requisitos
77
+
78
+ ```mermaid
79
+ graph TD
80
+ RF001[RF001: Login] --> RF002[RF002: Dashboard]
81
+ RF001 --> RF003[RF003: Perfil]
82
+ RF002 --> RF004[RF004: Relatórios]
83
+ RF005[RF005: Pagamento] --> RF006[RF006: Fatura]
84
+ ```
85
+
86
+ ---
87
+
88
+ ## Histórico de Mudanças em Requisitos
89
+
90
+ | ID | Data | Mudança | Impacto em US | Impacto em TC |
91
+ |---|---|---|---|---|
92
+ | RF001 | YYYY-MM-DD | [Descrição da mudança] | US001 atualizada | TC001, TC002 revisados |
93
+ | RF004 | YYYY-MM-DD | [Novo requisito adicionado] | US005 criada | TC007 criado |
94
+
95
+ ---
96
+
97
+ ## Checklist de Rastreabilidade
98
+
99
+ - [ ] Todo RF tem pelo menos 1 US associada
100
+ - [ ] Toda US tem critérios de aceite em Gherkin
101
+ - [ ] Todo critério de aceite tem TC correspondente
102
+ - [ ] Todos os TCs estão implementados e passando
103
+ - [ ] RNFs têm testes específicos (performance, segurança)
104
+ - [ ] Matriz atualizada após cada sprint
105
+
106
+ ---
107
+
108
+ ## Exportação / Links
109
+
110
+ - Requisitos: [Link para requisitos.md]
111
+ - Backlog: [Link para backlog.md]
112
+ - Plano de Testes: [Link para plano-testes.md]
113
+ - Board (Jira/Linear): [Link]
114
+
115
+ ---
116
+
117
+ ## Changelog
118
+
119
+ | Versão | Data | Autor | Mudanças |
120
+ |---|---|---|---|
121
+ | 1.0 | YYYY-MM-DD | [Nome] | Versão inicial |
@@ -0,0 +1,219 @@
1
+ # Modelo de Domínio: [Nome do Sistema]
2
+
3
+ **Versão:** 1.0
4
+ **Data:** YYYY-MM-DD
5
+ **Requisitos Relacionados:** [Link]
6
+
7
+ ---
8
+
9
+ ## 1. Bounded Contexts
10
+
11
+ ```mermaid
12
+ graph TB
13
+ subgraph Core["🔴 Core Domain"]
14
+ BC1[Contexto Principal]
15
+ end
16
+ subgraph Supporting["🟡 Supporting"]
17
+ BC2[Contexto de Suporte 1]
18
+ BC3[Contexto de Suporte 2]
19
+ end
20
+ subgraph Generic["🟢 Generic"]
21
+ BC4[Autenticação]
22
+ BC5[Notificações]
23
+ end
24
+
25
+ BC1 --> BC2
26
+ BC1 --> BC4
27
+ BC2 --> BC5
28
+ ```
29
+
30
+ | Bounded Context | Responsabilidade | Tipo | Linguagem Ubíqua |
31
+ |---|---|---|---|
32
+ | [Nome] | [O que faz] | Core/Supporting/Generic | [Termos específicos] |
33
+
34
+ ---
35
+
36
+ ## 2. Entidades
37
+
38
+ ### 2.1 [NomeEntidade]
39
+
40
+ **Descrição:** [O que esta entidade representa no domínio]
41
+
42
+ **Bounded Context:** [A qual contexto pertence]
43
+
44
+ | Campo | Tipo | Obrigatório | Descrição | Validações |
45
+ |---|---|---|---|---|
46
+ | id | UUID | ✅ | Identificador único | Auto-gerado |
47
+ | nome | string(100) | ✅ | Nome do... | Min 2 chars |
48
+ | email | string(255) | ✅ | Email do... | Formato email |
49
+ | status | enum | ✅ | Status atual | [ATIVO, INATIVO] |
50
+ | createdAt | datetime | ✅ | Data de criação | Auto |
51
+ | updatedAt | datetime | ✅ | Última atualização | Auto |
52
+
53
+ **Regras de Negócio:**
54
+ - RN1: [Nome deve ser único dentro de X]
55
+ - RN2: [Status só pode mudar de ATIVO para INATIVO se Y]
56
+
57
+ **Invariantes:**
58
+ - [Condição que SEMPRE deve ser verdadeira para esta entidade]
59
+ - Email não pode ser alterado após criação
60
+
61
+ **Métodos de Domínio:**
62
+ - `ativar()`: Muda status para ATIVO
63
+ - `desativar()`: Muda status para INATIVO se [condição]
64
+
65
+ ---
66
+
67
+ ### 2.2 [OutraEntidade]
68
+
69
+ **Descrição:** [Descrição]
70
+
71
+ | Campo | Tipo | Obrigatório | Descrição | Validações |
72
+ |---|---|---|---|---|
73
+ | id | UUID | ✅ | | |
74
+ | | | | | |
75
+
76
+ ---
77
+
78
+ ## 3. Value Objects
79
+
80
+ ### 3.1 [NomeVO]
81
+
82
+ **Descrição:** [Objeto imutável que representa um conceito]
83
+
84
+ | Campo | Tipo | Validação |
85
+ |---|---|---|
86
+ | valor | string | [Regra] |
87
+
88
+ **Exemplo:** Email, CPF, Dinheiro, Endereço
89
+
90
+ ```typescript
91
+ // Exemplo de uso
92
+ class Email {
93
+ constructor(private readonly value: string) {
94
+ if (!this.isValid(value)) throw new Error('Email inválido');
95
+ }
96
+ }
97
+ ```
98
+
99
+ ---
100
+
101
+ ## 4. Agregados
102
+
103
+ ### 4.1 Agregado: [Nome]
104
+
105
+ **Raiz do Agregado:** [Entidade raiz]
106
+
107
+ **Descrição:** [O que este agregado encapsula]
108
+
109
+ ```mermaid
110
+ classDiagram
111
+ class RaizAgregado {
112
+ +id: UUID
113
+ +campo1: tipo
114
+ +adicionarFilho()
115
+ +removerFilho()
116
+ }
117
+ class EntidadeFilha {
118
+ +id: UUID
119
+ +campo: tipo
120
+ }
121
+ class ValueObject {
122
+ +valor: tipo
123
+ }
124
+ RaizAgregado "1" --> "*" EntidadeFilha
125
+ RaizAgregado --> ValueObject
126
+ ```
127
+
128
+ **Regras do Agregado:**
129
+ - Acesso às entidades filhas somente através da raiz
130
+ - [Regra específica]
131
+
132
+ ---
133
+
134
+ ## 5. Relacionamentos
135
+
136
+ ### Diagrama ER
137
+
138
+ ```mermaid
139
+ erDiagram
140
+ USUARIO ||--o{ PEDIDO : "faz"
141
+ PEDIDO ||--|{ ITEM_PEDIDO : "contém"
142
+ ITEM_PEDIDO }|--|| PRODUTO : "referencia"
143
+ USUARIO ||--o{ ENDERECO : "tem"
144
+ ```
145
+
146
+ ### Tabela de Relacionamentos
147
+
148
+ | Origem | Destino | Cardinalidade | Descrição | Obrigatório |
149
+ |---|---|---|---|---|
150
+ | Usuario | Pedido | 1:N | Um usuário faz vários pedidos | Não |
151
+ | Pedido | ItemPedido | 1:N | Um pedido tem vários itens | Sim (min 1) |
152
+ | ItemPedido | Produto | N:1 | Item referencia um produto | Sim |
153
+
154
+ ---
155
+
156
+ ## 6. Eventos de Domínio
157
+
158
+ | Evento | Trigger | Payload | Consumidores |
159
+ |---|---|---|---|
160
+ | UsuarioCriado | Após criar usuário | `{id, email, nome}` | EmailService, Analytics |
161
+ | PedidoFinalizado | Após finalizar pedido | `{id, total, itens}` | Estoque, Financeiro |
162
+ | | | | |
163
+
164
+ ### Exemplo de Evento
165
+
166
+ ```typescript
167
+ interface PedidoFinalizadoEvent {
168
+ eventType: 'PedidoFinalizado';
169
+ occurredAt: Date;
170
+ payload: {
171
+ pedidoId: string;
172
+ usuarioId: string;
173
+ total: number;
174
+ itens: Array<{produtoId: string; quantidade: number}>;
175
+ };
176
+ }
177
+ ```
178
+
179
+ ---
180
+
181
+ ## 7. Serviços de Domínio
182
+
183
+ | Serviço | Responsabilidade | Entidades Envolvidas |
184
+ |---|---|---|
185
+ | CalculadoraPreco | Calcula preço com descontos | Pedido, Cupom, Produto |
186
+ | ValidadorEstoque | Verifica disponibilidade | Produto, ItemPedido |
187
+
188
+ ---
189
+
190
+ ## 8. Repositórios
191
+
192
+ | Repositório | Entidade | Métodos Principais |
193
+ |---|---|---|
194
+ | UsuarioRepository | Usuario | `findById`, `findByEmail`, `save` |
195
+ | PedidoRepository | Pedido | `findById`, `findByUsuario`, `save` |
196
+
197
+ ---
198
+
199
+ ## 9. Dúvidas em Aberto
200
+
201
+ - [ ] [Pergunta sobre o domínio para stakeholder]
202
+ - [ ] [Outra dúvida]
203
+
204
+ ---
205
+
206
+ ## Glossário (Linguagem Ubíqua)
207
+
208
+ | Termo | Definição no Domínio |
209
+ |---|---|
210
+ | [Termo] | [O que significa neste contexto] |
211
+ | | |
212
+
213
+ ---
214
+
215
+ ## Changelog
216
+
217
+ | Versão | Data | Autor | Mudanças |
218
+ |---|---|---|---|
219
+ | 1.0 | YYYY-MM-DD | [Nome] | Versão inicial |
@@ -0,0 +1,199 @@
1
+ # Plano de Testes: [Nome do Sistema]
2
+
3
+ **Versão:** 1.0
4
+ **Data:** YYYY-MM-DD
5
+ **QA Responsável:** [Nome]
6
+ **Requisitos Relacionados:** [Link]
7
+
8
+ ---
9
+
10
+ ## 1. Escopo
11
+
12
+ ### 1.1 O que será testado
13
+ - [Módulo/Funcionalidade 1]
14
+ - [Módulo/Funcionalidade 2]
15
+ - [Módulo/Funcionalidade 3]
16
+
17
+ ### 1.2 O que NÃO será testado
18
+ - [Funcionalidades fora do escopo e porquê]
19
+
20
+ ### 1.3 Riscos de Qualidade
21
+ | Risco | Probabilidade | Impacto | Mitigação |
22
+ |---|---|---|---|
23
+ | [Risco 1] | Alta/Média/Baixa | Alto/Médio/Baixo | [Ação] |
24
+
25
+ ---
26
+
27
+ ## 2. Estratégia de Testes
28
+
29
+ ### Pirâmide de Testes
30
+
31
+ ```
32
+ /\
33
+ / \ E2E (10%)
34
+ /----\
35
+ / \ Integração (20%)
36
+ /--------\
37
+ / \ Unitários (70%)
38
+ /--------------\
39
+ ```
40
+
41
+ ### Tipos de Teste por Camada
42
+
43
+ | Tipo | Ferramenta | Cobertura Alvo | Responsável |
44
+ |---|---|---|---|
45
+ | Unitários | Jest/Vitest | 80% | Devs |
46
+ | Integração | Jest + Supertest | 60% | Devs |
47
+ | E2E | Playwright/Cypress | Fluxos críticos | QA |
48
+ | Performance | k6/Artillery | - | DevOps/QA |
49
+ | Segurança | OWASP ZAP | - | Sec/QA |
50
+
51
+ ---
52
+
53
+ ## 3. Casos de Teste
54
+
55
+ ### 3.1 [Módulo/Funcionalidade 1]
56
+
57
+ #### TC001 - [Nome do Caso de Teste] (RF001)
58
+ | Campo | Valor |
59
+ |---|---|
60
+ | **Prioridade** | Alta/Média/Baixa |
61
+ | **Tipo** | Funcional/Integração/E2E |
62
+ | **Pré-condições** | [O que precisa estar configurado] |
63
+
64
+ **Passos:**
65
+ 1. [Ação 1]
66
+ 2. [Ação 2]
67
+ 3. [Ação 3]
68
+
69
+ **Resultado Esperado:**
70
+ - [O que deve acontecer]
71
+
72
+ **Dados de Teste:**
73
+ | Input | Output Esperado |
74
+ |---|---|
75
+ | [Valor 1] | [Resultado 1] |
76
+ | [Valor 2] | [Resultado 2] |
77
+
78
+ ---
79
+
80
+ #### TC002 - [Caso de Erro] (RF001)
81
+ | Campo | Valor |
82
+ |---|---|
83
+ | **Prioridade** | Alta |
84
+ | **Tipo** | Funcional |
85
+ | **Pré-condições** | [Condição de erro] |
86
+
87
+ **Passos:**
88
+ 1. [Ação que causa erro]
89
+
90
+ **Resultado Esperado:**
91
+ - Mensagem de erro "[texto]"
92
+ - Sistema mantém estado anterior
93
+
94
+ ---
95
+
96
+ ### 3.2 [Módulo/Funcionalidade 2]
97
+
98
+ #### TC003 - [Nome do Caso]
99
+ [Repetir estrutura]
100
+
101
+ ---
102
+
103
+ ## 4. Matriz de Rastreabilidade
104
+
105
+ | Requisito | Casos de Teste | Status |
106
+ |---|---|---|
107
+ | RF001 | TC001, TC002 | ✅ Passando |
108
+ | RF002 | TC003 | 🔄 Em desenvolvimento |
109
+ | RF003 | TC004, TC005 | ⏳ Pendente |
110
+
111
+ ---
112
+
113
+ ## 5. Ambiente de Testes
114
+
115
+ ### 5.1 Configuração
116
+ | Componente | Ambiente de Teste | Observações |
117
+ |---|---|---|
118
+ | API | staging.api.example.com | Reset diário |
119
+ | Banco | PostgreSQL (container) | Seeds automáticos |
120
+ | Redis | Container local | - |
121
+
122
+ ### 5.2 Dados de Teste
123
+ - [ ] Seeds de dados configurados
124
+ - [ ] Usuários de teste criados
125
+ - [ ] Limpeza entre execuções
126
+
127
+ ---
128
+
129
+ ## 6. Critérios de Aceitação
130
+
131
+ ### 6.1 Critérios de Entrada
132
+ - [ ] Código em branch de feature
133
+ - [ ] Build passando
134
+ - [ ] Code review aprovado
135
+
136
+ ### 6.2 Critérios de Saída
137
+ - [ ] Todos os testes passando
138
+ - [ ] Cobertura mínima atingida (80% unit, 60% integration)
139
+ - [ ] Zero bugs críticos/bloqueadores
140
+ - [ ] Bugs médios documentados
141
+
142
+ ---
143
+
144
+ ## 7. Métricas de Qualidade
145
+
146
+ | Métrica | Alvo | Atual |
147
+ |---|---|---|
148
+ | Cobertura unitária | > 80% | - |
149
+ | Cobertura integração | > 60% | - |
150
+ | Taxa de bugs escapados | < 5% | - |
151
+ | Tempo médio de fix | < 2 dias | - |
152
+
153
+ ---
154
+
155
+ ## 8. Cronograma
156
+
157
+ | Fase | Data Início | Data Fim | Status |
158
+ |---|---|---|---|
159
+ | Testes unitários | | | ⏳ |
160
+ | Testes integração | | | ⏳ |
161
+ | Testes E2E | | | ⏳ |
162
+ | Testes performance | | | ⏳ |
163
+ | Regression final | | | ⏳ |
164
+
165
+ ---
166
+
167
+ ## 9. Relatório de Bugs
168
+
169
+ Template para reportar bugs encontrados:
170
+
171
+ ```markdown
172
+ ## BUG-XXX: [Título]
173
+
174
+ **Severidade:** Crítico/Alto/Médio/Baixo
175
+ **Ambiente:** [Onde ocorreu]
176
+ **Requisito:** [RF relacionado]
177
+
178
+ ### Passos para Reproduzir
179
+ 1.
180
+ 2.
181
+ 3.
182
+
183
+ ### Resultado Atual
184
+ [O que acontece]
185
+
186
+ ### Resultado Esperado
187
+ [O que deveria acontecer]
188
+
189
+ ### Evidências
190
+ [Screenshots, logs]
191
+ ```
192
+
193
+ ---
194
+
195
+ ## Changelog
196
+
197
+ | Versão | Data | Autor | Mudanças |
198
+ |---|---|---|---|
199
+ | 1.0 | YYYY-MM-DD | [Nome] | Versão inicial |