bmad-method 5.1.3 → 6.0.0-Beta.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 (739) hide show
  1. package/.coderabbit.yaml +40 -0
  2. package/.github/CODE_OF_CONDUCT.md +128 -0
  3. package/.github/FUNDING.yaml +2 -2
  4. package/.github/ISSUE_TEMPLATE/config.yaml +8 -0
  5. package/.github/ISSUE_TEMPLATE/feature_request.md +11 -11
  6. package/.github/ISSUE_TEMPLATE/issue.md +32 -0
  7. package/.github/scripts/discord-helpers.sh +34 -0
  8. package/.github/workflows/discord.yaml +82 -17
  9. package/.github/workflows/docs.yaml +63 -0
  10. package/.github/workflows/manual-release.yaml +40 -20
  11. package/.github/workflows/quality.yaml +115 -0
  12. package/.husky/pre-commit +17 -0
  13. package/.markdownlint-cli2.yaml +41 -0
  14. package/.nvmrc +1 -0
  15. package/.prettierignore +9 -0
  16. package/.vscode/settings.json +38 -10
  17. package/CHANGELOG.md +1167 -372
  18. package/CNAME +1 -0
  19. package/CONTRIBUTING.md +100 -142
  20. package/CONTRIBUTORS.md +32 -0
  21. package/LICENSE +10 -1
  22. package/README.md +67 -170
  23. package/SECURITY.md +85 -0
  24. package/TRADEMARK.md +55 -0
  25. package/Wordmark.png +0 -0
  26. package/banner-bmad-method.png +0 -0
  27. package/docs/404.md +9 -0
  28. package/docs/_STYLE_GUIDE.md +367 -0
  29. package/docs/downloads.md +74 -0
  30. package/docs/explanation/advanced-elicitation.md +24 -0
  31. package/docs/explanation/adversarial-review.md +57 -0
  32. package/docs/explanation/brainstorming.md +31 -0
  33. package/docs/explanation/brownfield-faq.md +55 -0
  34. package/docs/explanation/party-mode.md +57 -0
  35. package/docs/explanation/preventing-agent-conflicts.md +110 -0
  36. package/docs/explanation/quick-flow.md +27 -0
  37. package/docs/explanation/why-solutioning-matters.md +75 -0
  38. package/docs/how-to/brownfield/index.md +84 -0
  39. package/docs/how-to/brownfield/quick-fix-in-brownfield.md +76 -0
  40. package/docs/how-to/customize-bmad.md +158 -0
  41. package/docs/how-to/get-answers-about-bmad.md +102 -0
  42. package/docs/how-to/install-bmad.md +82 -0
  43. package/docs/how-to/shard-large-documents.md +101 -0
  44. package/docs/how-to/upgrade-to-v6.md +131 -0
  45. package/docs/index.md +56 -0
  46. package/docs/reference/workflow-map.md +83 -0
  47. package/docs/tea/explanation/engagement-models.md +710 -0
  48. package/docs/tea/explanation/fixture-architecture.md +457 -0
  49. package/docs/tea/explanation/knowledge-base-system.md +554 -0
  50. package/docs/tea/explanation/network-first-patterns.md +853 -0
  51. package/docs/tea/explanation/risk-based-testing.md +586 -0
  52. package/docs/tea/explanation/tea-overview.md +410 -0
  53. package/docs/tea/explanation/test-quality-standards.md +907 -0
  54. package/docs/tea/explanation/testing-as-engineering.md +112 -0
  55. package/docs/tea/glossary/index.md +159 -0
  56. package/docs/tea/how-to/brownfield/use-tea-for-enterprise.md +525 -0
  57. package/docs/tea/how-to/brownfield/use-tea-with-existing-tests.md +577 -0
  58. package/docs/tea/how-to/customization/enable-tea-mcp-enhancements.md +424 -0
  59. package/docs/tea/how-to/customization/integrate-playwright-utils.md +813 -0
  60. package/docs/tea/how-to/workflows/run-atdd.md +436 -0
  61. package/docs/tea/how-to/workflows/run-automate.md +653 -0
  62. package/docs/tea/how-to/workflows/run-nfr-assess.md +679 -0
  63. package/docs/tea/how-to/workflows/run-test-design.md +135 -0
  64. package/docs/tea/how-to/workflows/run-test-review.md +605 -0
  65. package/docs/tea/how-to/workflows/run-trace.md +883 -0
  66. package/docs/tea/how-to/workflows/setup-ci.md +712 -0
  67. package/docs/tea/how-to/workflows/setup-test-framework.md +98 -0
  68. package/docs/tea/reference/commands.md +276 -0
  69. package/docs/tea/reference/configuration.md +678 -0
  70. package/docs/tea/reference/knowledge-base.md +340 -0
  71. package/docs/tea/tutorials/tea-lite-quickstart.md +444 -0
  72. package/docs/tutorials/getting-started.md +205 -0
  73. package/eslint.config.mjs +42 -9
  74. package/package.json +50 -38
  75. package/prettier.config.mjs +1 -1
  76. package/src/bmm/_module-installer/installer.js +48 -0
  77. package/src/bmm/agents/analyst.agent.yaml +36 -0
  78. package/src/bmm/agents/architect.agent.yaml +28 -0
  79. package/src/bmm/agents/dev.agent.yaml +38 -0
  80. package/src/bmm/agents/pm.agent.yaml +46 -0
  81. package/src/bmm/agents/quick-flow-solo-dev.agent.yaml +32 -0
  82. package/src/bmm/agents/sm.agent.yaml +36 -0
  83. package/src/bmm/agents/tea.agent.yaml +63 -0
  84. package/src/bmm/agents/tech-writer/tech-writer-sidecar/documentation-standards.md +224 -0
  85. package/src/bmm/agents/tech-writer/tech-writer.agent.yaml +45 -0
  86. package/src/bmm/agents/ux-designer.agent.yaml +26 -0
  87. package/src/bmm/data/project-context-template.md +26 -0
  88. package/src/bmm/module-help.csv +32 -0
  89. package/src/bmm/module.yaml +44 -0
  90. package/src/bmm/teams/default-party.csv +21 -0
  91. package/src/bmm/teams/team-fullstack.yaml +12 -0
  92. package/src/bmm/testarch/knowledge/adr-quality-readiness-checklist.md +350 -0
  93. package/src/bmm/testarch/knowledge/api-request.md +442 -0
  94. package/src/bmm/testarch/knowledge/api-testing-patterns.md +843 -0
  95. package/src/bmm/testarch/knowledge/auth-session.md +552 -0
  96. package/src/bmm/testarch/knowledge/burn-in.md +273 -0
  97. package/src/bmm/testarch/knowledge/ci-burn-in.md +675 -0
  98. package/src/bmm/testarch/knowledge/component-tdd.md +486 -0
  99. package/src/bmm/testarch/knowledge/contract-testing.md +957 -0
  100. package/src/bmm/testarch/knowledge/data-factories.md +500 -0
  101. package/src/bmm/testarch/knowledge/email-auth.md +721 -0
  102. package/src/bmm/testarch/knowledge/error-handling.md +725 -0
  103. package/src/bmm/testarch/knowledge/feature-flags.md +750 -0
  104. package/src/bmm/testarch/knowledge/file-utils.md +463 -0
  105. package/src/bmm/testarch/knowledge/fixture-architecture.md +401 -0
  106. package/src/bmm/testarch/knowledge/fixtures-composition.md +382 -0
  107. package/src/bmm/testarch/knowledge/intercept-network-call.md +430 -0
  108. package/src/bmm/testarch/knowledge/log.md +429 -0
  109. package/src/bmm/testarch/knowledge/network-error-monitor.md +405 -0
  110. package/src/bmm/testarch/knowledge/network-first.md +486 -0
  111. package/src/bmm/testarch/knowledge/network-recorder.md +527 -0
  112. package/src/bmm/testarch/knowledge/nfr-criteria.md +670 -0
  113. package/src/bmm/testarch/knowledge/overview.md +286 -0
  114. package/src/bmm/testarch/knowledge/playwright-config.md +730 -0
  115. package/src/bmm/testarch/knowledge/probability-impact.md +601 -0
  116. package/src/bmm/testarch/knowledge/recurse.md +421 -0
  117. package/src/bmm/testarch/knowledge/risk-governance.md +615 -0
  118. package/src/bmm/testarch/knowledge/selective-testing.md +732 -0
  119. package/src/bmm/testarch/knowledge/selector-resilience.md +527 -0
  120. package/src/bmm/testarch/knowledge/test-healing-patterns.md +644 -0
  121. package/src/bmm/testarch/knowledge/test-levels-framework.md +473 -0
  122. package/src/bmm/testarch/knowledge/test-priorities-matrix.md +373 -0
  123. package/src/bmm/testarch/knowledge/test-quality.md +664 -0
  124. package/src/bmm/testarch/knowledge/timing-debugging.md +372 -0
  125. package/src/bmm/testarch/knowledge/visual-debugging.md +524 -0
  126. package/src/bmm/testarch/tea-index.csv +35 -0
  127. package/src/bmm/workflows/1-analysis/create-product-brief/product-brief.template.md +10 -0
  128. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-01-init.md +177 -0
  129. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +161 -0
  130. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +199 -0
  131. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-03-users.md +202 -0
  132. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +205 -0
  133. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +219 -0
  134. package/src/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +162 -0
  135. package/src/bmm/workflows/1-analysis/create-product-brief/workflow.md +58 -0
  136. package/src/bmm/workflows/1-analysis/research/domain-steps/step-01-init.md +137 -0
  137. package/src/bmm/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +229 -0
  138. package/src/bmm/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +238 -0
  139. package/src/bmm/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +206 -0
  140. package/src/bmm/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +234 -0
  141. package/src/bmm/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +443 -0
  142. package/src/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
  143. package/src/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
  144. package/src/bmm/workflows/1-analysis/research/market-steps/step-02-customer-insights.md +200 -0
  145. package/src/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
  146. package/src/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
  147. package/src/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
  148. package/src/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +475 -0
  149. package/src/bmm/workflows/1-analysis/research/research.template.md +29 -0
  150. package/src/bmm/workflows/1-analysis/research/technical-steps/step-01-init.md +137 -0
  151. package/src/bmm/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +239 -0
  152. package/src/bmm/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +248 -0
  153. package/src/bmm/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +202 -0
  154. package/src/bmm/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +239 -0
  155. package/src/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +486 -0
  156. package/src/bmm/workflows/1-analysis/research/workflow.md +173 -0
  157. package/src/bmm/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +13 -0
  158. package/src/bmm/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +197 -0
  159. package/src/bmm/workflows/2-plan-workflows/create-prd/data/project-types.csv +11 -0
  160. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01-init.md +191 -0
  161. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01b-continue.md +153 -0
  162. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02-discovery.md +224 -0
  163. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-03-success.md +226 -0
  164. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-04-journeys.md +213 -0
  165. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-05-domain.md +207 -0
  166. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-06-innovation.md +226 -0
  167. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-07-project-type.md +237 -0
  168. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-08-scoping.md +228 -0
  169. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-09-functional.md +231 -0
  170. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-10-nonfunctional.md +242 -0
  171. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-11-polish.md +217 -0
  172. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-12-complete.md +124 -0
  173. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01-discovery.md +247 -0
  174. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01b-legacy-conversion.md +208 -0
  175. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-02-review.md +249 -0
  176. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-03-edit.md +253 -0
  177. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-04-complete.md +168 -0
  178. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +218 -0
  179. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +191 -0
  180. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +209 -0
  181. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +174 -0
  182. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
  183. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +228 -0
  184. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +217 -0
  185. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
  186. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
  187. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +263 -0
  188. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +209 -0
  189. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
  190. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +242 -0
  191. package/src/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +231 -0
  192. package/src/bmm/workflows/2-plan-workflows/create-prd/templates/prd-template.md +10 -0
  193. package/src/bmm/workflows/2-plan-workflows/create-prd/validation-report-prd-workflow.md +433 -0
  194. package/src/bmm/workflows/2-plan-workflows/create-prd/workflow.md +150 -0
  195. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +135 -0
  196. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +127 -0
  197. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +190 -0
  198. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +216 -0
  199. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +219 -0
  200. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +234 -0
  201. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +252 -0
  202. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +254 -0
  203. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +224 -0
  204. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +224 -0
  205. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +241 -0
  206. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +248 -0
  207. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +237 -0
  208. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +264 -0
  209. package/src/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +171 -0
  210. package/src/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +13 -0
  211. package/src/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +43 -0
  212. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +190 -0
  213. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +178 -0
  214. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +179 -0
  215. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +139 -0
  216. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +252 -0
  217. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +135 -0
  218. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +4 -0
  219. package/src/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +55 -0
  220. package/src/bmm/workflows/3-solutioning/create-architecture/architecture-decision-template.md +12 -0
  221. package/src/bmm/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +11 -0
  222. package/src/bmm/workflows/3-solutioning/create-architecture/data/project-types.csv +7 -0
  223. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-01-init.md +153 -0
  224. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +164 -0
  225. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-02-context.md +224 -0
  226. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +331 -0
  227. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +318 -0
  228. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +359 -0
  229. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +379 -0
  230. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +359 -0
  231. package/src/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +76 -0
  232. package/src/bmm/workflows/3-solutioning/create-architecture/workflow.md +50 -0
  233. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +259 -0
  234. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +233 -0
  235. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +272 -0
  236. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +149 -0
  237. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +57 -0
  238. package/src/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +59 -0
  239. package/src/bmm/workflows/4-implementation/code-review/checklist.md +23 -0
  240. package/src/bmm/workflows/4-implementation/code-review/instructions.xml +227 -0
  241. package/src/bmm/workflows/4-implementation/code-review/workflow.yaml +51 -0
  242. package/src/bmm/workflows/4-implementation/correct-course/checklist.md +288 -0
  243. package/src/bmm/workflows/4-implementation/correct-course/instructions.md +206 -0
  244. package/src/bmm/workflows/4-implementation/correct-course/workflow.yaml +60 -0
  245. package/src/bmm/workflows/4-implementation/create-story/checklist.md +358 -0
  246. package/src/bmm/workflows/4-implementation/create-story/instructions.xml +345 -0
  247. package/src/bmm/workflows/4-implementation/create-story/template.md +49 -0
  248. package/src/bmm/workflows/4-implementation/create-story/workflow.yaml +61 -0
  249. package/src/bmm/workflows/4-implementation/dev-story/checklist.md +80 -0
  250. package/src/bmm/workflows/4-implementation/dev-story/instructions.xml +410 -0
  251. package/src/bmm/workflows/4-implementation/dev-story/workflow.yaml +27 -0
  252. package/src/bmm/workflows/4-implementation/retrospective/instructions.md +1443 -0
  253. package/src/bmm/workflows/4-implementation/retrospective/workflow.yaml +58 -0
  254. package/src/bmm/workflows/4-implementation/sprint-planning/checklist.md +33 -0
  255. package/src/bmm/workflows/4-implementation/sprint-planning/instructions.md +225 -0
  256. package/src/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +55 -0
  257. package/src/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +54 -0
  258. package/src/bmm/workflows/4-implementation/sprint-status/instructions.md +229 -0
  259. package/src/bmm/workflows/4-implementation/sprint-status/workflow.yaml +36 -0
  260. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +176 -0
  261. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +120 -0
  262. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +113 -0
  263. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +113 -0
  264. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +106 -0
  265. package/src/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +149 -0
  266. package/src/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +50 -0
  267. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-01-understand.md +192 -0
  268. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-02-investigate.md +145 -0
  269. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +128 -0
  270. package/src/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +201 -0
  271. package/src/bmm/workflows/bmad-quick-flow/quick-spec/tech-spec-template.md +74 -0
  272. package/src/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +79 -0
  273. package/src/bmm/workflows/document-project/checklist.md +245 -0
  274. package/src/bmm/workflows/document-project/documentation-requirements.csv +12 -0
  275. package/src/bmm/workflows/document-project/instructions.md +221 -0
  276. package/src/bmm/workflows/document-project/templates/deep-dive-template.md +345 -0
  277. package/src/bmm/workflows/document-project/templates/index-template.md +169 -0
  278. package/src/bmm/workflows/document-project/templates/project-overview-template.md +103 -0
  279. package/src/bmm/workflows/document-project/templates/project-scan-report-schema.json +160 -0
  280. package/src/bmm/workflows/document-project/templates/source-tree-template.md +135 -0
  281. package/src/bmm/workflows/document-project/workflow.yaml +30 -0
  282. package/src/bmm/workflows/document-project/workflows/deep-dive-instructions.md +298 -0
  283. package/src/bmm/workflows/document-project/workflows/deep-dive.yaml +31 -0
  284. package/src/bmm/workflows/document-project/workflows/full-scan-instructions.md +1106 -0
  285. package/src/bmm/workflows/document-project/workflows/full-scan.yaml +31 -0
  286. package/src/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-library.json +90 -0
  287. package/src/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-templates.yaml +127 -0
  288. package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/checklist.md +39 -0
  289. package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/instructions.md +130 -0
  290. package/src/bmm/workflows/excalidraw-diagrams/create-dataflow/workflow.yaml +27 -0
  291. package/src/bmm/workflows/excalidraw-diagrams/create-diagram/checklist.md +43 -0
  292. package/src/bmm/workflows/excalidraw-diagrams/create-diagram/instructions.md +141 -0
  293. package/src/bmm/workflows/excalidraw-diagrams/create-diagram/workflow.yaml +27 -0
  294. package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/checklist.md +49 -0
  295. package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/instructions.md +241 -0
  296. package/src/bmm/workflows/excalidraw-diagrams/create-flowchart/workflow.yaml +27 -0
  297. package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/checklist.md +38 -0
  298. package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/instructions.md +133 -0
  299. package/src/bmm/workflows/excalidraw-diagrams/create-wireframe/workflow.yaml +27 -0
  300. package/src/bmm/workflows/testarch/atdd/atdd-checklist-template.md +363 -0
  301. package/src/bmm/workflows/testarch/atdd/checklist.md +374 -0
  302. package/src/bmm/workflows/testarch/atdd/instructions.md +806 -0
  303. package/src/bmm/workflows/testarch/atdd/workflow.yaml +47 -0
  304. package/src/bmm/workflows/testarch/automate/checklist.md +582 -0
  305. package/src/bmm/workflows/testarch/automate/instructions.md +1324 -0
  306. package/src/bmm/workflows/testarch/automate/workflow.yaml +54 -0
  307. package/src/bmm/workflows/testarch/ci/checklist.md +247 -0
  308. package/src/bmm/workflows/testarch/ci/github-actions-template.yaml +198 -0
  309. package/src/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +149 -0
  310. package/src/bmm/workflows/testarch/ci/instructions.md +536 -0
  311. package/src/bmm/workflows/testarch/ci/workflow.yaml +47 -0
  312. package/src/bmm/workflows/testarch/framework/checklist.md +320 -0
  313. package/src/bmm/workflows/testarch/framework/instructions.md +481 -0
  314. package/src/bmm/workflows/testarch/framework/workflow.yaml +49 -0
  315. package/src/bmm/workflows/testarch/nfr-assess/checklist.md +407 -0
  316. package/src/bmm/workflows/testarch/nfr-assess/instructions.md +726 -0
  317. package/src/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +461 -0
  318. package/src/bmm/workflows/testarch/nfr-assess/workflow.yaml +49 -0
  319. package/src/bmm/workflows/testarch/test-design/checklist.md +407 -0
  320. package/src/bmm/workflows/testarch/test-design/instructions.md +1158 -0
  321. package/src/bmm/workflows/testarch/test-design/test-design-architecture-template.md +213 -0
  322. package/src/bmm/workflows/testarch/test-design/test-design-qa-template.md +286 -0
  323. package/src/bmm/workflows/testarch/test-design/test-design-template.md +294 -0
  324. package/src/bmm/workflows/testarch/test-design/workflow.yaml +71 -0
  325. package/src/bmm/workflows/testarch/test-review/checklist.md +472 -0
  326. package/src/bmm/workflows/testarch/test-review/instructions.md +628 -0
  327. package/src/bmm/workflows/testarch/test-review/test-review-template.md +390 -0
  328. package/src/bmm/workflows/testarch/test-review/workflow.yaml +48 -0
  329. package/src/bmm/workflows/testarch/trace/checklist.md +642 -0
  330. package/src/bmm/workflows/testarch/trace/instructions.md +1030 -0
  331. package/src/bmm/workflows/testarch/trace/trace-template.md +675 -0
  332. package/src/bmm/workflows/testarch/trace/workflow.yaml +57 -0
  333. package/src/core/_module-installer/installer.js +60 -0
  334. package/src/core/agents/bmad-master.agent.yaml +29 -0
  335. package/src/core/module-help.csv +9 -0
  336. package/src/core/module.yaml +25 -0
  337. package/src/core/resources/excalidraw/README.md +160 -0
  338. package/src/core/resources/excalidraw/excalidraw-helpers.md +127 -0
  339. package/src/core/resources/excalidraw/library-loader.md +50 -0
  340. package/src/core/resources/excalidraw/validate-json-instructions.md +79 -0
  341. package/src/core/tasks/editorial-review-prose.xml +100 -0
  342. package/src/core/tasks/editorial-review-structure.xml +209 -0
  343. package/src/core/tasks/help.md +62 -0
  344. package/src/core/tasks/index-docs.xml +65 -0
  345. package/src/core/tasks/review-adversarial-general.xml +48 -0
  346. package/src/core/tasks/shard-doc.xml +109 -0
  347. package/src/core/tasks/workflow.xml +235 -0
  348. package/src/core/workflows/advanced-elicitation/methods.csv +51 -0
  349. package/src/core/workflows/advanced-elicitation/workflow.xml +117 -0
  350. package/src/core/workflows/brainstorming/brain-methods.csv +62 -0
  351. package/src/core/workflows/brainstorming/steps/step-01-session-setup.md +197 -0
  352. package/src/core/workflows/brainstorming/steps/step-01b-continue.md +122 -0
  353. package/src/core/workflows/brainstorming/steps/step-02a-user-selected.md +225 -0
  354. package/src/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +237 -0
  355. package/src/core/workflows/brainstorming/steps/step-02c-random-selection.md +209 -0
  356. package/src/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +264 -0
  357. package/src/core/workflows/brainstorming/steps/step-03-technique-execution.md +399 -0
  358. package/src/core/workflows/brainstorming/steps/step-04-idea-organization.md +303 -0
  359. package/src/core/workflows/brainstorming/template.md +15 -0
  360. package/src/core/workflows/brainstorming/workflow.md +58 -0
  361. package/src/core/workflows/party-mode/steps/step-01-agent-loading.md +138 -0
  362. package/src/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +187 -0
  363. package/src/core/workflows/party-mode/steps/step-03-graceful-exit.md +157 -0
  364. package/src/core/workflows/party-mode/workflow.md +194 -0
  365. package/src/utility/agent-components/activation-rules.txt +6 -0
  366. package/src/utility/agent-components/activation-steps.txt +14 -0
  367. package/src/utility/agent-components/agent-command-header.md +1 -0
  368. package/src/utility/agent-components/agent.customize.template.yaml +41 -0
  369. package/src/utility/agent-components/handler-action.txt +4 -0
  370. package/src/utility/agent-components/handler-data.txt +5 -0
  371. package/src/utility/agent-components/handler-exec.txt +6 -0
  372. package/src/utility/agent-components/handler-multi.txt +14 -0
  373. package/src/utility/agent-components/handler-tmpl.txt +5 -0
  374. package/src/utility/agent-components/handler-validate-workflow.txt +7 -0
  375. package/src/utility/agent-components/handler-workflow.txt +10 -0
  376. package/src/utility/agent-components/menu-handlers.txt +6 -0
  377. package/test/README.md +295 -0
  378. package/test/adversarial-review-tests/README.md +56 -0
  379. package/test/adversarial-review-tests/sample-content.md +46 -0
  380. package/test/adversarial-review-tests/test-cases.yaml +103 -0
  381. package/test/fixtures/agent-schema/invalid/critical-actions/actions-as-string.agent.yaml +27 -0
  382. package/test/fixtures/agent-schema/invalid/critical-actions/empty-string-in-actions.agent.yaml +30 -0
  383. package/test/fixtures/agent-schema/invalid/menu/empty-menu.agent.yaml +22 -0
  384. package/test/fixtures/agent-schema/invalid/menu/missing-menu.agent.yaml +20 -0
  385. package/test/fixtures/agent-schema/invalid/menu-commands/empty-command-target.agent.yaml +25 -0
  386. package/test/fixtures/agent-schema/invalid/menu-commands/no-command-target.agent.yaml +24 -0
  387. package/test/fixtures/agent-schema/invalid/menu-triggers/camel-case.agent.yaml +25 -0
  388. package/test/fixtures/agent-schema/invalid/menu-triggers/compound-invalid-format.agent.yaml +25 -0
  389. package/test/fixtures/agent-schema/invalid/menu-triggers/compound-mismatched-kebab.agent.yaml +25 -0
  390. package/test/fixtures/agent-schema/invalid/menu-triggers/duplicate-triggers.agent.yaml +31 -0
  391. package/test/fixtures/agent-schema/invalid/menu-triggers/empty-trigger.agent.yaml +25 -0
  392. package/test/fixtures/agent-schema/invalid/menu-triggers/leading-asterisk.agent.yaml +25 -0
  393. package/test/fixtures/agent-schema/invalid/menu-triggers/snake-case.agent.yaml +25 -0
  394. package/test/fixtures/agent-schema/invalid/menu-triggers/trigger-with-spaces.agent.yaml +25 -0
  395. package/test/fixtures/agent-schema/invalid/metadata/empty-module-string.agent.yaml +26 -0
  396. package/test/fixtures/agent-schema/invalid/metadata/empty-name.agent.yaml +24 -0
  397. package/test/fixtures/agent-schema/invalid/metadata/extra-metadata-fields.agent.yaml +27 -0
  398. package/test/fixtures/agent-schema/invalid/metadata/missing-id.agent.yaml +23 -0
  399. package/test/fixtures/agent-schema/invalid/persona/empty-principles-array.agent.yaml +24 -0
  400. package/test/fixtures/agent-schema/invalid/persona/empty-string-in-principles.agent.yaml +27 -0
  401. package/test/fixtures/agent-schema/invalid/persona/extra-persona-fields.agent.yaml +27 -0
  402. package/test/fixtures/agent-schema/invalid/persona/missing-role.agent.yaml +24 -0
  403. package/test/fixtures/agent-schema/invalid/prompts/empty-content.agent.yaml +29 -0
  404. package/test/fixtures/agent-schema/invalid/prompts/extra-prompt-fields.agent.yaml +31 -0
  405. package/test/fixtures/agent-schema/invalid/prompts/missing-content.agent.yaml +28 -0
  406. package/test/fixtures/agent-schema/invalid/prompts/missing-id.agent.yaml +28 -0
  407. package/test/fixtures/agent-schema/invalid/top-level/empty-file.agent.yaml +5 -0
  408. package/test/fixtures/agent-schema/invalid/top-level/extra-top-level-keys.agent.yaml +28 -0
  409. package/test/fixtures/agent-schema/invalid/top-level/missing-agent-key.agent.yaml +11 -0
  410. package/test/fixtures/agent-schema/invalid/yaml-errors/invalid-indentation.agent.yaml +19 -0
  411. package/test/fixtures/agent-schema/invalid/yaml-errors/malformed-yaml.agent.yaml +18 -0
  412. package/test/fixtures/agent-schema/valid/critical-actions/empty-critical-actions.agent.yaml +24 -0
  413. package/test/fixtures/agent-schema/valid/critical-actions/no-critical-actions.agent.yaml +22 -0
  414. package/test/fixtures/agent-schema/valid/critical-actions/valid-critical-actions.agent.yaml +27 -0
  415. package/test/fixtures/agent-schema/valid/menu/multiple-menu-items.agent.yaml +31 -0
  416. package/test/fixtures/agent-schema/valid/menu/single-menu-item.agent.yaml +22 -0
  417. package/test/fixtures/agent-schema/valid/menu-commands/all-command-types.agent.yaml +38 -0
  418. package/test/fixtures/agent-schema/valid/menu-commands/multiple-commands.agent.yaml +24 -0
  419. package/test/fixtures/agent-schema/valid/menu-triggers/compound-triggers.agent.yaml +31 -0
  420. package/test/fixtures/agent-schema/valid/menu-triggers/kebab-case-triggers.agent.yaml +34 -0
  421. package/test/fixtures/agent-schema/valid/metadata/core-agent-with-module.agent.yaml +24 -0
  422. package/test/fixtures/agent-schema/valid/metadata/empty-module-name-in-path.agent.yaml +24 -0
  423. package/test/fixtures/agent-schema/valid/metadata/malformed-path-treated-as-core.agent.yaml +24 -0
  424. package/test/fixtures/agent-schema/valid/metadata/module-agent-correct.agent.yaml +24 -0
  425. package/test/fixtures/agent-schema/valid/metadata/module-agent-missing-module.agent.yaml +23 -0
  426. package/test/fixtures/agent-schema/valid/metadata/wrong-module-value.agent.yaml +24 -0
  427. package/test/fixtures/agent-schema/valid/persona/complete-persona.agent.yaml +24 -0
  428. package/test/fixtures/agent-schema/valid/prompts/empty-prompts.agent.yaml +24 -0
  429. package/test/fixtures/agent-schema/valid/prompts/no-prompts.agent.yaml +22 -0
  430. package/test/fixtures/agent-schema/valid/prompts/valid-prompts-minimal.agent.yaml +28 -0
  431. package/test/fixtures/agent-schema/valid/prompts/valid-prompts-with-description.agent.yaml +30 -0
  432. package/test/fixtures/agent-schema/valid/top-level/minimal-core-agent.agent.yaml +24 -0
  433. package/test/test-agent-schema.js +387 -0
  434. package/test/test-cli-integration.sh +159 -0
  435. package/test/test-installation-components.js +214 -0
  436. package/test/unit-test-schema.js +133 -0
  437. package/tools/bmad-npx-wrapper.js +11 -12
  438. package/tools/build-docs.js +577 -0
  439. package/tools/cli/README.md +7 -0
  440. package/tools/cli/bmad-cli.js +58 -0
  441. package/tools/cli/commands/install.js +87 -0
  442. package/tools/cli/commands/status.js +65 -0
  443. package/tools/cli/external-official-modules.yaml +44 -0
  444. package/tools/cli/installers/install-messages.yaml +58 -0
  445. package/tools/cli/installers/lib/core/config-collector.js +1079 -0
  446. package/tools/cli/installers/lib/core/custom-module-cache.js +259 -0
  447. package/tools/cli/installers/lib/core/dependency-resolver.js +739 -0
  448. package/tools/cli/installers/lib/core/detector.js +223 -0
  449. package/tools/cli/installers/lib/core/ide-config-manager.js +156 -0
  450. package/tools/cli/installers/lib/core/installer.js +2826 -0
  451. package/tools/cli/installers/lib/core/manifest-generator.js +1054 -0
  452. package/tools/cli/installers/lib/core/manifest.js +1036 -0
  453. package/tools/cli/installers/lib/custom/handler.js +363 -0
  454. package/tools/cli/installers/lib/ide/STANDARDIZATION_PLAN.md +208 -0
  455. package/tools/cli/installers/lib/ide/_base-ide.js +655 -0
  456. package/tools/cli/installers/lib/ide/antigravity.js +474 -0
  457. package/tools/cli/installers/lib/ide/auggie.js +244 -0
  458. package/tools/cli/installers/lib/ide/claude-code.js +506 -0
  459. package/tools/cli/installers/lib/ide/cline.js +272 -0
  460. package/tools/cli/installers/lib/ide/codex.js +412 -0
  461. package/tools/cli/installers/lib/ide/crush.js +149 -0
  462. package/tools/cli/installers/lib/ide/cursor.js +160 -0
  463. package/tools/cli/installers/lib/ide/gemini.js +301 -0
  464. package/tools/cli/installers/lib/ide/github-copilot.js +383 -0
  465. package/tools/cli/installers/lib/ide/iflow.js +191 -0
  466. package/tools/cli/installers/lib/ide/kilo.js +250 -0
  467. package/tools/cli/installers/lib/ide/kiro-cli.js +326 -0
  468. package/tools/cli/installers/lib/ide/manager.js +244 -0
  469. package/tools/cli/installers/lib/ide/opencode.js +257 -0
  470. package/tools/cli/installers/lib/ide/qwen.js +372 -0
  471. package/tools/cli/installers/lib/ide/roo.js +273 -0
  472. package/tools/cli/installers/lib/ide/rovo-dev.js +290 -0
  473. package/tools/cli/installers/lib/ide/shared/agent-command-generator.js +165 -0
  474. package/tools/cli/installers/lib/ide/shared/bmad-artifacts.js +158 -0
  475. package/tools/cli/installers/lib/ide/shared/module-injections.js +136 -0
  476. package/tools/cli/installers/lib/ide/shared/path-utils.js +165 -0
  477. package/tools/cli/installers/lib/ide/shared/task-tool-command-generator.js +268 -0
  478. package/tools/cli/installers/lib/ide/shared/workflow-command-generator.js +293 -0
  479. package/tools/cli/installers/lib/ide/templates/agent-command-template.md +14 -0
  480. package/tools/cli/installers/lib/ide/templates/gemini-agent-command.toml +14 -0
  481. package/tools/cli/installers/lib/ide/templates/gemini-task-command.toml +12 -0
  482. package/tools/cli/installers/lib/ide/templates/workflow-command-template.md +13 -0
  483. package/tools/cli/installers/lib/ide/templates/workflow-commander.md +5 -0
  484. package/tools/cli/installers/lib/ide/trae.js +313 -0
  485. package/tools/cli/installers/lib/ide/windsurf.js +258 -0
  486. package/tools/cli/installers/lib/message-loader.js +85 -0
  487. package/tools/cli/installers/lib/modules/external-manager.js +135 -0
  488. package/tools/cli/installers/lib/modules/manager.js +1375 -0
  489. package/tools/cli/lib/activation-builder.js +163 -0
  490. package/tools/cli/lib/agent/compiler.js +522 -0
  491. package/tools/cli/lib/agent/installer.js +716 -0
  492. package/tools/cli/lib/agent/template-engine.js +152 -0
  493. package/tools/cli/lib/agent-analyzer.js +109 -0
  494. package/tools/cli/lib/agent-party-generator.js +194 -0
  495. package/tools/cli/lib/cli-utils.js +227 -0
  496. package/tools/cli/lib/config.js +213 -0
  497. package/tools/cli/lib/file-ops.js +204 -0
  498. package/tools/cli/lib/platform-codes.js +116 -0
  499. package/tools/cli/lib/project-root.js +77 -0
  500. package/tools/cli/lib/prompts.js +433 -0
  501. package/tools/cli/lib/ui.js +1716 -0
  502. package/tools/cli/lib/xml-handler.js +177 -0
  503. package/tools/cli/lib/xml-to-markdown.js +82 -0
  504. package/tools/{yaml-format.js → cli/lib/yaml-format.js} +9 -17
  505. package/tools/cli/lib/yaml-xml-builder.js +587 -0
  506. package/tools/docs/BUNDLE_DISTRIBUTION_SETUP.md +95 -0
  507. package/tools/docs/fix-refs.md +91 -0
  508. package/tools/docs/index.md +2 -0
  509. package/tools/fix-doc-links.js +288 -0
  510. package/tools/flattener/ignoreRules.js +2 -6
  511. package/tools/flattener/main.js +31 -121
  512. package/tools/flattener/projectRoot.js +3 -8
  513. package/tools/flattener/stats.helpers.js +8 -35
  514. package/tools/flattener/stats.js +1 -6
  515. package/tools/flattener/test-matrix.js +1 -5
  516. package/tools/flattener/xml.js +1 -7
  517. package/tools/format-workflow-md.js +263 -0
  518. package/tools/lib/xml-utils.js +13 -0
  519. package/tools/maintainer/review-pr-README.md +55 -0
  520. package/tools/maintainer/review-pr.md +242 -0
  521. package/tools/migrate-custom-module-paths.js +124 -0
  522. package/tools/platform-codes.yaml +157 -0
  523. package/tools/schema/agent.js +491 -0
  524. package/tools/validate-agent-schema.js +110 -0
  525. package/tools/validate-doc-links.js +371 -0
  526. package/tools/validate-svg-changes.sh +356 -0
  527. package/website/README.md +76 -0
  528. package/website/_basement/components/WorkflowGuide.astro +444 -0
  529. package/website/_basement/pages/workflow-guide.astro +17 -0
  530. package/website/astro.config.mjs +169 -0
  531. package/website/public/favicon.ico +0 -0
  532. package/website/public/img/bmad-dark.png +0 -0
  533. package/website/public/img/bmad-light.png +0 -0
  534. package/website/public/img/logo.svg +4 -0
  535. package/website/public/img/workflow-map.png +0 -0
  536. package/website/public/robots.txt +37 -0
  537. package/website/public/workflow-map-diagram.html +361 -0
  538. package/website/src/components/Banner.astro +59 -0
  539. package/website/src/components/Header.astro +121 -0
  540. package/website/src/components/MobileMenuFooter.astro +53 -0
  541. package/website/src/content/config.ts +6 -0
  542. package/website/src/lib/site-url.js +25 -0
  543. package/website/src/pages/404.astro +11 -0
  544. package/website/src/rehype-base-paths.js +89 -0
  545. package/website/src/rehype-markdown-links.js +117 -0
  546. package/website/src/styles/custom.css +500 -0
  547. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -32
  548. package/.github/workflows/format-check.yaml +0 -42
  549. package/bmad-core/agent-teams/team-all.yaml +0 -14
  550. package/bmad-core/agent-teams/team-fullstack.yaml +0 -18
  551. package/bmad-core/agent-teams/team-ide-minimal.yaml +0 -10
  552. package/bmad-core/agent-teams/team-no-ui.yaml +0 -13
  553. package/bmad-core/agents/analyst.md +0 -81
  554. package/bmad-core/agents/architect.md +0 -83
  555. package/bmad-core/agents/bmad-master.md +0 -107
  556. package/bmad-core/agents/bmad-orchestrator.md +0 -149
  557. package/bmad-core/agents/dev.md +0 -75
  558. package/bmad-core/agents/pm.md +0 -81
  559. package/bmad-core/agents/po.md +0 -76
  560. package/bmad-core/agents/qa.md +0 -88
  561. package/bmad-core/agents/sm.md +0 -62
  562. package/bmad-core/agents/ux-expert.md +0 -66
  563. package/bmad-core/checklists/architect-checklist.md +0 -438
  564. package/bmad-core/checklists/change-checklist.md +0 -182
  565. package/bmad-core/checklists/pm-checklist.md +0 -370
  566. package/bmad-core/checklists/po-master-checklist.md +0 -432
  567. package/bmad-core/checklists/story-dod-checklist.md +0 -94
  568. package/bmad-core/checklists/story-draft-checklist.md +0 -153
  569. package/bmad-core/core-config.yaml +0 -20
  570. package/bmad-core/data/bmad-kb.md +0 -806
  571. package/bmad-core/data/brainstorming-techniques.md +0 -36
  572. package/bmad-core/data/elicitation-methods.md +0 -154
  573. package/bmad-core/data/technical-preferences.md +0 -3
  574. package/bmad-core/data/test-levels-framework.md +0 -146
  575. package/bmad-core/data/test-priorities-matrix.md +0 -172
  576. package/bmad-core/tasks/advanced-elicitation.md +0 -117
  577. package/bmad-core/tasks/brownfield-create-epic.md +0 -160
  578. package/bmad-core/tasks/brownfield-create-story.md +0 -147
  579. package/bmad-core/tasks/correct-course.md +0 -70
  580. package/bmad-core/tasks/create-brownfield-story.md +0 -312
  581. package/bmad-core/tasks/create-deep-research-prompt.md +0 -278
  582. package/bmad-core/tasks/create-next-story.md +0 -112
  583. package/bmad-core/tasks/document-project.md +0 -343
  584. package/bmad-core/tasks/facilitate-brainstorming-session.md +0 -136
  585. package/bmad-core/tasks/generate-ai-frontend-prompt.md +0 -51
  586. package/bmad-core/tasks/index-docs.md +0 -173
  587. package/bmad-core/tasks/kb-mode-interaction.md +0 -75
  588. package/bmad-core/tasks/nfr-assess.md +0 -343
  589. package/bmad-core/tasks/qa-gate.md +0 -159
  590. package/bmad-core/tasks/review-story.md +0 -314
  591. package/bmad-core/tasks/risk-profile.md +0 -353
  592. package/bmad-core/tasks/shard-doc.md +0 -185
  593. package/bmad-core/tasks/test-design.md +0 -174
  594. package/bmad-core/tasks/trace-requirements.md +0 -264
  595. package/bmad-core/tasks/validate-next-story.md +0 -134
  596. package/bmad-core/templates/architecture-tmpl.yaml +0 -650
  597. package/bmad-core/templates/brainstorming-output-tmpl.yaml +0 -156
  598. package/bmad-core/templates/brownfield-architecture-tmpl.yaml +0 -476
  599. package/bmad-core/templates/brownfield-prd-tmpl.yaml +0 -280
  600. package/bmad-core/templates/competitor-analysis-tmpl.yaml +0 -306
  601. package/bmad-core/templates/front-end-architecture-tmpl.yaml +0 -218
  602. package/bmad-core/templates/front-end-spec-tmpl.yaml +0 -349
  603. package/bmad-core/templates/fullstack-architecture-tmpl.yaml +0 -823
  604. package/bmad-core/templates/market-research-tmpl.yaml +0 -252
  605. package/bmad-core/templates/prd-tmpl.yaml +0 -202
  606. package/bmad-core/templates/project-brief-tmpl.yaml +0 -221
  607. package/bmad-core/templates/qa-gate-tmpl.yaml +0 -102
  608. package/bmad-core/templates/story-tmpl.yaml +0 -137
  609. package/bmad-core/workflows/brownfield-fullstack.yaml +0 -297
  610. package/bmad-core/workflows/brownfield-service.yaml +0 -187
  611. package/bmad-core/workflows/brownfield-ui.yaml +0 -197
  612. package/bmad-core/workflows/greenfield-fullstack.yaml +0 -240
  613. package/bmad-core/workflows/greenfield-service.yaml +0 -206
  614. package/bmad-core/workflows/greenfield-ui.yaml +0 -235
  615. package/common/tasks/create-doc.md +0 -101
  616. package/common/tasks/execute-checklist.md +0 -86
  617. package/common/utils/bmad-doc-template.md +0 -325
  618. package/common/utils/workflow-management.md +0 -69
  619. package/dist/agents/analyst.txt +0 -2889
  620. package/dist/agents/architect.txt +0 -3552
  621. package/dist/agents/bmad-master.txt +0 -8769
  622. package/dist/agents/bmad-orchestrator.txt +0 -1513
  623. package/dist/agents/dev.txt +0 -414
  624. package/dist/agents/pm.txt +0 -2204
  625. package/dist/agents/po.txt +0 -1346
  626. package/dist/agents/qa.txt +0 -1987
  627. package/dist/agents/sm.txt +0 -658
  628. package/dist/agents/ux-expert.txt +0 -694
  629. package/dist/expansion-packs/bmad-2d-phaser-game-dev/agents/game-designer.txt +0 -2371
  630. package/dist/expansion-packs/bmad-2d-phaser-game-dev/agents/game-developer.txt +0 -1620
  631. package/dist/expansion-packs/bmad-2d-phaser-game-dev/agents/game-sm.txt +0 -815
  632. package/dist/expansion-packs/bmad-2d-phaser-game-dev/teams/phaser-2d-nodejs-game-team.txt +0 -10952
  633. package/dist/expansion-packs/bmad-2d-unity-game-dev/agents/game-architect.txt +0 -4012
  634. package/dist/expansion-packs/bmad-2d-unity-game-dev/agents/game-designer.txt +0 -3698
  635. package/dist/expansion-packs/bmad-2d-unity-game-dev/agents/game-developer.txt +0 -450
  636. package/dist/expansion-packs/bmad-2d-unity-game-dev/agents/game-sm.txt +0 -973
  637. package/dist/expansion-packs/bmad-2d-unity-game-dev/teams/unity-2d-game-team.txt +0 -15376
  638. package/dist/expansion-packs/bmad-infrastructure-devops/agents/infra-devops-platform.txt +0 -2075
  639. package/dist/teams/team-all.txt +0 -12682
  640. package/dist/teams/team-fullstack.txt +0 -10421
  641. package/dist/teams/team-ide-minimal.txt +0 -5103
  642. package/dist/teams/team-no-ui.txt +0 -8980
  643. package/docs/GUIDING-PRINCIPLES.md +0 -91
  644. package/docs/core-architecture.md +0 -219
  645. package/docs/enhanced-ide-development-workflow.md +0 -248
  646. package/docs/expansion-packs.md +0 -280
  647. package/docs/how-to-contribute-with-pull-requests.md +0 -158
  648. package/docs/user-guide.md +0 -504
  649. package/docs/versioning-and-releases.md +0 -147
  650. package/docs/versions.md +0 -48
  651. package/docs/working-in-the-brownfield.md +0 -597
  652. package/expansion-packs/Complete AI Agent System - Blank Templates & Google Cloud Setup/Complete AI Agent System - Flowchart.svg +0 -102
  653. package/expansion-packs/Complete AI Agent System - Blank Templates & Google Cloud Setup/PART 1 - Google Cloud Vertex AI Setup Documentation/1.1 Google Cloud Project Setup/1.1.1 - Initial Project Configuration - bash copy.txt +0 -13
  654. package/expansion-packs/Complete AI Agent System - Blank Templates & Google Cloud Setup/PART 1 - Google Cloud Vertex AI Setup Documentation/1.1 Google Cloud Project Setup/1.1.1 - Initial Project Configuration - bash.txt +0 -13
  655. package/expansion-packs/Complete AI Agent System - Blank Templates & Google Cloud Setup/PART 1 - Google Cloud Vertex AI Setup Documentation/1.2 Agent Development Kit Installation/1.2.2 - Basic Project Structure - txt.txt +0 -25
  656. package/expansion-packs/Complete AI Agent System - Blank Templates & Google Cloud Setup/PART 1 - Google Cloud Vertex AI Setup Documentation/1.3 Core Configuration Files/1.3.1 - settings.py +0 -34
  657. package/expansion-packs/Complete AI Agent System - Blank Templates & Google Cloud Setup/PART 1 - Google Cloud Vertex AI Setup Documentation/1.3 Core Configuration Files/1.3.2 - main.py - Base Application.py +0 -70
  658. package/expansion-packs/Complete AI Agent System - Blank Templates & Google Cloud Setup/PART 1 - Google Cloud Vertex AI Setup Documentation/1.4 Deployment Configuration/1.4.2 - cloudbuild.yaml +0 -26
  659. package/expansion-packs/Complete AI Agent System - Blank Templates & Google Cloud Setup/README.md +0 -109
  660. package/expansion-packs/README.md +0 -3
  661. package/expansion-packs/bmad-2d-phaser-game-dev/agent-teams/phaser-2d-nodejs-game-team.yaml +0 -13
  662. package/expansion-packs/bmad-2d-phaser-game-dev/agents/game-designer.md +0 -71
  663. package/expansion-packs/bmad-2d-phaser-game-dev/agents/game-developer.md +0 -78
  664. package/expansion-packs/bmad-2d-phaser-game-dev/agents/game-sm.md +0 -64
  665. package/expansion-packs/bmad-2d-phaser-game-dev/checklists/game-design-checklist.md +0 -201
  666. package/expansion-packs/bmad-2d-phaser-game-dev/checklists/game-story-dod-checklist.md +0 -160
  667. package/expansion-packs/bmad-2d-phaser-game-dev/config.yaml +0 -8
  668. package/expansion-packs/bmad-2d-phaser-game-dev/data/bmad-kb.md +0 -250
  669. package/expansion-packs/bmad-2d-phaser-game-dev/data/development-guidelines.md +0 -647
  670. package/expansion-packs/bmad-2d-phaser-game-dev/tasks/advanced-elicitation.md +0 -110
  671. package/expansion-packs/bmad-2d-phaser-game-dev/tasks/create-game-story.md +0 -216
  672. package/expansion-packs/bmad-2d-phaser-game-dev/tasks/game-design-brainstorming.md +0 -290
  673. package/expansion-packs/bmad-2d-phaser-game-dev/templates/game-architecture-tmpl.yaml +0 -613
  674. package/expansion-packs/bmad-2d-phaser-game-dev/templates/game-brief-tmpl.yaml +0 -356
  675. package/expansion-packs/bmad-2d-phaser-game-dev/templates/game-design-doc-tmpl.yaml +0 -343
  676. package/expansion-packs/bmad-2d-phaser-game-dev/templates/game-story-tmpl.yaml +0 -253
  677. package/expansion-packs/bmad-2d-phaser-game-dev/templates/level-design-doc-tmpl.yaml +0 -484
  678. package/expansion-packs/bmad-2d-phaser-game-dev/workflows/game-dev-greenfield.yaml +0 -183
  679. package/expansion-packs/bmad-2d-phaser-game-dev/workflows/game-prototype.yaml +0 -175
  680. package/expansion-packs/bmad-2d-unity-game-dev/agent-teams/unity-2d-game-team.yaml +0 -14
  681. package/expansion-packs/bmad-2d-unity-game-dev/agents/game-architect.md +0 -80
  682. package/expansion-packs/bmad-2d-unity-game-dev/agents/game-designer.md +0 -77
  683. package/expansion-packs/bmad-2d-unity-game-dev/agents/game-developer.md +0 -78
  684. package/expansion-packs/bmad-2d-unity-game-dev/agents/game-sm.md +0 -65
  685. package/expansion-packs/bmad-2d-unity-game-dev/checklists/game-architect-checklist.md +0 -391
  686. package/expansion-packs/bmad-2d-unity-game-dev/checklists/game-change-checklist.md +0 -203
  687. package/expansion-packs/bmad-2d-unity-game-dev/checklists/game-design-checklist.md +0 -201
  688. package/expansion-packs/bmad-2d-unity-game-dev/checklists/game-story-dod-checklist.md +0 -124
  689. package/expansion-packs/bmad-2d-unity-game-dev/config.yaml +0 -6
  690. package/expansion-packs/bmad-2d-unity-game-dev/data/bmad-kb.md +0 -769
  691. package/expansion-packs/bmad-2d-unity-game-dev/data/development-guidelines.md +0 -586
  692. package/expansion-packs/bmad-2d-unity-game-dev/tasks/advanced-elicitation.md +0 -110
  693. package/expansion-packs/bmad-2d-unity-game-dev/tasks/correct-course-game.md +0 -141
  694. package/expansion-packs/bmad-2d-unity-game-dev/tasks/create-game-story.md +0 -184
  695. package/expansion-packs/bmad-2d-unity-game-dev/tasks/game-design-brainstorming.md +0 -290
  696. package/expansion-packs/bmad-2d-unity-game-dev/tasks/validate-game-story.md +0 -200
  697. package/expansion-packs/bmad-2d-unity-game-dev/templates/game-architecture-tmpl.yaml +0 -1030
  698. package/expansion-packs/bmad-2d-unity-game-dev/templates/game-brief-tmpl.yaml +0 -356
  699. package/expansion-packs/bmad-2d-unity-game-dev/templates/game-design-doc-tmpl.yaml +0 -705
  700. package/expansion-packs/bmad-2d-unity-game-dev/templates/game-story-tmpl.yaml +0 -256
  701. package/expansion-packs/bmad-2d-unity-game-dev/templates/level-design-doc-tmpl.yaml +0 -484
  702. package/expansion-packs/bmad-2d-unity-game-dev/workflows/game-dev-greenfield.yaml +0 -183
  703. package/expansion-packs/bmad-2d-unity-game-dev/workflows/game-prototype.yaml +0 -175
  704. package/expansion-packs/bmad-infrastructure-devops/README.md +0 -147
  705. package/expansion-packs/bmad-infrastructure-devops/agents/infra-devops-platform.md +0 -71
  706. package/expansion-packs/bmad-infrastructure-devops/checklists/infrastructure-checklist.md +0 -484
  707. package/expansion-packs/bmad-infrastructure-devops/config.yaml +0 -9
  708. package/expansion-packs/bmad-infrastructure-devops/data/bmad-kb.md +0 -305
  709. package/expansion-packs/bmad-infrastructure-devops/tasks/review-infrastructure.md +0 -159
  710. package/expansion-packs/bmad-infrastructure-devops/tasks/validate-infrastructure.md +0 -153
  711. package/expansion-packs/bmad-infrastructure-devops/templates/infrastructure-architecture-tmpl.yaml +0 -424
  712. package/expansion-packs/bmad-infrastructure-devops/templates/infrastructure-platform-from-arch-tmpl.yaml +0 -629
  713. package/release_notes.md +0 -33
  714. package/tools/builders/web-builder.js +0 -675
  715. package/tools/bump-all-versions.js +0 -115
  716. package/tools/bump-expansion-version.js +0 -90
  717. package/tools/cli.js +0 -152
  718. package/tools/installer/README.md +0 -8
  719. package/tools/installer/bin/bmad.js +0 -585
  720. package/tools/installer/config/ide-agent-config.yaml +0 -58
  721. package/tools/installer/config/install.config.yaml +0 -123
  722. package/tools/installer/lib/config-loader.js +0 -257
  723. package/tools/installer/lib/file-manager.js +0 -389
  724. package/tools/installer/lib/ide-base-setup.js +0 -228
  725. package/tools/installer/lib/ide-setup.js +0 -1441
  726. package/tools/installer/lib/installer.js +0 -1995
  727. package/tools/installer/lib/memory-profiler.js +0 -225
  728. package/tools/installer/lib/module-manager.js +0 -114
  729. package/tools/installer/lib/resource-locator.js +0 -308
  730. package/tools/installer/package.json +0 -44
  731. package/tools/lib/dependency-resolver.js +0 -175
  732. package/tools/lib/yaml-utils.js +0 -29
  733. package/tools/md-assets/web-agent-startup-instructions.md +0 -39
  734. package/tools/preview-release-notes.js +0 -66
  735. package/tools/shared/bannerArt.js +0 -105
  736. package/tools/sync-installer-version.js +0 -32
  737. package/tools/update-expansion-version.js +0 -53
  738. package/tools/upgraders/v3-to-v4-upgrader.js +0 -672
  739. package/tools/version-bump.js +0 -94
