bmad-method 6.0.0-alpha.8 → 6.0.0-alpha.9

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 (539) hide show
  1. package/.github/ISSUE_TEMPLATE/idea_submission.md +1 -1
  2. package/.github/workflows/bundle-latest.yaml +277 -0
  3. package/.github/workflows/manual-release.yaml +55 -16
  4. package/CHANGELOG.md +439 -1
  5. package/README.md +12 -4
  6. package/docs/BUNDLE_DISTRIBUTION_SETUP.md +95 -0
  7. package/docs/agent-customization-guide.md +208 -0
  8. package/docs/ide-info/crush.md +1 -1
  9. package/docs/ide-info/cursor.md +7 -7
  10. package/docs/ide-info/iflow.md +3 -3
  11. package/docs/ide-info/opencode.md +1 -1
  12. package/docs/index.md +3 -1
  13. package/docs/installers-bundlers/ide-injections.md +2 -2
  14. package/docs/installers-bundlers/installers-modules-platforms-reference.md +23 -23
  15. package/docs/v4-to-v6-upgrade.md +12 -12
  16. package/docs/web-bundles-gemini-gpt-guide.md +473 -0
  17. package/package.json +1 -1
  18. package/src/core/_module-installer/install-config.yaml +2 -1
  19. package/src/core/agents/bmad-web-orchestrator.agent.xml +1 -1
  20. package/src/core/tasks/{adv-elicit.xml → advanced-elicitation.xml} +3 -3
  21. package/src/core/tasks/workflow.xml +124 -10
  22. package/src/core/tools/shard-doc.xml +44 -0
  23. package/src/core/workflows/brainstorming/README.md +5 -15
  24. package/src/core/workflows/brainstorming/instructions.md +4 -3
  25. package/src/core/workflows/brainstorming/template.md +4 -0
  26. package/src/modules/bmb/workflows/audit-workflow/checklist.md +3 -4
  27. package/src/modules/bmb/workflows/convert-legacy/README.md +1 -1
  28. package/src/modules/bmb/workflows/convert-legacy/checklist.md +1 -1
  29. package/src/modules/bmb/workflows/convert-legacy/instructions.md +2 -2
  30. package/src/modules/bmb/workflows/create-agent/agent-architecture.md +0 -4
  31. package/src/modules/bmb/workflows/create-agent/instructions.md +13 -16
  32. package/src/modules/bmb/workflows/create-module/checklist.md +0 -9
  33. package/src/modules/bmb/workflows/create-module/instructions.md +5 -10
  34. package/src/modules/bmb/workflows/create-module/module-structure.md +3 -3
  35. package/src/modules/bmb/workflows/create-workflow/instructions.md +1 -1
  36. package/src/modules/bmb/workflows/create-workflow/workflow-creation-guide.md +0 -2
  37. package/src/modules/bmb/workflows/module-brief/checklist.md +2 -2
  38. package/src/modules/bmgd/_module-installer/install-config.yaml +4 -17
  39. package/src/modules/bmgd/agents/game-architect.agent.yaml +2 -2
  40. package/src/modules/bmgd/agents/game-designer.agent.yaml +2 -2
  41. package/src/modules/bmgd/agents/game-dev.agent.yaml +2 -2
  42. package/src/modules/bmgd/agents/game-scrum-master.agent.yaml +2 -2
  43. package/src/modules/bmgd/workflows/2-design/gdd/instructions-gdd.md +1 -6
  44. package/src/modules/bmgd/workflows/2-design/narrative/instructions-narrative.md +0 -5
  45. package/src/modules/bmgd/workflows/3-technical/game-architecture/architecture-patterns.yaml +0 -26
  46. package/src/modules/bmgd/workflows/3-technical/game-architecture/checklist.md +2 -6
  47. package/src/modules/bmgd/workflows/3-technical/game-architecture/instructions.md +1 -6
  48. package/src/modules/bmgd/workflows/4-production/code-review/instructions.md +21 -43
  49. package/src/modules/bmgd/workflows/4-production/code-review/workflow.yaml +11 -21
  50. package/src/modules/bmgd/workflows/4-production/correct-course/instructions.md +5 -0
  51. package/src/modules/bmgd/workflows/4-production/correct-course/workflow.yaml +29 -22
  52. package/src/modules/bmgd/workflows/4-production/create-story/instructions.md +18 -45
  53. package/src/modules/bmgd/workflows/4-production/create-story/workflow.yaml +14 -22
  54. package/src/modules/bmgd/workflows/4-production/dev-story/instructions.md +6 -1
  55. package/src/modules/bmgd/workflows/4-production/dev-story/workflow.yaml +28 -3
  56. package/src/modules/bmgd/workflows/4-production/epic-tech-context/instructions.md +8 -33
  57. package/src/modules/bmgd/workflows/4-production/epic-tech-context/workflow.yaml +14 -22
  58. package/src/modules/bmgd/workflows/4-production/retrospective/instructions.md +16 -34
  59. package/src/modules/bmgd/workflows/4-production/retrospective/workflow.yaml +13 -34
  60. package/src/modules/bmgd/workflows/4-production/sprint-planning/instructions.md +9 -13
  61. package/src/modules/bmgd/workflows/4-production/sprint-planning/sprint-status-template.yaml +1 -1
  62. package/src/modules/bmgd/workflows/4-production/sprint-planning/workflow.yaml +6 -5
  63. package/src/modules/bmgd/workflows/4-production/story-context/instructions.md +18 -43
  64. package/src/modules/bmgd/workflows/4-production/story-context/workflow.yaml +13 -15
  65. package/src/modules/bmgd/workflows/4-production/story-done/workflow.yaml +3 -2
  66. package/src/modules/bmgd/workflows/4-production/story-ready/instructions.md +5 -5
  67. package/src/modules/bmgd/workflows/4-production/story-ready/workflow.yaml +3 -5
  68. package/src/modules/bmm/_module-installer/install-config.yaml +3 -8
  69. package/src/modules/bmm/_module-installer/installer.js +2 -2
  70. package/src/modules/bmm/agents/analyst.agent.yaml +2 -2
  71. package/src/modules/bmm/agents/architect.agent.yaml +2 -2
  72. package/src/modules/bmm/agents/pm.agent.yaml +2 -2
  73. package/src/modules/bmm/agents/sm.agent.yaml +2 -2
  74. package/src/modules/bmm/agents/tea.agent.yaml +2 -2
  75. package/src/modules/bmm/agents/tech-writer.agent.yaml +3 -3
  76. package/src/modules/bmm/agents/ux-designer.agent.yaml +2 -2
  77. package/src/modules/bmm/workflows/1-analysis/domain-research/workflow.yaml +0 -13
  78. package/src/modules/bmm/workflows/1-analysis/product-brief/instructions.md +9 -11
  79. package/src/modules/bmm/workflows/1-analysis/product-brief/workflow.yaml +4 -0
  80. package/src/modules/bmm/workflows/1-analysis/research/checklist-deep-prompt.md +2 -2
  81. package/src/modules/bmm/workflows/1-analysis/research/checklist-technical.md +2 -2
  82. package/src/modules/bmm/workflows/1-analysis/research/checklist.md +2 -2
  83. package/src/modules/bmm/workflows/1-analysis/research/instructions-deep-prompt.md +0 -2
  84. package/src/modules/bmm/workflows/1-analysis/research/instructions-market.md +1 -6
  85. package/src/modules/bmm/workflows/1-analysis/research/instructions-technical.md +0 -5
  86. package/src/modules/bmm/workflows/2-plan-workflows/create-ux-design/instructions.md +6 -1
  87. package/src/modules/bmm/workflows/2-plan-workflows/create-ux-design/workflow.yaml +6 -0
  88. package/src/modules/bmm/workflows/2-plan-workflows/prd/checklist.md +8 -12
  89. package/src/modules/bmm/workflows/2-plan-workflows/prd/create-epics-and-stories/epics-template.md +28 -0
  90. package/src/modules/bmm/workflows/2-plan-workflows/prd/create-epics-and-stories/instructions.md +145 -22
  91. package/src/modules/bmm/workflows/2-plan-workflows/prd/create-epics-and-stories/workflow.yaml +1 -3
  92. package/src/modules/bmm/workflows/2-plan-workflows/prd/instructions.md +151 -34
  93. package/src/modules/bmm/workflows/2-plan-workflows/prd/prd-template.md +2 -2
  94. package/src/modules/bmm/workflows/2-plan-workflows/prd/workflow.yaml +6 -2
  95. package/src/modules/bmm/workflows/2-plan-workflows/tech-spec/checklist.md +12 -9
  96. package/src/modules/bmm/workflows/2-plan-workflows/tech-spec/epics-template.md +0 -6
  97. package/src/modules/bmm/workflows/2-plan-workflows/tech-spec/instructions-generate-stories.md +434 -0
  98. package/src/modules/bmm/workflows/2-plan-workflows/tech-spec/instructions.md +128 -265
  99. package/src/modules/bmm/workflows/2-plan-workflows/tech-spec/workflow.yaml +13 -35
  100. package/src/modules/bmm/workflows/3-solutioning/architecture/architecture-patterns.yaml +0 -26
  101. package/src/modules/bmm/workflows/3-solutioning/architecture/checklist.md +3 -7
  102. package/src/modules/bmm/workflows/3-solutioning/architecture/instructions.md +29 -37
  103. package/src/modules/bmm/workflows/3-solutioning/architecture/workflow.yaml +9 -27
  104. package/src/modules/bmm/workflows/3-solutioning/solutioning-gate-check/checklist.md +7 -13
  105. package/src/modules/bmm/workflows/3-solutioning/solutioning-gate-check/instructions.md +55 -58
  106. package/src/modules/bmm/workflows/3-solutioning/solutioning-gate-check/workflow.yaml +8 -8
  107. package/src/modules/bmm/workflows/4-implementation/code-review/instructions.md +10 -32
  108. package/src/modules/bmm/workflows/4-implementation/code-review/workflow.yaml +11 -13
  109. package/src/modules/bmm/workflows/4-implementation/correct-course/instructions.md +5 -0
  110. package/src/modules/bmm/workflows/4-implementation/correct-course/workflow.yaml +29 -22
  111. package/src/modules/bmm/workflows/4-implementation/create-story/instructions.md +12 -37
  112. package/src/modules/bmm/workflows/4-implementation/create-story/workflow.yaml +12 -7
  113. package/src/modules/bmm/workflows/4-implementation/dev-story/instructions.md +6 -1
  114. package/src/modules/bmm/workflows/4-implementation/dev-story/workflow.yaml +28 -3
  115. package/src/modules/bmm/workflows/4-implementation/epic-tech-context/instructions.md +7 -30
  116. package/src/modules/bmm/workflows/4-implementation/epic-tech-context/workflow.yaml +13 -9
  117. package/src/modules/bmm/workflows/4-implementation/retrospective/instructions.md +8 -26
  118. package/src/modules/bmm/workflows/4-implementation/retrospective/workflow.yaml +13 -31
  119. package/src/modules/bmm/workflows/4-implementation/sprint-planning/instructions.md +5 -0
  120. package/src/modules/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +1 -1
  121. package/src/modules/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +6 -6
  122. package/src/modules/bmm/workflows/4-implementation/story-context/instructions.md +12 -36
  123. package/src/modules/bmm/workflows/4-implementation/story-context/workflow.yaml +12 -6
  124. package/src/modules/bmm/workflows/4-implementation/story-done/workflow.yaml +3 -2
  125. package/src/modules/bmm/workflows/4-implementation/story-ready/instructions.md +5 -5
  126. package/src/modules/bmm/workflows/4-implementation/story-ready/workflow.yaml +3 -5
  127. package/src/modules/bmm/workflows/document-project/checklist.md +1 -1
  128. package/src/modules/bmm/workflows/document-project/workflows/deep-dive-instructions.md +4 -4
  129. package/src/modules/bmm/workflows/document-project/workflows/full-scan-instructions.md +13 -13
  130. package/src/modules/bmm/workflows/testarch/ci/checklist.md +4 -4
  131. package/src/modules/bmm/workflows/testarch/framework/checklist.md +4 -4
  132. package/src/modules/bmm/workflows/testarch/test-design/checklist.md +4 -4
  133. package/src/modules/bmm/workflows/testarch/test-design/instructions.md +173 -12
  134. package/src/modules/bmm/workflows/testarch/test-design/test-design-template.md +3 -3
  135. package/src/modules/bmm/workflows/testarch/test-design/workflow.yaml +5 -1
  136. package/src/modules/bmm/workflows/workflow-status/init/instructions.md +9 -9
  137. package/src/modules/bmm/workflows/workflow-status/init/workflow.yaml +1 -1
  138. package/src/modules/bmm/workflows/workflow-status/paths/enterprise-brownfield.yaml +9 -16
  139. package/src/modules/bmm/workflows/workflow-status/paths/enterprise-greenfield.yaml +11 -18
  140. package/src/modules/bmm/workflows/workflow-status/paths/method-brownfield.yaml +8 -1
  141. package/src/modules/bmm/workflows/workflow-status/paths/method-greenfield.yaml +9 -2
  142. package/src/modules/bmm/workflows/workflow-status/workflow-status-template.yaml +2 -9
  143. package/src/modules/cis/agents/brainstorming-coach.agent.yaml +2 -2
  144. package/src/modules/cis/agents/creative-problem-solver.agent.yaml +2 -2
  145. package/src/modules/cis/agents/design-thinking-coach.agent.yaml +2 -2
  146. package/src/modules/cis/agents/innovation-strategist.agent.yaml +2 -2
  147. package/src/modules/cis/agents/storyteller.agent.yaml +2 -2
  148. package/tools/cli/README.md +50 -32
  149. package/tools/cli/bundlers/web-bundler.js +1 -1
  150. package/tools/cli/installers/lib/core/installer.js +17 -10
  151. package/tools/cli/lib/ui.js +14 -4
  152. package/tools/cli/lib/yaml-xml-builder.js +20 -2
  153. package/.bmad/_cfg/agent-manifest.csv +0 -11
  154. package/.bmad/_cfg/agents/bmb-bmad-builder.customize.yaml +0 -42
  155. package/.bmad/_cfg/agents/bmm-analyst.customize.yaml +0 -42
  156. package/.bmad/_cfg/agents/bmm-architect.customize.yaml +0 -42
  157. package/.bmad/_cfg/agents/bmm-dev.customize.yaml +0 -42
  158. package/.bmad/_cfg/agents/bmm-pm.customize.yaml +0 -42
  159. package/.bmad/_cfg/agents/bmm-sm.customize.yaml +0 -42
  160. package/.bmad/_cfg/agents/bmm-tea.customize.yaml +0 -42
  161. package/.bmad/_cfg/agents/bmm-tech-writer.customize.yaml +0 -42
  162. package/.bmad/_cfg/agents/bmm-ux-designer.customize.yaml +0 -42
  163. package/.bmad/_cfg/agents/core-bmad-master.customize.yaml +0 -42
  164. package/.bmad/_cfg/files-manifest.csv +0 -289
  165. package/.bmad/_cfg/ides/claude-code.yaml +0 -7
  166. package/.bmad/_cfg/manifest.yaml +0 -10
  167. package/.bmad/_cfg/task-manifest.csv +0 -6
  168. package/.bmad/_cfg/tool-manifest.csv +0 -2
  169. package/.bmad/_cfg/workflow-manifest.csv +0 -44
  170. package/.bmad/bmb/README.md +0 -194
  171. package/.bmad/bmb/agents/bmad-builder.md +0 -70
  172. package/.bmad/bmb/config.yaml +0 -16
  173. package/.bmad/bmb/workflows/audit-workflow/checklist.md +0 -143
  174. package/.bmad/bmb/workflows/audit-workflow/instructions.md +0 -341
  175. package/.bmad/bmb/workflows/audit-workflow/template.md +0 -118
  176. package/.bmad/bmb/workflows/audit-workflow/workflow.yaml +0 -23
  177. package/.bmad/bmb/workflows/convert-legacy/README.md +0 -262
  178. package/.bmad/bmb/workflows/convert-legacy/checklist.md +0 -205
  179. package/.bmad/bmb/workflows/convert-legacy/instructions.md +0 -377
  180. package/.bmad/bmb/workflows/convert-legacy/workflow.yaml +0 -32
  181. package/.bmad/bmb/workflows/create-agent/README.md +0 -203
  182. package/.bmad/bmb/workflows/create-agent/agent-architecture.md +0 -419
  183. package/.bmad/bmb/workflows/create-agent/agent-command-patterns.md +0 -759
  184. package/.bmad/bmb/workflows/create-agent/agent-types.md +0 -292
  185. package/.bmad/bmb/workflows/create-agent/brainstorm-context.md +0 -174
  186. package/.bmad/bmb/workflows/create-agent/checklist.md +0 -62
  187. package/.bmad/bmb/workflows/create-agent/communication-styles.md +0 -202
  188. package/.bmad/bmb/workflows/create-agent/instructions.md +0 -459
  189. package/.bmad/bmb/workflows/create-agent/workflow.yaml +0 -37
  190. package/.bmad/bmb/workflows/create-module/README.md +0 -229
  191. package/.bmad/bmb/workflows/create-module/brainstorm-context.md +0 -137
  192. package/.bmad/bmb/workflows/create-module/checklist.md +0 -244
  193. package/.bmad/bmb/workflows/create-module/installer-templates/install-config.yaml +0 -92
  194. package/.bmad/bmb/workflows/create-module/installer-templates/installer.js +0 -231
  195. package/.bmad/bmb/workflows/create-module/instructions.md +0 -581
  196. package/.bmad/bmb/workflows/create-module/module-structure.md +0 -400
  197. package/.bmad/bmb/workflows/create-module/workflow.yaml +0 -42
  198. package/.bmad/bmb/workflows/create-workflow/README.md +0 -277
  199. package/.bmad/bmb/workflows/create-workflow/brainstorm-context.md +0 -197
  200. package/.bmad/bmb/workflows/create-workflow/checklist.md +0 -94
  201. package/.bmad/bmb/workflows/create-workflow/instructions.md +0 -724
  202. package/.bmad/bmb/workflows/create-workflow/workflow-creation-guide.md +0 -1308
  203. package/.bmad/bmb/workflows/create-workflow/workflow-template/checklist.md +0 -24
  204. package/.bmad/bmb/workflows/create-workflow/workflow-template/instructions.md +0 -13
  205. package/.bmad/bmb/workflows/create-workflow/workflow-template/template.md +0 -9
  206. package/.bmad/bmb/workflows/create-workflow/workflow-template/workflow.yaml +0 -39
  207. package/.bmad/bmb/workflows/create-workflow/workflow.yaml +0 -40
  208. package/.bmad/bmb/workflows/edit-agent/README.md +0 -112
  209. package/.bmad/bmb/workflows/edit-agent/checklist.md +0 -112
  210. package/.bmad/bmb/workflows/edit-agent/instructions.md +0 -290
  211. package/.bmad/bmb/workflows/edit-agent/workflow.yaml +0 -33
  212. package/.bmad/bmb/workflows/edit-module/README.md +0 -187
  213. package/.bmad/bmb/workflows/edit-module/checklist.md +0 -165
  214. package/.bmad/bmb/workflows/edit-module/instructions.md +0 -339
  215. package/.bmad/bmb/workflows/edit-module/workflow.yaml +0 -34
  216. package/.bmad/bmb/workflows/edit-workflow/README.md +0 -119
  217. package/.bmad/bmb/workflows/edit-workflow/checklist.md +0 -70
  218. package/.bmad/bmb/workflows/edit-workflow/instructions.md +0 -342
  219. package/.bmad/bmb/workflows/edit-workflow/workflow.yaml +0 -27
  220. package/.bmad/bmb/workflows/module-brief/README.md +0 -264
  221. package/.bmad/bmb/workflows/module-brief/checklist.md +0 -116
  222. package/.bmad/bmb/workflows/module-brief/instructions.md +0 -267
  223. package/.bmad/bmb/workflows/module-brief/template.md +0 -275
  224. package/.bmad/bmb/workflows/module-brief/workflow.yaml +0 -29
  225. package/.bmad/bmb/workflows/redoc/README.md +0 -87
  226. package/.bmad/bmb/workflows/redoc/checklist.md +0 -99
  227. package/.bmad/bmb/workflows/redoc/instructions.md +0 -265
  228. package/.bmad/bmb/workflows/redoc/workflow.yaml +0 -32
  229. package/.bmad/bmm/README.md +0 -128
  230. package/.bmad/bmm/agents/analyst.md +0 -75
  231. package/.bmad/bmm/agents/architect.md +0 -80
  232. package/.bmad/bmm/agents/dev.md +0 -69
  233. package/.bmad/bmm/agents/pm.md +0 -84
  234. package/.bmad/bmm/agents/sm.md +0 -93
  235. package/.bmad/bmm/agents/tea.md +0 -80
  236. package/.bmad/bmm/agents/tech-writer.md +0 -90
  237. package/.bmad/bmm/agents/ux-designer.md +0 -79
  238. package/.bmad/bmm/config.yaml +0 -18
  239. package/.bmad/bmm/docs/README.md +0 -235
  240. package/.bmad/bmm/docs/agents-guide.md +0 -1056
  241. package/.bmad/bmm/docs/brownfield-guide.md +0 -754
  242. package/.bmad/bmm/docs/enterprise-agentic-development.md +0 -680
  243. package/.bmad/bmm/docs/faq.md +0 -587
  244. package/.bmad/bmm/docs/glossary.md +0 -320
  245. package/.bmad/bmm/docs/party-mode.md +0 -224
  246. package/.bmad/bmm/docs/quick-spec-flow.md +0 -652
  247. package/.bmad/bmm/docs/quick-start.md +0 -366
  248. package/.bmad/bmm/docs/scale-adaptive-system.md +0 -599
  249. package/.bmad/bmm/docs/test-architecture.md +0 -394
  250. package/.bmad/bmm/docs/workflow-architecture-reference.md +0 -371
  251. package/.bmad/bmm/docs/workflow-document-project-reference.md +0 -487
  252. package/.bmad/bmm/docs/workflows-analysis.md +0 -370
  253. package/.bmad/bmm/docs/workflows-implementation.md +0 -284
  254. package/.bmad/bmm/docs/workflows-planning.md +0 -601
  255. package/.bmad/bmm/docs/workflows-solutioning.md +0 -501
  256. package/.bmad/bmm/tasks/daily-standup.xml +0 -85
  257. package/.bmad/bmm/teams/default-party.csv +0 -19
  258. package/.bmad/bmm/teams/team-fullstack.yaml +0 -12
  259. package/.bmad/bmm/testarch/knowledge/ci-burn-in.md +0 -675
  260. package/.bmad/bmm/testarch/knowledge/component-tdd.md +0 -486
  261. package/.bmad/bmm/testarch/knowledge/contract-testing.md +0 -957
  262. package/.bmad/bmm/testarch/knowledge/data-factories.md +0 -500
  263. package/.bmad/bmm/testarch/knowledge/email-auth.md +0 -721
  264. package/.bmad/bmm/testarch/knowledge/error-handling.md +0 -725
  265. package/.bmad/bmm/testarch/knowledge/feature-flags.md +0 -750
  266. package/.bmad/bmm/testarch/knowledge/fixture-architecture.md +0 -401
  267. package/.bmad/bmm/testarch/knowledge/network-first.md +0 -486
  268. package/.bmad/bmm/testarch/knowledge/nfr-criteria.md +0 -670
  269. package/.bmad/bmm/testarch/knowledge/playwright-config.md +0 -730
  270. package/.bmad/bmm/testarch/knowledge/probability-impact.md +0 -601
  271. package/.bmad/bmm/testarch/knowledge/risk-governance.md +0 -615
  272. package/.bmad/bmm/testarch/knowledge/selective-testing.md +0 -732
  273. package/.bmad/bmm/testarch/knowledge/selector-resilience.md +0 -527
  274. package/.bmad/bmm/testarch/knowledge/test-healing-patterns.md +0 -644
  275. package/.bmad/bmm/testarch/knowledge/test-levels-framework.md +0 -473
  276. package/.bmad/bmm/testarch/knowledge/test-priorities-matrix.md +0 -373
  277. package/.bmad/bmm/testarch/knowledge/test-quality.md +0 -664
  278. package/.bmad/bmm/testarch/knowledge/timing-debugging.md +0 -372
  279. package/.bmad/bmm/testarch/knowledge/visual-debugging.md +0 -524
  280. package/.bmad/bmm/testarch/tea-index.csv +0 -22
  281. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/instructions.md +0 -110
  282. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/project-context.md +0 -25
  283. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/workflow.yaml +0 -26
  284. package/.bmad/bmm/workflows/1-analysis/domain-research/instructions.md +0 -423
  285. package/.bmad/bmm/workflows/1-analysis/domain-research/template.md +0 -180
  286. package/.bmad/bmm/workflows/1-analysis/domain-research/workflow.yaml +0 -40
  287. package/.bmad/bmm/workflows/1-analysis/product-brief/checklist.md +0 -115
  288. package/.bmad/bmm/workflows/1-analysis/product-brief/instructions.md +0 -524
  289. package/.bmad/bmm/workflows/1-analysis/product-brief/template.md +0 -181
  290. package/.bmad/bmm/workflows/1-analysis/product-brief/workflow.yaml +0 -45
  291. package/.bmad/bmm/workflows/1-analysis/research/checklist-deep-prompt.md +0 -144
  292. package/.bmad/bmm/workflows/1-analysis/research/checklist-technical.md +0 -249
  293. package/.bmad/bmm/workflows/1-analysis/research/checklist.md +0 -299
  294. package/.bmad/bmm/workflows/1-analysis/research/claude-code/injections.yaml +0 -114
  295. package/.bmad/bmm/workflows/1-analysis/research/instructions-deep-prompt.md +0 -439
  296. package/.bmad/bmm/workflows/1-analysis/research/instructions-market.md +0 -679
  297. package/.bmad/bmm/workflows/1-analysis/research/instructions-router.md +0 -133
  298. package/.bmad/bmm/workflows/1-analysis/research/instructions-technical.md +0 -538
  299. package/.bmad/bmm/workflows/1-analysis/research/template-deep-prompt.md +0 -94
  300. package/.bmad/bmm/workflows/1-analysis/research/template-market.md +0 -347
  301. package/.bmad/bmm/workflows/1-analysis/research/template-technical.md +0 -245
  302. package/.bmad/bmm/workflows/1-analysis/research/workflow.yaml +0 -44
  303. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/checklist.md +0 -310
  304. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/instructions.md +0 -1301
  305. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +0 -145
  306. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.yaml +0 -60
  307. package/.bmad/bmm/workflows/2-plan-workflows/prd/checklist.md +0 -350
  308. package/.bmad/bmm/workflows/2-plan-workflows/prd/create-epics-and-stories/epics-template.md +0 -52
  309. package/.bmad/bmm/workflows/2-plan-workflows/prd/create-epics-and-stories/instructions.md +0 -169
  310. package/.bmad/bmm/workflows/2-plan-workflows/prd/create-epics-and-stories/workflow.yaml +0 -45
  311. package/.bmad/bmm/workflows/2-plan-workflows/prd/domain-complexity.csv +0 -13
  312. package/.bmad/bmm/workflows/2-plan-workflows/prd/instructions.md +0 -408
  313. package/.bmad/bmm/workflows/2-plan-workflows/prd/prd-template.md +0 -237
  314. package/.bmad/bmm/workflows/2-plan-workflows/prd/project-types.csv +0 -11
  315. package/.bmad/bmm/workflows/2-plan-workflows/prd/workflow.yaml +0 -46
  316. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/checklist.md +0 -214
  317. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/epics-template.md +0 -80
  318. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions-level0-story.md +0 -200
  319. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions-level1-stories.md +0 -451
  320. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions.md +0 -1115
  321. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/tech-spec-template.md +0 -181
  322. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/user-story-template.md +0 -90
  323. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/workflow.yaml +0 -60
  324. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-patterns.yaml +0 -347
  325. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-template.md +0 -103
  326. package/.bmad/bmm/workflows/3-solutioning/architecture/checklist.md +0 -244
  327. package/.bmad/bmm/workflows/3-solutioning/architecture/decision-catalog.yaml +0 -222
  328. package/.bmad/bmm/workflows/3-solutioning/architecture/instructions.md +0 -704
  329. package/.bmad/bmm/workflows/3-solutioning/architecture/pattern-categories.csv +0 -13
  330. package/.bmad/bmm/workflows/3-solutioning/architecture/workflow.yaml +0 -68
  331. package/.bmad/bmm/workflows/3-solutioning/solutioning-gate-check/checklist.md +0 -175
  332. package/.bmad/bmm/workflows/3-solutioning/solutioning-gate-check/instructions.md +0 -305
  333. package/.bmad/bmm/workflows/3-solutioning/solutioning-gate-check/template.md +0 -146
  334. package/.bmad/bmm/workflows/3-solutioning/solutioning-gate-check/validation-criteria.yaml +0 -189
  335. package/.bmad/bmm/workflows/3-solutioning/solutioning-gate-check/workflow.yaml +0 -64
  336. package/.bmad/bmm/workflows/4-implementation/code-review/backlog_template.md +0 -12
  337. package/.bmad/bmm/workflows/4-implementation/code-review/checklist.md +0 -22
  338. package/.bmad/bmm/workflows/4-implementation/code-review/instructions.md +0 -420
  339. package/.bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +0 -65
  340. package/.bmad/bmm/workflows/4-implementation/correct-course/checklist.md +0 -279
  341. package/.bmad/bmm/workflows/4-implementation/correct-course/instructions.md +0 -201
  342. package/.bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +0 -43
  343. package/.bmad/bmm/workflows/4-implementation/create-story/checklist.md +0 -240
  344. package/.bmad/bmm/workflows/4-implementation/create-story/instructions.md +0 -283
  345. package/.bmad/bmm/workflows/4-implementation/create-story/template.md +0 -51
  346. package/.bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +0 -74
  347. package/.bmad/bmm/workflows/4-implementation/dev-story/AUDIT-REPORT.md +0 -367
  348. package/.bmad/bmm/workflows/4-implementation/dev-story/checklist.md +0 -38
  349. package/.bmad/bmm/workflows/4-implementation/dev-story/instructions.md +0 -262
  350. package/.bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +0 -26
  351. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/checklist.md +0 -17
  352. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/instructions.md +0 -189
  353. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/template.md +0 -76
  354. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/workflow.yaml +0 -58
  355. package/.bmad/bmm/workflows/4-implementation/retrospective/instructions.md +0 -1460
  356. package/.bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +0 -71
  357. package/.bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +0 -33
  358. package/.bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +0 -238
  359. package/.bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +0 -55
  360. package/.bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +0 -47
  361. package/.bmad/bmm/workflows/4-implementation/story-context/checklist.md +0 -16
  362. package/.bmad/bmm/workflows/4-implementation/story-context/context-template.xml +0 -34
  363. package/.bmad/bmm/workflows/4-implementation/story-context/instructions.md +0 -234
  364. package/.bmad/bmm/workflows/4-implementation/story-context/workflow.yaml +0 -57
  365. package/.bmad/bmm/workflows/4-implementation/story-done/instructions.md +0 -111
  366. package/.bmad/bmm/workflows/4-implementation/story-done/workflow.yaml +0 -25
  367. package/.bmad/bmm/workflows/4-implementation/story-ready/instructions.md +0 -117
  368. package/.bmad/bmm/workflows/4-implementation/story-ready/workflow.yaml +0 -25
  369. package/.bmad/bmm/workflows/document-project/checklist.md +0 -245
  370. package/.bmad/bmm/workflows/document-project/documentation-requirements.csv +0 -12
  371. package/.bmad/bmm/workflows/document-project/instructions.md +0 -222
  372. package/.bmad/bmm/workflows/document-project/templates/deep-dive-template.md +0 -345
  373. package/.bmad/bmm/workflows/document-project/templates/index-template.md +0 -169
  374. package/.bmad/bmm/workflows/document-project/templates/project-overview-template.md +0 -103
  375. package/.bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +0 -160
  376. package/.bmad/bmm/workflows/document-project/templates/source-tree-template.md +0 -135
  377. package/.bmad/bmm/workflows/document-project/workflow.yaml +0 -34
  378. package/.bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +0 -298
  379. package/.bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +0 -31
  380. package/.bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +0 -1106
  381. package/.bmad/bmm/workflows/document-project/workflows/full-scan.yaml +0 -31
  382. package/.bmad/bmm/workflows/techdoc/documentation-standards.md +0 -262
  383. package/.bmad/bmm/workflows/testarch/atdd/atdd-checklist-template.md +0 -363
  384. package/.bmad/bmm/workflows/testarch/atdd/checklist.md +0 -373
  385. package/.bmad/bmm/workflows/testarch/atdd/instructions.md +0 -785
  386. package/.bmad/bmm/workflows/testarch/atdd/workflow.yaml +0 -52
  387. package/.bmad/bmm/workflows/testarch/automate/checklist.md +0 -580
  388. package/.bmad/bmm/workflows/testarch/automate/instructions.md +0 -1303
  389. package/.bmad/bmm/workflows/testarch/automate/workflow.yaml +0 -61
  390. package/.bmad/bmm/workflows/testarch/ci/checklist.md +0 -246
  391. package/.bmad/bmm/workflows/testarch/ci/github-actions-template.yaml +0 -165
  392. package/.bmad/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +0 -128
  393. package/.bmad/bmm/workflows/testarch/ci/instructions.md +0 -517
  394. package/.bmad/bmm/workflows/testarch/ci/workflow.yaml +0 -53
  395. package/.bmad/bmm/workflows/testarch/framework/checklist.md +0 -321
  396. package/.bmad/bmm/workflows/testarch/framework/instructions.md +0 -455
  397. package/.bmad/bmm/workflows/testarch/framework/workflow.yaml +0 -53
  398. package/.bmad/bmm/workflows/testarch/nfr-assess/checklist.md +0 -405
  399. package/.bmad/bmm/workflows/testarch/nfr-assess/instructions.md +0 -722
  400. package/.bmad/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +0 -443
  401. package/.bmad/bmm/workflows/testarch/nfr-assess/workflow.yaml +0 -56
  402. package/.bmad/bmm/workflows/testarch/test-design/checklist.md +0 -234
  403. package/.bmad/bmm/workflows/testarch/test-design/instructions.md +0 -621
  404. package/.bmad/bmm/workflows/testarch/test-design/test-design-template.md +0 -285
  405. package/.bmad/bmm/workflows/testarch/test-design/workflow.yaml +0 -52
  406. package/.bmad/bmm/workflows/testarch/test-review/checklist.md +0 -470
  407. package/.bmad/bmm/workflows/testarch/test-review/instructions.md +0 -608
  408. package/.bmad/bmm/workflows/testarch/test-review/test-review-template.md +0 -388
  409. package/.bmad/bmm/workflows/testarch/test-review/workflow.yaml +0 -53
  410. package/.bmad/bmm/workflows/testarch/trace/checklist.md +0 -654
  411. package/.bmad/bmm/workflows/testarch/trace/instructions.md +0 -1045
  412. package/.bmad/bmm/workflows/testarch/trace/trace-template.md +0 -673
  413. package/.bmad/bmm/workflows/testarch/trace/workflow.yaml +0 -66
  414. package/.bmad/bmm/workflows/workflow-status/init/instructions.md +0 -822
  415. package/.bmad/bmm/workflows/workflow-status/init/workflow.yaml +0 -27
  416. package/.bmad/bmm/workflows/workflow-status/instructions.md +0 -387
  417. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-brownfield.yaml +0 -127
  418. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-greenfield.yaml +0 -115
  419. package/.bmad/bmm/workflows/workflow-status/paths/game-design.yaml +0 -52
  420. package/.bmad/bmm/workflows/workflow-status/paths/method-brownfield.yaml +0 -97
  421. package/.bmad/bmm/workflows/workflow-status/paths/method-greenfield.yaml +0 -88
  422. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-brownfield.yaml +0 -58
  423. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-greenfield.yaml +0 -47
  424. package/.bmad/bmm/workflows/workflow-status/project-levels.yaml +0 -59
  425. package/.bmad/bmm/workflows/workflow-status/sample-level-3-workflow.yaml +0 -49
  426. package/.bmad/bmm/workflows/workflow-status/workflow-status-template.yaml +0 -31
  427. package/.bmad/bmm/workflows/workflow-status/workflow.yaml +0 -28
  428. package/.bmad/core/agents/bmad-master.md +0 -71
  429. package/.bmad/core/agents/bmad-web-orchestrator.agent.xml +0 -113
  430. package/.bmad/core/config.yaml +0 -11
  431. package/.bmad/core/tasks/adv-elicit-methods.csv +0 -39
  432. package/.bmad/core/tasks/adv-elicit.xml +0 -106
  433. package/.bmad/core/tasks/index-docs.xml +0 -65
  434. package/.bmad/core/tasks/validate-workflow.xml +0 -89
  435. package/.bmad/core/tasks/workflow.xml +0 -156
  436. package/.bmad/core/tools/shard-doc.xml +0 -65
  437. package/.bmad/core/workflows/brainstorming/README.md +0 -271
  438. package/.bmad/core/workflows/brainstorming/brain-methods.csv +0 -36
  439. package/.bmad/core/workflows/brainstorming/instructions.md +0 -314
  440. package/.bmad/core/workflows/brainstorming/template.md +0 -102
  441. package/.bmad/core/workflows/brainstorming/workflow.yaml +0 -43
  442. package/.bmad/core/workflows/party-mode/instructions.md +0 -183
  443. package/.bmad/core/workflows/party-mode/workflow.yaml +0 -27
  444. package/.bmad/docs/claude-code-instructions.md +0 -25
  445. package/.claude/commands/bmad/bmb/agents/bmad-builder.md +0 -70
  446. package/.claude/commands/bmad/bmb/workflows/audit-workflow.md +0 -15
  447. package/.claude/commands/bmad/bmb/workflows/convert-legacy.md +0 -15
  448. package/.claude/commands/bmad/bmb/workflows/create-agent.md +0 -15
  449. package/.claude/commands/bmad/bmb/workflows/create-module.md +0 -15
  450. package/.claude/commands/bmad/bmb/workflows/create-workflow.md +0 -15
  451. package/.claude/commands/bmad/bmb/workflows/edit-agent.md +0 -15
  452. package/.claude/commands/bmad/bmb/workflows/edit-module.md +0 -15
  453. package/.claude/commands/bmad/bmb/workflows/edit-workflow.md +0 -15
  454. package/.claude/commands/bmad/bmb/workflows/module-brief.md +0 -15
  455. package/.claude/commands/bmad/bmb/workflows/redoc.md +0 -15
  456. package/.claude/commands/bmad/bmm/agents/analyst.md +0 -75
  457. package/.claude/commands/bmad/bmm/agents/architect.md +0 -80
  458. package/.claude/commands/bmad/bmm/agents/dev.md +0 -69
  459. package/.claude/commands/bmad/bmm/agents/pm.md +0 -84
  460. package/.claude/commands/bmad/bmm/agents/sm.md +0 -93
  461. package/.claude/commands/bmad/bmm/agents/tea.md +0 -80
  462. package/.claude/commands/bmad/bmm/agents/tech-writer.md +0 -90
  463. package/.claude/commands/bmad/bmm/agents/ux-designer.md +0 -79
  464. package/.claude/commands/bmad/bmm/workflows/architecture.md +0 -15
  465. package/.claude/commands/bmad/bmm/workflows/brainstorm-project.md +0 -15
  466. package/.claude/commands/bmad/bmm/workflows/code-review.md +0 -15
  467. package/.claude/commands/bmad/bmm/workflows/correct-course.md +0 -15
  468. package/.claude/commands/bmad/bmm/workflows/create-epics-and-stories.md +0 -15
  469. package/.claude/commands/bmad/bmm/workflows/create-story.md +0 -15
  470. package/.claude/commands/bmad/bmm/workflows/create-ux-design.md +0 -15
  471. package/.claude/commands/bmad/bmm/workflows/dev-story.md +0 -15
  472. package/.claude/commands/bmad/bmm/workflows/document-project.md +0 -15
  473. package/.claude/commands/bmad/bmm/workflows/domain-research.md +0 -15
  474. package/.claude/commands/bmad/bmm/workflows/epic-tech-context.md +0 -15
  475. package/.claude/commands/bmad/bmm/workflows/prd.md +0 -15
  476. package/.claude/commands/bmad/bmm/workflows/product-brief.md +0 -15
  477. package/.claude/commands/bmad/bmm/workflows/research.md +0 -15
  478. package/.claude/commands/bmad/bmm/workflows/retrospective.md +0 -15
  479. package/.claude/commands/bmad/bmm/workflows/solutioning-gate-check.md +0 -15
  480. package/.claude/commands/bmad/bmm/workflows/sprint-planning.md +0 -15
  481. package/.claude/commands/bmad/bmm/workflows/story-context.md +0 -15
  482. package/.claude/commands/bmad/bmm/workflows/story-done.md +0 -15
  483. package/.claude/commands/bmad/bmm/workflows/story-ready.md +0 -15
  484. package/.claude/commands/bmad/bmm/workflows/tech-spec.md +0 -15
  485. package/.claude/commands/bmad/bmm/workflows/workflow-init.md +0 -15
  486. package/.claude/commands/bmad/bmm/workflows/workflow-status.md +0 -15
  487. package/.claude/commands/bmad/core/agents/bmad-master.md +0 -71
  488. package/.claude/commands/bmad/core/tasks/adv-elicit.md +0 -9
  489. package/.claude/commands/bmad/core/tasks/index-docs.md +0 -9
  490. package/.claude/commands/bmad/core/tools/shard-doc.md +0 -9
  491. package/.claude/commands/bmad/core/workflows/brainstorming.md +0 -15
  492. package/.claude/commands/bmad/core/workflows/party-mode.md +0 -15
  493. package/.claude/settings.local.json +0 -16
  494. package/src/modules/bmgd/workflows/4-production/dev-story/AUDIT-REPORT.md +0 -367
  495. package/src/modules/bmm/sub-modules/claude-code/README.md +0 -87
  496. package/src/modules/bmm/sub-modules/claude-code/config.yaml +0 -5
  497. package/src/modules/bmm/sub-modules/claude-code/injections.yaml +0 -242
  498. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-analysis/api-documenter.md +0 -102
  499. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-analysis/codebase-analyzer.md +0 -82
  500. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-analysis/data-analyst.md +0 -101
  501. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-analysis/pattern-detector.md +0 -84
  502. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-planning/dependency-mapper.md +0 -83
  503. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-planning/epic-optimizer.md +0 -81
  504. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-planning/requirements-analyst.md +0 -61
  505. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-planning/technical-decisions-curator.md +0 -168
  506. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-planning/trend-spotter.md +0 -115
  507. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-planning/user-journey-mapper.md +0 -123
  508. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-planning/user-researcher.md +0 -72
  509. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-research/market-researcher.md +0 -51
  510. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-research/tech-debt-auditor.md +0 -106
  511. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-review/document-reviewer.md +0 -102
  512. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-review/technical-evaluator.md +0 -68
  513. package/src/modules/bmm/sub-modules/claude-code/sub-agents/bmad-review/test-coverage-analyzer.md +0 -108
  514. package/src/modules/bmm/tasks/daily-standup.xml +0 -85
  515. package/src/modules/bmm/workflows/2-plan-workflows/tech-spec/instructions-level0-story.md +0 -200
  516. package/src/modules/bmm/workflows/2-plan-workflows/tech-spec/instructions-level1-stories.md +0 -451
  517. package/src/modules/bmm/workflows/3-solutioning/solutioning-gate-check/validation-criteria.yaml +0 -189
  518. package/src/modules/bmm/workflows/4-implementation/dev-story/AUDIT-REPORT.md +0 -367
  519. package/src/modules/bmm/workflows/workflow-status/sample-level-3-workflow.yaml +0 -49
  520. package/web-bundles/bmgd/agents/game-architect.xml +0 -664
  521. package/web-bundles/bmgd/agents/game-designer.xml +0 -5489
  522. package/web-bundles/bmgd/agents/game-dev.xml +0 -595
  523. package/web-bundles/bmgd/agents/game-scrum-master.xml +0 -699
  524. package/web-bundles/bmgd/teams/team-gamedev.xml +0 -6588
  525. package/web-bundles/bmm/agents/analyst.xml +0 -5263
  526. package/web-bundles/bmm/agents/architect.xml +0 -2378
  527. package/web-bundles/bmm/agents/dev.xml +0 -248
  528. package/web-bundles/bmm/agents/pm.xml +0 -4137
  529. package/web-bundles/bmm/agents/sm.xml +0 -708
  530. package/web-bundles/bmm/agents/tea.xml +0 -759
  531. package/web-bundles/bmm/agents/tech-writer.xml +0 -624
  532. package/web-bundles/bmm/agents/ux-designer.xml +0 -2492
  533. package/web-bundles/bmm/teams/team-fullstack.xml +0 -12369
  534. package/web-bundles/cis/agents/brainstorming-coach.xml +0 -1069
  535. package/web-bundles/cis/agents/creative-problem-solver.xml +0 -1060
  536. package/web-bundles/cis/agents/design-thinking-coach.xml +0 -955
  537. package/web-bundles/cis/agents/innovation-strategist.xml +0 -1108
  538. package/web-bundles/cis/agents/storyteller.xml +0 -598
  539. package/web-bundles/cis/teams/creative-squad.xml +0 -3449