@@ -0,0 +1,843 @@
1
+ # API Testing Patterns
2
+
3
+ ## Principle
4
+
5
+ Test APIs and backend services directly without browser overhead. Use Playwright's `request` context for HTTP operations, `apiRequest` utility for enhanced features, and `recurse` for async operations. Pure API tests run faster, are more stable, and provide better coverage for service-layer logic.
6
+
7
+ ## Rationale
8
+
9
+ Many teams over-rely on E2E/browser tests when API tests would be more appropriate:
10
+
11
+ - **Slower feedback**: Browser tests take seconds, API tests take milliseconds
12
+ - **More brittle**: UI changes break tests even when API works correctly
13
+ - **Wrong abstraction**: Testing business logic through UI layers adds noise
14
+ - **Resource heavy**: Browsers consume memory and CPU
15
+
16
+ API-first testing provides:
17
+
18
+ - **Fast execution**: No browser startup, no rendering, no JavaScript execution
19
+ - **Direct validation**: Test exactly what the service returns
20
+ - **Better isolation**: Test service logic independent of UI
21
+ - **Easier debugging**: Clear request/response without DOM noise
22
+ - **Contract validation**: Verify API contracts explicitly
23
+
24
+ ## When to Use API Tests vs E2E Tests
25
+
26
+ | Scenario | API Test | E2E Test |
27
+ |----------|----------|----------|
28
+ | CRUD operations | ✅ Primary | ❌ Overkill |
29
+ | Business logic validation | ✅ Primary | ❌ Overkill |
30
+ | Error handling (4xx, 5xx) | ✅ Primary | ⚠️ Supplement |
31
+ | Authentication flows | ✅ Primary | ⚠️ Supplement |
32
+ | Data transformation | ✅ Primary | ❌ Overkill |
33
+ | User journeys | ❌ Can't test | ✅ Primary |
34
+ | Visual regression | ❌ Can't test | ✅ Primary |
35
+ | Cross-browser issues | ❌ Can't test | ✅ Primary |
36
+
37
+ **Rule of thumb**: If you're testing what the server returns (not how it looks), use API tests.
38
+
39
+ ## Pattern Examples
40
+
41
+ ### Example 1: Pure API Test (No Browser)
42
+
43
+ **Context**: Test REST API endpoints directly without any browser context.
44
+
45
+ **Implementation**:
46
+
47
+ ```typescript
48
+ // tests/api/users.spec.ts
49
+ import { test, expect } from '@playwright/test';
50
+
51
+ // No page, no browser - just API
52
+ test.describe('Users API', () => {
53
+ test('should create user', async ({ request }) => {
54
+ const response = await request.post('/api/users', {
55
+ data: {
56
+ name: 'John Doe',
57
+ email: 'john@example.com',
58
+ role: 'user',
59
+ },
60
+ });
61
+
62
+ expect(response.status()).toBe(201);
63
+
64
+ const user = await response.json();
65
+ expect(user.id).toBeDefined();
66
+ expect(user.name).toBe('John Doe');
67
+ expect(user.email).toBe('john@example.com');
68
+ });
69
+
70
+ test('should get user by ID', async ({ request }) => {
71
+ // Create user first
72
+ const createResponse = await request.post('/api/users', {
73
+ data: { name: 'Jane Doe', email: 'jane@example.com' },
74
+ });
75
+ const { id } = await createResponse.json();
76
+
77
+ // Get user
78
+ const getResponse = await request.get(`/api/users/${id}`);
79
+ expect(getResponse.status()).toBe(200);
80
+
81
+ const user = await getResponse.json();
82
+ expect(user.id).toBe(id);
83
+ expect(user.name).toBe('Jane Doe');
84
+ });
85
+
86
+ test('should return 404 for non-existent user', async ({ request }) => {
87
+ const response = await request.get('/api/users/non-existent-id');
88
+ expect(response.status()).toBe(404);
89
+
90
+ const error = await response.json();
91
+ expect(error.code).toBe('USER_NOT_FOUND');
92
+ });
93
+
94
+ test('should validate required fields', async ({ request }) => {
95
+ const response = await request.post('/api/users', {
96
+ data: { name: 'Missing Email' }, // email is required
97
+ });
98
+
99
+ expect(response.status()).toBe(400);
100
+
101
+ const error = await response.json();
102
+ expect(error.code).toBe('VALIDATION_ERROR');
103
+ expect(error.details).toContainEqual(
104
+ expect.objectContaining({ field: 'email', message: expect.any(String) })
105
+ );
106
+ });
107
+ });
108
+ ```
109
+
110
+ **Key Points**:
111
+
112
+ - No `page` fixture needed - only `request`
113
+ - Tests run without browser overhead
114
+ - Direct HTTP assertions
115
+ - Clear error handling tests
116
+
117
+ ### Example 2: API Test with apiRequest Utility
118
+
119
+ **Context**: Use enhanced apiRequest for schema validation, retry, and type safety.
120
+
121
+ **Implementation**:
122
+
123
+ ```typescript
124
+ // tests/api/orders.spec.ts
125
+ import { test, expect } from '@seontechnologies/playwright-utils/api-request/fixtures';
126
+ import { z } from 'zod';
127
+
128
+ // Define schema for type safety and validation
129
+ const OrderSchema = z.object({
130
+ id: z.string().uuid(),
131
+ userId: z.string(),
132
+ items: z.array(
133
+ z.object({
134
+ productId: z.string(),
135
+ quantity: z.number().positive(),
136
+ price: z.number().positive(),
137
+ })
138
+ ),
139
+ total: z.number().positive(),
140
+ status: z.enum(['pending', 'processing', 'shipped', 'delivered']),
141
+ createdAt: z.string().datetime(),
142
+ });
143
+
144
+ type Order = z.infer<typeof OrderSchema>;
145
+
146
+ test.describe('Orders API', () => {
147
+ test('should create order with schema validation', async ({ apiRequest }) => {
148
+ const { status, body } = await apiRequest<Order>({
149
+ method: 'POST',
150
+ path: '/api/orders',
151
+ body: {
152
+ userId: 'user-123',
153
+ items: [
154
+ { productId: 'prod-1', quantity: 2, price: 29.99 },
155
+ { productId: 'prod-2', quantity: 1, price: 49.99 },
156
+ ],
157
+ },
158
+ validateSchema: OrderSchema, // Validates response matches schema
159
+ });
160
+
161
+ expect(status).toBe(201);
162
+ expect(body.id).toBeDefined();
163
+ expect(body.status).toBe('pending');
164
+ expect(body.total).toBe(109.97); // 2*29.99 + 49.99
165
+ });
166
+
167
+ test('should handle server errors with retry', async ({ apiRequest }) => {
168
+ // apiRequest retries 5xx errors by default
169
+ const { status, body } = await apiRequest({
170
+ method: 'GET',
171
+ path: '/api/orders/order-123',
172
+ retryConfig: {
173
+ maxRetries: 3,
174
+ retryDelay: 1000,
175
+ },
176
+ });
177
+
178
+ expect(status).toBe(200);
179
+ });
180
+
181
+ test('should list orders with pagination', async ({ apiRequest }) => {
182
+ const { status, body } = await apiRequest<{ orders: Order[]; total: number; page: number }>({
183
+ method: 'GET',
184
+ path: '/api/orders',
185
+ params: { page: 1, limit: 10, status: 'pending' },
186
+ });
187
+
188
+ expect(status).toBe(200);
189
+ expect(body.orders).toHaveLength(10);
190
+ expect(body.total).toBeGreaterThan(10);
191
+ expect(body.page).toBe(1);
192
+ });
193
+ });
194
+ ```
195
+
196
+ **Key Points**:
197
+
198
+ - Zod schema for runtime validation AND TypeScript types
199
+ - `validateSchema` throws if response doesn't match
200
+ - Built-in retry for transient failures
201
+ - Type-safe `body` access
202
+
203
+ ### Example 3: Microservice-to-Microservice Testing
204
+
205
+ **Context**: Test service interactions without browser - validate API contracts between services.
206
+
207
+ **Implementation**:
208
+
209
+ ```typescript
210
+ // tests/api/service-integration.spec.ts
211
+ import { test, expect } from '@seontechnologies/playwright-utils/fixtures';
212
+
213
+ test.describe('Service Integration', () => {
214
+ const USER_SERVICE_URL = process.env.USER_SERVICE_URL || 'http://localhost:3001';
215
+ const ORDER_SERVICE_URL = process.env.ORDER_SERVICE_URL || 'http://localhost:3002';
216
+ const INVENTORY_SERVICE_URL = process.env.INVENTORY_SERVICE_URL || 'http://localhost:3003';
217
+
218
+ test('order service should validate user exists', async ({ apiRequest }) => {
219
+ // Create user in user-service
220
+ const { body: user } = await apiRequest({
221
+ method: 'POST',
222
+ path: '/api/users',
223
+ baseUrl: USER_SERVICE_URL,
224
+ body: { name: 'Test User', email: 'test@example.com' },
225
+ });
226
+
227
+ // Create order in order-service (should validate user via user-service)
228
+ const { status, body: order } = await apiRequest({
229
+ method: 'POST',
230
+ path: '/api/orders',
231
+ baseUrl: ORDER_SERVICE_URL,
232
+ body: {
233
+ userId: user.id,
234
+ items: [{ productId: 'prod-1', quantity: 1 }],
235
+ },
236
+ });
237
+
238
+ expect(status).toBe(201);
239
+ expect(order.userId).toBe(user.id);
240
+ });
241
+
242
+ test('order service should reject invalid user', async ({ apiRequest }) => {
243
+ const { status, body } = await apiRequest({
244
+ method: 'POST',
245
+ path: '/api/orders',
246
+ baseUrl: ORDER_SERVICE_URL,
247
+ body: {
248
+ userId: 'non-existent-user',
249
+ items: [{ productId: 'prod-1', quantity: 1 }],
250
+ },
251
+ });
252
+
253
+ expect(status).toBe(400);
254
+ expect(body.code).toBe('INVALID_USER');
255
+ });
256
+
257
+ test('order should decrease inventory', async ({ apiRequest, recurse }) => {
258
+ // Get initial inventory
259
+ const { body: initialInventory } = await apiRequest({
260
+ method: 'GET',
261
+ path: '/api/inventory/prod-1',
262
+ baseUrl: INVENTORY_SERVICE_URL,
263
+ });
264
+
265
+ // Create order
266
+ await apiRequest({
267
+ method: 'POST',
268
+ path: '/api/orders',
269
+ baseUrl: ORDER_SERVICE_URL,
270
+ body: {
271
+ userId: 'user-123',
272
+ items: [{ productId: 'prod-1', quantity: 2 }],
273
+ },
274
+ });
275
+
276
+ // Poll for inventory update (eventual consistency)
277
+ const { body: updatedInventory } = await recurse(
278
+ () =>
279
+ apiRequest({
280
+ method: 'GET',
281
+ path: '/api/inventory/prod-1',
282
+ baseUrl: INVENTORY_SERVICE_URL,
283
+ }),
284
+ (response) => response.body.quantity === initialInventory.quantity - 2,
285
+ { timeout: 10000, interval: 500 }
286
+ );
287
+
288
+ expect(updatedInventory.quantity).toBe(initialInventory.quantity - 2);
289
+ });
290
+ });
291
+ ```
292
+
293
+ **Key Points**:
294
+
295
+ - Multiple service URLs for microservice testing
296
+ - Tests service-to-service communication
297
+ - Uses `recurse` for eventual consistency
298
+ - No browser needed for full integration testing
299
+
300
+ ### Example 4: GraphQL API Testing
301
+
302
+ **Context**: Test GraphQL endpoints with queries and mutations.
303
+
304
+ **Implementation**:
305
+
306
+ ```typescript
307
+ // tests/api/graphql.spec.ts
308
+ import { test, expect } from '@seontechnologies/playwright-utils/api-request/fixtures';
309
+
310
+ const GRAPHQL_ENDPOINT = '/graphql';
311
+
312
+ test.describe('GraphQL API', () => {
313
+ test('should query users', async ({ apiRequest }) => {
314
+ const query = `
315
+ query GetUsers($limit: Int) {
316
+ users(limit: $limit) {
317
+ id
318
+ name
319
+ email
320
+ role
321
+ }
322
+ }
323
+ `;
324
+
325
+ const { status, body } = await apiRequest({
326
+ method: 'POST',
327
+ path: GRAPHQL_ENDPOINT,
328
+ body: {
329
+ query,
330
+ variables: { limit: 10 },
331
+ },
332
+ });
333
+
334
+ expect(status).toBe(200);
335
+ expect(body.errors).toBeUndefined();
336
+ expect(body.data.users).toHaveLength(10);
337
+ expect(body.data.users[0]).toHaveProperty('id');
338
+ expect(body.data.users[0]).toHaveProperty('name');
339
+ });
340
+
341
+ test('should create user via mutation', async ({ apiRequest }) => {
342
+ const mutation = `
343
+ mutation CreateUser($input: CreateUserInput!) {
344
+ createUser(input: $input) {
345
+ id
346
+ name
347
+ email
348
+ }
349
+ }
350
+ `;
351
+
352
+ const { status, body } = await apiRequest({
353
+ method: 'POST',
354
+ path: GRAPHQL_ENDPOINT,
355
+ body: {
356
+ query: mutation,
357
+ variables: {
358
+ input: {
359
+ name: 'GraphQL User',
360
+ email: 'graphql@example.com',
361
+ },
362
+ },
363
+ },
364
+ });
365
+
366
+ expect(status).toBe(200);
367
+ expect(body.errors).toBeUndefined();
368
+ expect(body.data.createUser.id).toBeDefined();
369
+ expect(body.data.createUser.name).toBe('GraphQL User');
370
+ });
371
+
372
+ test('should handle GraphQL errors', async ({ apiRequest }) => {
373
+ const query = `
374
+ query GetUser($id: ID!) {
375
+ user(id: $id) {
376
+ id
377
+ name
378
+ }
379
+ }
380
+ `;
381
+
382
+ const { status, body } = await apiRequest({
383
+ method: 'POST',
384
+ path: GRAPHQL_ENDPOINT,
385
+ body: {
386
+ query,
387
+ variables: { id: 'non-existent' },
388
+ },
389
+ });
390
+
391
+ expect(status).toBe(200); // GraphQL returns 200 even for errors
392
+ expect(body.errors).toBeDefined();
393
+ expect(body.errors[0].message).toContain('not found');
394
+ expect(body.data.user).toBeNull();
395
+ });
396
+
397
+ test('should handle validation errors', async ({ apiRequest }) => {
398
+ const mutation = `
399
+ mutation CreateUser($input: CreateUserInput!) {
400
+ createUser(input: $input) {
401
+ id
402
+ }
403
+ }
404
+ `;
405
+
406
+ const { status, body } = await apiRequest({
407
+ method: 'POST',
408
+ path: GRAPHQL_ENDPOINT,
409
+ body: {
410
+ query: mutation,
411
+ variables: {
412
+ input: {
413
+ name: '', // Invalid: empty name
414
+ email: 'invalid-email', // Invalid: bad format
415
+ },
416
+ },
417
+ },
418
+ });
419
+
420
+ expect(status).toBe(200);
421
+ expect(body.errors).toBeDefined();
422
+ expect(body.errors[0].extensions.code).toBe('BAD_USER_INPUT');
423
+ });
424
+ });
425
+ ```
426
+
427
+ **Key Points**:
428
+
429
+ - GraphQL queries and mutations via POST
430
+ - Variables passed in request body
431
+ - GraphQL returns 200 even for errors (check `body.errors`)
432
+ - Test validation and business logic errors
433
+
434
+ ### Example 5: Database Seeding and Cleanup via API
435
+
436
+ **Context**: Use API calls to set up and tear down test data without direct database access.
437
+
438
+ **Implementation**:
439
+
440
+ ```typescript
441
+ // tests/api/with-data-setup.spec.ts
442
+ import { test, expect } from '@seontechnologies/playwright-utils/fixtures';
443
+
444
+ test.describe('Orders with Data Setup', () => {
445
+ let testUser: { id: string; email: string };
446
+ let testProducts: Array<{ id: string; name: string; price: number }>;
447
+
448
+ test.beforeAll(async ({ request }) => {
449
+ // Seed user via API
450
+ const userResponse = await request.post('/api/users', {
451
+ data: {
452
+ name: 'Test User',
453
+ email: `test-${Date.now()}@example.com`,
454
+ },
455
+ });
456
+ testUser = await userResponse.json();
457
+
458
+ // Seed products via API
459
+ testProducts = [];
460
+ for (const product of [
461
+ { name: 'Widget A', price: 29.99 },
462
+ { name: 'Widget B', price: 49.99 },
463
+ { name: 'Widget C', price: 99.99 },
464
+ ]) {
465
+ const productResponse = await request.post('/api/products', {
466
+ data: product,
467
+ });
468
+ testProducts.push(await productResponse.json());
469
+ }
470
+ });
471
+
472
+ test.afterAll(async ({ request }) => {
473
+ // Cleanup via API
474
+ if (testUser?.id) {
475
+ await request.delete(`/api/users/${testUser.id}`);
476
+ }
477
+ for (const product of testProducts) {
478
+ await request.delete(`/api/products/${product.id}`);
479
+ }
480
+ });
481
+
482
+ test('should create order with seeded data', async ({ apiRequest }) => {
483
+ const { status, body } = await apiRequest({
484
+ method: 'POST',
485
+ path: '/api/orders',
486
+ body: {
487
+ userId: testUser.id,
488
+ items: [
489
+ { productId: testProducts[0].id, quantity: 2 },
490
+ { productId: testProducts[1].id, quantity: 1 },
491
+ ],
492
+ },
493
+ });
494
+
495
+ expect(status).toBe(201);
496
+ expect(body.userId).toBe(testUser.id);
497
+ expect(body.items).toHaveLength(2);
498
+ expect(body.total).toBe(2 * 29.99 + 49.99);
499
+ });
500
+
501
+ test('should list user orders', async ({ apiRequest }) => {
502
+ // Create an order first
503
+ await apiRequest({
504
+ method: 'POST',
505
+ path: '/api/orders',
506
+ body: {
507
+ userId: testUser.id,
508
+ items: [{ productId: testProducts[2].id, quantity: 1 }],
509
+ },
510
+ });
511
+
512
+ // List orders for user
513
+ const { status, body } = await apiRequest({
514
+ method: 'GET',
515
+ path: '/api/orders',
516
+ params: { userId: testUser.id },
517
+ });
518
+
519
+ expect(status).toBe(200);
520
+ expect(body.orders.length).toBeGreaterThanOrEqual(1);
521
+ expect(body.orders.every((o: any) => o.userId === testUser.id)).toBe(true);
522
+ });
523
+ });
524
+ ```
525
+
526
+ **Key Points**:
527
+
528
+ - `beforeAll`/`afterAll` for test data setup/cleanup
529
+ - API-based seeding (no direct DB access needed)
530
+ - Unique emails to prevent conflicts in parallel runs
531
+ - Cleanup after all tests complete
532
+
533
+ ### Example 6: Background Job Testing with Recurse
534
+
535
+ **Context**: Test async operations like background jobs, webhooks, and eventual consistency.
536
+
537
+ **Implementation**:
538
+
539
+ ```typescript
540
+ // tests/api/background-jobs.spec.ts
541
+ import { test, expect } from '@seontechnologies/playwright-utils/fixtures';
542
+
543
+ test.describe('Background Jobs', () => {
544
+ test('should process export job', async ({ apiRequest, recurse }) => {
545
+ // Trigger export job
546
+ const { body: job } = await apiRequest({
547
+ method: 'POST',
548
+ path: '/api/exports',
549
+ body: {
550
+ type: 'users',
551
+ format: 'csv',
552
+ filters: { createdAfter: '2024-01-01' },
553
+ },
554
+ });
555
+
556
+ expect(job.id).toBeDefined();
557
+ expect(job.status).toBe('pending');
558
+
559
+ // Poll until job completes
560
+ const { body: completedJob } = await recurse(
561
+ () => apiRequest({ method: 'GET', path: `/api/exports/${job.id}` }),
562
+ (response) => response.body.status === 'completed',
563
+ {
564
+ timeout: 60000,
565
+ interval: 2000,
566
+ log: `Waiting for export job ${job.id} to complete`,
567
+ }
568
+ );
569
+
570
+ expect(completedJob.status).toBe('completed');
571
+ expect(completedJob.downloadUrl).toBeDefined();
572
+ expect(completedJob.recordCount).toBeGreaterThan(0);
573
+ });
574
+
575
+ test('should handle job failure gracefully', async ({ apiRequest, recurse }) => {
576
+ // Trigger job that will fail
577
+ const { body: job } = await apiRequest({
578
+ method: 'POST',
579
+ path: '/api/exports',
580
+ body: {
581
+ type: 'invalid-type', // This will cause failure
582
+ format: 'csv',
583
+ },
584
+ });
585
+
586
+ // Poll until job fails
587
+ const { body: failedJob } = await recurse(
588
+ () => apiRequest({ method: 'GET', path: `/api/exports/${job.id}` }),
589
+ (response) => ['completed', 'failed'].includes(response.body.status),
590
+ { timeout: 30000 }
591
+ );
592
+
593
+ expect(failedJob.status).toBe('failed');
594
+ expect(failedJob.error).toBeDefined();
595
+ expect(failedJob.error.code).toBe('INVALID_EXPORT_TYPE');
596
+ });
597
+
598
+ test('should process webhook delivery', async ({ apiRequest, recurse }) => {
599
+ // Trigger action that sends webhook
600
+ const { body: order } = await apiRequest({
601
+ method: 'POST',
602
+ path: '/api/orders',
603
+ body: {
604
+ userId: 'user-123',
605
+ items: [{ productId: 'prod-1', quantity: 1 }],
606
+ webhookUrl: 'https://webhook.site/test-endpoint',
607
+ },
608
+ });
609
+
610
+ // Poll for webhook delivery status
611
+ const { body: webhookStatus } = await recurse(
612
+ () => apiRequest({ method: 'GET', path: `/api/webhooks/order/${order.id}` }),
613
+ (response) => response.body.delivered === true,
614
+ { timeout: 30000, interval: 1000 }
615
+ );
616
+
617
+ expect(webhookStatus.delivered).toBe(true);
618
+ expect(webhookStatus.deliveredAt).toBeDefined();
619
+ expect(webhookStatus.responseStatus).toBe(200);
620
+ });
621
+ });
622
+ ```
623
+
624
+ **Key Points**:
625
+
626
+ - `recurse` for polling async operations
627
+ - Test both success and failure scenarios
628
+ - Configurable timeout and interval
629
+ - Log messages for debugging
630
+
631
+ ### Example 7: Service Authentication (No Browser)
632
+
633
+ **Context**: Test authenticated API endpoints using tokens directly - no browser login needed.
634
+
635
+ **Implementation**:
636
+
637
+ ```typescript
638
+ // tests/api/authenticated.spec.ts
639
+ import { test, expect } from '@seontechnologies/playwright-utils/fixtures';
640
+
641
+ test.describe('Authenticated API Tests', () => {
642
+ let authToken: string;
643
+
644
+ test.beforeAll(async ({ request }) => {
645
+ // Get token via API (no browser!)
646
+ const response = await request.post('/api/auth/login', {
647
+ data: {
648
+ email: process.env.TEST_USER_EMAIL,
649
+ password: process.env.TEST_USER_PASSWORD,
650
+ },
651
+ });
652
+
653
+ const { token } = await response.json();
654
+ authToken = token;
655
+ });
656
+
657
+ test('should access protected endpoint with token', async ({ apiRequest }) => {
658
+ const { status, body } = await apiRequest({
659
+ method: 'GET',
660
+ path: '/api/me',
661
+ headers: {
662
+ Authorization: `Bearer ${authToken}`,
663
+ },
664
+ });
665
+
666
+ expect(status).toBe(200);
667
+ expect(body.email).toBe(process.env.TEST_USER_EMAIL);
668
+ });
669
+
670
+ test('should reject request without token', async ({ apiRequest }) => {
671
+ const { status, body } = await apiRequest({
672
+ method: 'GET',
673
+ path: '/api/me',
674
+ // No Authorization header
675
+ });
676
+
677
+ expect(status).toBe(401);
678
+ expect(body.code).toBe('UNAUTHORIZED');
679
+ });
680
+
681
+ test('should reject expired token', async ({ apiRequest }) => {
682
+ const expiredToken = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...'; // Expired token
683
+
684
+ const { status, body } = await apiRequest({
685
+ method: 'GET',
686
+ path: '/api/me',
687
+ headers: {
688
+ Authorization: `Bearer ${expiredToken}`,
689
+ },
690
+ });
691
+
692
+ expect(status).toBe(401);
693
+ expect(body.code).toBe('TOKEN_EXPIRED');
694
+ });
695
+
696
+ test('should handle role-based access', async ({ apiRequest }) => {
697
+ // User token (non-admin)
698
+ const { status } = await apiRequest({
699
+ method: 'GET',
700
+ path: '/api/admin/users',
701
+ headers: {
702
+ Authorization: `Bearer ${authToken}`,
703
+ },
704
+ });
705
+
706
+ expect(status).toBe(403); // Forbidden for non-admin
707
+ });
708
+ });
709
+ ```
710
+
711
+ **Key Points**:
712
+
713
+ - Token obtained via API login (no browser)
714
+ - Token reused across all tests in describe block
715
+ - Test auth, expired tokens, and RBAC
716
+ - Pure API testing without UI
717
+
718
+ ## API Test Configuration
719
+
720
+ ### Playwright Config for API-Only Tests
721
+
722
+ ```typescript
723
+ // playwright.config.ts
724
+ import { defineConfig } from '@playwright/test';
725
+
726
+ export default defineConfig({
727
+ testDir: './tests/api',
728
+
729
+ // No browser needed for API tests
730
+ use: {
731
+ baseURL: process.env.API_URL || 'http://localhost:3000',
732
+ extraHTTPHeaders: {
733
+ 'Accept': 'application/json',
734
+ 'Content-Type': 'application/json',
735
+ },
736
+ },
737
+
738
+ // Faster without browser overhead
739
+ timeout: 30000,
740
+
741
+ // Run API tests in parallel
742
+ workers: 4,
743
+ fullyParallel: true,
744
+
745
+ // No screenshots/traces needed for API tests
746
+ reporter: [['html'], ['json', { outputFile: 'api-test-results.json' }]],
747
+ });
748
+ ```
749
+
750
+ ### Separate API Test Project
751
+
752
+ ```typescript
753
+ // playwright.config.ts
754
+ export default defineConfig({
755
+ projects: [
756
+ {
757
+ name: 'api',
758
+ testDir: './tests/api',
759
+ use: {
760
+ baseURL: process.env.API_URL,
761
+ },
762
+ },
763
+ {
764
+ name: 'e2e',
765
+ testDir: './tests/e2e',
766
+ use: {
767
+ baseURL: process.env.APP_URL,
768
+ ...devices['Desktop Chrome'],
769
+ },
770
+ },
771
+ ],
772
+ });
773
+ ```
774
+
775
+ ## Comparison: API Tests vs E2E Tests
776
+
777
+ | Aspect | API Test | E2E Test |
778
+ |--------|----------|----------|
779
+ | **Speed** | ~50-100ms per test | ~2-10s per test |
780
+ | **Stability** | Very stable | More flaky (UI timing) |
781
+ | **Setup** | Minimal | Browser, context, page |
782
+ | **Debugging** | Clear request/response | DOM, screenshots, traces |
783
+ | **Coverage** | Service logic | User experience |
784
+ | **Parallelization** | Easy (stateless) | Complex (browser resources) |
785
+ | **CI Cost** | Low (no browser) | High (browser containers) |
786
+
787
+ ## Related Fragments
788
+
789
+ - `api-request.md` - apiRequest utility details
790
+ - `recurse.md` - Polling patterns for async operations
791
+ - `auth-session.md` - Token management
792
+ - `contract-testing.md` - Pact contract testing
793
+ - `test-levels-framework.md` - When to use which test level
794
+ - `data-factories.md` - Test data setup patterns
795
+
796
+ ## Anti-Patterns
797
+
798
+ **DON'T use E2E for API validation:**
799
+
800
+ ```typescript
801
+ // Bad: Testing API through UI
802
+ test('validate user creation', async ({ page }) => {
803
+ await page.goto('/admin/users');
804
+ await page.fill('#name', 'John');
805
+ await page.click('#submit');
806
+ await expect(page.getByText('User created')).toBeVisible();
807
+ });
808
+ ```
809
+
810
+ **DO test APIs directly:**
811
+
812
+ ```typescript
813
+ // Good: Direct API test
814
+ test('validate user creation', async ({ apiRequest }) => {
815
+ const { status, body } = await apiRequest({
816
+ method: 'POST',
817
+ path: '/api/users',
818
+ body: { name: 'John' },
819
+ });
820
+ expect(status).toBe(201);
821
+ expect(body.id).toBeDefined();
822
+ });
823
+ ```
824
+
825
+ **DON'T ignore API tests because "E2E covers it":**
826
+
827
+ ```typescript
828
+ // Bad thinking: "Our E2E tests create users, so API is tested"
829
+ // Reality: E2E tests one happy path; API tests cover edge cases
830
+ ```
831
+
832
+ **DO have dedicated API test coverage:**
833
+
834
+ ```typescript
835
+ // Good: Explicit API test suite
836
+ test.describe('Users API', () => {
837
+ test('creates user', async ({ apiRequest }) => { /* ... */ });
838
+ test('handles duplicate email', async ({ apiRequest }) => { /* ... */ });
839
+ test('validates required fields', async ({ apiRequest }) => { /* ... */ });
840
+ test('handles malformed JSON', async ({ apiRequest }) => { /* ... */ });
841
+ test('rate limits requests', async ({ apiRequest }) => { /* ... */ });
842
+ });
843
+ ```