@@ -1,401 +0,0 @@
1
- # Fixture Architecture Playbook
2
-
3
- ## Principle
4
-
5
- Build test helpers as pure functions first, then wrap them in framework-specific fixtures. Compose capabilities using `mergeTests` (Playwright) or layered commands (Cypress) instead of inheritance. Each fixture should solve one isolated concern (auth, API, logs, network).
6
-
7
- ## Rationale
8
-
9
- Traditional Page Object Models create tight coupling through inheritance chains (`BasePage → LoginPage → AdminPage`). When base classes change, all descendants break. Pure functions with fixture wrappers provide:
10
-
11
- - **Testability**: Pure functions run in unit tests without framework overhead
12
- - **Composability**: Mix capabilities freely via `mergeTests`, no inheritance constraints
13
- - **Reusability**: Export fixtures via package subpaths for cross-project sharing
14
- - **Maintainability**: One concern per fixture = clear responsibility boundaries
15
-
16
- ## Pattern Examples
17
-
18
- ### Example 1: Pure Function → Fixture Pattern
19
-
20
- **Context**: When building any test helper, always start with a pure function that accepts all dependencies explicitly. Then wrap it in a Playwright fixture or Cypress command.
21
-
22
- **Implementation**:
23
-
24
- ```typescript
25
- // playwright/support/helpers/api-request.ts
26
- // Step 1: Pure function (ALWAYS FIRST!)
27
- type ApiRequestParams = {
28
- request: APIRequestContext;
29
- method: 'GET' | 'POST' | 'PUT' | 'DELETE';
30
- url: string;
31
- data?: unknown;
32
- headers?: Record<string, string>;
33
- };
34
-
35
- export async function apiRequest({
36
- request,
37
- method,
38
- url,
39
- data,
40
- headers = {}
41
- }: ApiRequestParams) {
42
- const response = await request.fetch(url, {
43
- method,
44
- data,
45
- headers: {
46
- 'Content-Type': 'application/json',
47
- ...headers
48
- }
49
- });
50
-
51
- if (!response.ok()) {
52
- throw new Error(`API request failed: ${response.status()} ${await response.text()}`);
53
- }
54
-
55
- return response.json();
56
- }
57
-
58
- // Step 2: Fixture wrapper
59
- // playwright/support/fixtures/api-request-fixture.ts
60
- import { test as base } from '@playwright/test';
61
- import { apiRequest } from '../helpers/api-request';
62
-
63
- export const test = base.extend<{ apiRequest: typeof apiRequest }>({
64
- apiRequest: async ({ request }, use) => {
65
- // Inject framework dependency, expose pure function
66
- await use((params) => apiRequest({ request, ...params }));
67
- }
68
- });
69
-
70
- // Step 3: Package exports for reusability
71
- // package.json
72
- {
73
- "exports": {
74
- "./api-request": "./playwright/support/helpers/api-request.ts",
75
- "./api-request/fixtures": "./playwright/support/fixtures/api-request-fixture.ts"
76
- }
77
- }
78
- ```
79
-
80
- **Key Points**:
81
-
82
- - Pure function is unit-testable without Playwright running
83
- - Framework dependency (`request`) injected at fixture boundary
84
- - Fixture exposes the pure function to test context
85
- - Package subpath exports enable `import { apiRequest } from 'my-fixtures/api-request'`
86
-
87
- ### Example 2: Composable Fixture System with mergeTests
88
-
89
- **Context**: When building comprehensive test capabilities, compose multiple focused fixtures instead of creating monolithic helper classes. Each fixture provides one capability.
90
-
91
- **Implementation**:
92
-
93
- ```typescript
94
- // playwright/support/fixtures/merged-fixtures.ts
95
- import { test as base, mergeTests } from '@playwright/test';
96
- import { test as apiRequestFixture } from './api-request-fixture';
97
- import { test as networkFixture } from './network-fixture';
98
- import { test as authFixture } from './auth-fixture';
99
- import { test as logFixture } from './log-fixture';
100
-
101
- // Compose all fixtures for comprehensive capabilities
102
- export const test = mergeTests(base, apiRequestFixture, networkFixture, authFixture, logFixture);
103
-
104
- export { expect } from '@playwright/test';
105
-
106
- // Example usage in tests:
107
- // import { test, expect } from './support/fixtures/merged-fixtures';
108
- //
109
- // test('user can create order', async ({ page, apiRequest, auth, network }) => {
110
- // await auth.loginAs('customer@example.com');
111
- // await network.interceptRoute('POST', '**/api/orders', { id: 123 });
112
- // await page.goto('/checkout');
113
- // await page.click('[data-testid="submit-order"]');
114
- // await expect(page.getByText('Order #123')).toBeVisible();
115
- // });
116
- ```
117
-
118
- **Individual Fixture Examples**:
119
-
120
- ```typescript
121
- // network-fixture.ts
122
- export const test = base.extend({
123
- network: async ({ page }, use) => {
124
- const interceptedRoutes = new Map();
125
-
126
- const interceptRoute = async (method: string, url: string, response: unknown) => {
127
- await page.route(url, (route) => {
128
- if (route.request().method() === method) {
129
- route.fulfill({ body: JSON.stringify(response) });
130
- }
131
- });
132
- interceptedRoutes.set(`${method}:${url}`, response);
133
- };
134
-
135
- await use({ interceptRoute });
136
-
137
- // Cleanup
138
- interceptedRoutes.clear();
139
- },
140
- });
141
-
142
- // auth-fixture.ts
143
- export const test = base.extend({
144
- auth: async ({ page, context }, use) => {
145
- const loginAs = async (email: string) => {
146
- // Use API to setup auth (fast!)
147
- const token = await getAuthToken(email);
148
- await context.addCookies([
149
- {
150
- name: 'auth_token',
151
- value: token,
152
- domain: 'localhost',
153
- path: '/',
154
- },
155
- ]);
156
- };
157
-
158
- await use({ loginAs });
159
- },
160
- });
161
- ```
162
-
163
- **Key Points**:
164
-
165
- - `mergeTests` combines fixtures without inheritance
166
- - Each fixture has single responsibility (network, auth, logs)
167
- - Tests import merged fixture and access all capabilities
168
- - No coupling between fixtures—add/remove freely
169
-
170
- ### Example 3: Framework-Agnostic HTTP Helper
171
-
172
- **Context**: When building HTTP helpers, keep them framework-agnostic. Accept all params explicitly so they work in unit tests, Playwright, Cypress, or any context.
173
-
174
- **Implementation**:
175
-
176
- ```typescript
177
- // shared/helpers/http-helper.ts
178
- // Pure, framework-agnostic function
179
- type HttpHelperParams = {
180
- baseUrl: string;
181
- endpoint: string;
182
- method: 'GET' | 'POST' | 'PUT' | 'DELETE';
183
- body?: unknown;
184
- headers?: Record<string, string>;
185
- token?: string;
186
- };
187
-
188
- export async function makeHttpRequest({ baseUrl, endpoint, method, body, headers = {}, token }: HttpHelperParams): Promise<unknown> {
189
- const url = `${baseUrl}${endpoint}`;
190
- const requestHeaders = {
191
- 'Content-Type': 'application/json',
192
- ...(token && { Authorization: `Bearer ${token}` }),
193
- ...headers,
194
- };
195
-
196
- const response = await fetch(url, {
197
- method,
198
- headers: requestHeaders,
199
- body: body ? JSON.stringify(body) : undefined,
200
- });
201
-
202
- if (!response.ok) {
203
- const errorText = await response.text();
204
- throw new Error(`HTTP ${method} ${url} failed: ${response.status} ${errorText}`);
205
- }
206
-
207
- return response.json();
208
- }
209
-
210
- // Playwright fixture wrapper
211
- // playwright/support/fixtures/http-fixture.ts
212
- import { test as base } from '@playwright/test';
213
- import { makeHttpRequest } from '../../shared/helpers/http-helper';
214
-
215
- export const test = base.extend({
216
- httpHelper: async ({}, use) => {
217
- const baseUrl = process.env.API_BASE_URL || 'http://localhost:3000';
218
-
219
- await use((params) => makeHttpRequest({ baseUrl, ...params }));
220
- },
221
- });
222
-
223
- // Cypress command wrapper
224
- // cypress/support/commands.ts
225
- import { makeHttpRequest } from '../../shared/helpers/http-helper';
226
-
227
- Cypress.Commands.add('apiRequest', (params) => {
228
- const baseUrl = Cypress.env('API_BASE_URL') || 'http://localhost:3000';
229
- return cy.wrap(makeHttpRequest({ baseUrl, ...params }));
230
- });
231
- ```
232
-
233
- **Key Points**:
234
-
235
- - Pure function uses only standard `fetch`, no framework dependencies
236
- - Unit tests call `makeHttpRequest` directly with all params
237
- - Playwright and Cypress wrappers inject framework-specific config
238
- - Same logic runs everywhere—zero duplication
239
-
240
- ### Example 4: Fixture Cleanup Pattern
241
-
242
- **Context**: When fixtures create resources (data, files, connections), ensure automatic cleanup in fixture teardown. Tests must not leak state.
243
-
244
- **Implementation**:
245
-
246
- ```typescript
247
- // playwright/support/fixtures/database-fixture.ts
248
- import { test as base } from '@playwright/test';
249
- import { seedDatabase, deleteRecord } from '../helpers/db-helpers';
250
-
251
- type DatabaseFixture = {
252
- seedUser: (userData: Partial<User>) => Promise<User>;
253
- seedOrder: (orderData: Partial<Order>) => Promise<Order>;
254
- };
255
-
256
- export const test = base.extend<DatabaseFixture>({
257
- seedUser: async ({}, use) => {
258
- const createdUsers: string[] = [];
259
-
260
- const seedUser = async (userData: Partial<User>) => {
261
- const user = await seedDatabase('users', userData);
262
- createdUsers.push(user.id);
263
- return user;
264
- };
265
-
266
- await use(seedUser);
267
-
268
- // Auto-cleanup: Delete all users created during test
269
- for (const userId of createdUsers) {
270
- await deleteRecord('users', userId);
271
- }
272
- createdUsers.length = 0;
273
- },
274
-
275
- seedOrder: async ({}, use) => {
276
- const createdOrders: string[] = [];
277
-
278
- const seedOrder = async (orderData: Partial<Order>) => {
279
- const order = await seedDatabase('orders', orderData);
280
- createdOrders.push(order.id);
281
- return order;
282
- };
283
-
284
- await use(seedOrder);
285
-
286
- // Auto-cleanup: Delete all orders
287
- for (const orderId of createdOrders) {
288
- await deleteRecord('orders', orderId);
289
- }
290
- createdOrders.length = 0;
291
- },
292
- });
293
-
294
- // Example usage:
295
- // test('user can place order', async ({ seedUser, seedOrder, page }) => {
296
- // const user = await seedUser({ email: 'test@example.com' });
297
- // const order = await seedOrder({ userId: user.id, total: 100 });
298
- //
299
- // await page.goto(`/orders/${order.id}`);
300
- // await expect(page.getByText('Order Total: $100')).toBeVisible();
301
- //
302
- // // No manual cleanup needed—fixture handles it automatically
303
- // });
304
- ```
305
-
306
- **Key Points**:
307
-
308
- - Track all created resources in array during test execution
309
- - Teardown (after `use()`) deletes all tracked resources
310
- - Tests don't manually clean up—happens automatically
311
- - Prevents test pollution and flakiness from shared state
312
-
313
- ### Anti-Pattern: Inheritance-Based Page Objects
314
-
315
- **Problem**:
316
-
317
- ```typescript
318
- // ❌ BAD: Page Object Model with inheritance
319
- class BasePage {
320
- constructor(public page: Page) {}
321
-
322
- async navigate(url: string) {
323
- await this.page.goto(url);
324
- }
325
-
326
- async clickButton(selector: string) {
327
- await this.page.click(selector);
328
- }
329
- }
330
-
331
- class LoginPage extends BasePage {
332
- async login(email: string, password: string) {
333
- await this.navigate('/login');
334
- await this.page.fill('#email', email);
335
- await this.page.fill('#password', password);
336
- await this.clickButton('#submit');
337
- }
338
- }
339
-
340
- class AdminPage extends LoginPage {
341
- async accessAdminPanel() {
342
- await this.login('admin@example.com', 'admin123');
343
- await this.navigate('/admin');
344
- }
345
- }
346
- ```
347
-
348
- **Why It Fails**:
349
-
350
- - Changes to `BasePage` break all descendants (`LoginPage`, `AdminPage`)
351
- - `AdminPage` inherits unnecessary `login` details—tight coupling
352
- - Cannot compose capabilities (e.g., admin + reporting features require multiple inheritance)
353
- - Hard to test `BasePage` methods in isolation
354
- - Hidden state in class instances leads to unpredictable behavior
355
-
356
- **Better Approach**: Use pure functions + fixtures
357
-
358
- ```typescript
359
- // ✅ GOOD: Pure functions with fixture composition
360
- // helpers/navigation.ts
361
- export async function navigate(page: Page, url: string) {
362
- await page.goto(url);
363
- }
364
-
365
- // helpers/auth.ts
366
- export async function login(page: Page, email: string, password: string) {
367
- await page.fill('[data-testid="email"]', email);
368
- await page.fill('[data-testid="password"]', password);
369
- await page.click('[data-testid="submit"]');
370
- }
371
-
372
- // fixtures/admin-fixture.ts
373
- export const test = base.extend({
374
- adminPage: async ({ page }, use) => {
375
- await login(page, 'admin@example.com', 'admin123');
376
- await navigate(page, '/admin');
377
- await use(page);
378
- },
379
- });
380
-
381
- // Tests import exactly what they need—no inheritance
382
- ```
383
-
384
- ## Integration Points
385
-
386
- - **Used in workflows**: `*atdd` (test generation), `*automate` (test expansion), `*framework` (initial setup)
387
- - **Related fragments**:
388
- - `data-factories.md` - Factory functions for test data
389
- - `network-first.md` - Network interception patterns
390
- - `test-quality.md` - Deterministic test design principles
391
-
392
- ## Helper Function Reuse Guidelines
393
-
394
- When deciding whether to create a fixture, follow these rules:
395
-
396
- - **3+ uses** → Create fixture with subpath export (shared across tests/projects)
397
- - **2-3 uses** → Create utility module (shared within project)
398
- - **1 use** → Keep inline (avoid premature abstraction)
399
- - **Complex logic** → Factory function pattern (dynamic data generation)
400
-
401
- _Source: Murat Testing Philosophy (lines 74-122), SEON production patterns, Playwright fixture docs._