agentvibes 2.13.7 → 2.13.8

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 (421) hide show
  1. package/.claude/personalities/rapper.md +1 -1
  2. package/README.md +7 -8
  3. package/package.json +1 -1
  4. package/src/installer.js +6 -13
  5. package/.bmad/_cfg/agent-manifest.csv +0 -11
  6. package/.bmad/_cfg/agent-voice-map.csv +0 -11
  7. package/.bmad/_cfg/agents/bmm-analyst.customize.yaml +0 -42
  8. package/.bmad/_cfg/agents/bmm-architect.customize.yaml +0 -42
  9. package/.bmad/_cfg/agents/bmm-dev.customize.yaml +0 -42
  10. package/.bmad/_cfg/agents/bmm-frame-expert.customize.yaml +0 -42
  11. package/.bmad/_cfg/agents/bmm-pm.customize.yaml +0 -42
  12. package/.bmad/_cfg/agents/bmm-sm.customize.yaml +0 -42
  13. package/.bmad/_cfg/agents/bmm-tea.customize.yaml +0 -42
  14. package/.bmad/_cfg/agents/bmm-tech-writer.customize.yaml +0 -42
  15. package/.bmad/_cfg/agents/bmm-ux-designer.customize.yaml +0 -42
  16. package/.bmad/_cfg/agents/core-bmad-master.customize.yaml +0 -42
  17. package/.bmad/_cfg/files-manifest.csv +0 -243
  18. package/.bmad/_cfg/ides/claude-code.yaml +0 -6
  19. package/.bmad/_cfg/manifest.yaml +0 -9
  20. package/.bmad/_cfg/task-manifest.csv +0 -5
  21. package/.bmad/_cfg/tool-manifest.csv +0 -2
  22. package/.bmad/_cfg/workflow-manifest.csv +0 -38
  23. package/.bmad/bmm/README.md +0 -128
  24. package/.bmad/bmm/agents/analyst.md +0 -79
  25. package/.bmad/bmm/agents/analyst.md.backup-pre-tts +0 -75
  26. package/.bmad/bmm/agents/architect.md +0 -80
  27. package/.bmad/bmm/agents/dev.md +0 -70
  28. package/.bmad/bmm/agents/frame-expert.md +0 -72
  29. package/.bmad/bmm/agents/pm.md +0 -84
  30. package/.bmad/bmm/agents/sm.md +0 -93
  31. package/.bmad/bmm/agents/tea.md +0 -80
  32. package/.bmad/bmm/agents/tech-writer.md +0 -84
  33. package/.bmad/bmm/agents/ux-designer.md +0 -79
  34. package/.bmad/bmm/config.yaml +0 -17
  35. package/.bmad/bmm/docs/README.md +0 -236
  36. package/.bmad/bmm/docs/agents-guide.md +0 -1058
  37. package/.bmad/bmm/docs/brownfield-guide.md +0 -762
  38. package/.bmad/bmm/docs/enterprise-agentic-development.md +0 -686
  39. package/.bmad/bmm/docs/faq.md +0 -588
  40. package/.bmad/bmm/docs/glossary.md +0 -320
  41. package/.bmad/bmm/docs/party-mode.md +0 -224
  42. package/.bmad/bmm/docs/quick-spec-flow.md +0 -652
  43. package/.bmad/bmm/docs/quick-start.md +0 -376
  44. package/.bmad/bmm/docs/scale-adaptive-system.md +0 -612
  45. package/.bmad/bmm/docs/test-architecture.md +0 -396
  46. package/.bmad/bmm/docs/workflow-architecture-reference.md +0 -366
  47. package/.bmad/bmm/docs/workflow-document-project-reference.md +0 -489
  48. package/.bmad/bmm/docs/workflows-analysis.md +0 -370
  49. package/.bmad/bmm/docs/workflows-implementation.md +0 -286
  50. package/.bmad/bmm/docs/workflows-planning.md +0 -612
  51. package/.bmad/bmm/docs/workflows-solutioning.md +0 -554
  52. package/.bmad/bmm/teams/default-party.csv +0 -20
  53. package/.bmad/bmm/teams/team-fullstack.yaml +0 -13
  54. package/.bmad/bmm/testarch/knowledge/ci-burn-in.md +0 -675
  55. package/.bmad/bmm/testarch/knowledge/component-tdd.md +0 -486
  56. package/.bmad/bmm/testarch/knowledge/contract-testing.md +0 -957
  57. package/.bmad/bmm/testarch/knowledge/data-factories.md +0 -500
  58. package/.bmad/bmm/testarch/knowledge/email-auth.md +0 -721
  59. package/.bmad/bmm/testarch/knowledge/error-handling.md +0 -725
  60. package/.bmad/bmm/testarch/knowledge/feature-flags.md +0 -750
  61. package/.bmad/bmm/testarch/knowledge/fixture-architecture.md +0 -401
  62. package/.bmad/bmm/testarch/knowledge/network-first.md +0 -486
  63. package/.bmad/bmm/testarch/knowledge/nfr-criteria.md +0 -670
  64. package/.bmad/bmm/testarch/knowledge/playwright-config.md +0 -730
  65. package/.bmad/bmm/testarch/knowledge/probability-impact.md +0 -601
  66. package/.bmad/bmm/testarch/knowledge/risk-governance.md +0 -615
  67. package/.bmad/bmm/testarch/knowledge/selective-testing.md +0 -732
  68. package/.bmad/bmm/testarch/knowledge/selector-resilience.md +0 -527
  69. package/.bmad/bmm/testarch/knowledge/test-healing-patterns.md +0 -644
  70. package/.bmad/bmm/testarch/knowledge/test-levels-framework.md +0 -473
  71. package/.bmad/bmm/testarch/knowledge/test-priorities-matrix.md +0 -373
  72. package/.bmad/bmm/testarch/knowledge/test-quality.md +0 -664
  73. package/.bmad/bmm/testarch/knowledge/timing-debugging.md +0 -372
  74. package/.bmad/bmm/testarch/knowledge/visual-debugging.md +0 -524
  75. package/.bmad/bmm/testarch/tea-index.csv +0 -22
  76. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/instructions.md +0 -112
  77. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/project-context.md +0 -25
  78. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/workflow.yaml +0 -26
  79. package/.bmad/bmm/workflows/1-analysis/domain-research/instructions.md +0 -425
  80. package/.bmad/bmm/workflows/1-analysis/domain-research/template.md +0 -180
  81. package/.bmad/bmm/workflows/1-analysis/domain-research/workflow.yaml +0 -28
  82. package/.bmad/bmm/workflows/1-analysis/product-brief/checklist.md +0 -115
  83. package/.bmad/bmm/workflows/1-analysis/product-brief/instructions.md +0 -524
  84. package/.bmad/bmm/workflows/1-analysis/product-brief/template.md +0 -181
  85. package/.bmad/bmm/workflows/1-analysis/product-brief/workflow.yaml +0 -45
  86. package/.bmad/bmm/workflows/1-analysis/research/checklist-deep-prompt.md +0 -144
  87. package/.bmad/bmm/workflows/1-analysis/research/checklist-technical.md +0 -249
  88. package/.bmad/bmm/workflows/1-analysis/research/checklist.md +0 -299
  89. package/.bmad/bmm/workflows/1-analysis/research/claude-code/injections.yaml +0 -114
  90. package/.bmad/bmm/workflows/1-analysis/research/instructions-deep-prompt.md +0 -438
  91. package/.bmad/bmm/workflows/1-analysis/research/instructions-market.md +0 -675
  92. package/.bmad/bmm/workflows/1-analysis/research/instructions-router.md +0 -134
  93. package/.bmad/bmm/workflows/1-analysis/research/instructions-technical.md +0 -534
  94. package/.bmad/bmm/workflows/1-analysis/research/template-deep-prompt.md +0 -94
  95. package/.bmad/bmm/workflows/1-analysis/research/template-market.md +0 -347
  96. package/.bmad/bmm/workflows/1-analysis/research/template-technical.md +0 -245
  97. package/.bmad/bmm/workflows/1-analysis/research/workflow.yaml +0 -44
  98. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/epics-template.md +0 -80
  99. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/instructions.md +0 -616
  100. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/workflow.yaml +0 -53
  101. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/checklist.md +0 -310
  102. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/instructions.md +0 -1308
  103. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +0 -145
  104. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.yaml +0 -61
  105. package/.bmad/bmm/workflows/2-plan-workflows/prd/checklist.md +0 -346
  106. package/.bmad/bmm/workflows/2-plan-workflows/prd/domain-complexity.csv +0 -13
  107. package/.bmad/bmm/workflows/2-plan-workflows/prd/instructions.md +0 -703
  108. package/.bmad/bmm/workflows/2-plan-workflows/prd/prd-template.md +0 -204
  109. package/.bmad/bmm/workflows/2-plan-workflows/prd/project-types.csv +0 -11
  110. package/.bmad/bmm/workflows/2-plan-workflows/prd/workflow.yaml +0 -52
  111. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/checklist.md +0 -217
  112. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/epics-template.md +0 -74
  113. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions-generate-stories.md +0 -436
  114. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions.md +0 -980
  115. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/tech-spec-template.md +0 -181
  116. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/user-story-template.md +0 -90
  117. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/workflow.yaml +0 -58
  118. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-patterns.yaml +0 -321
  119. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-template.md +0 -103
  120. package/.bmad/bmm/workflows/3-solutioning/architecture/checklist.md +0 -240
  121. package/.bmad/bmm/workflows/3-solutioning/architecture/decision-catalog.yaml +0 -222
  122. package/.bmad/bmm/workflows/3-solutioning/architecture/instructions.md +0 -768
  123. package/.bmad/bmm/workflows/3-solutioning/architecture/pattern-categories.csv +0 -13
  124. package/.bmad/bmm/workflows/3-solutioning/architecture/workflow.yaml +0 -55
  125. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/checklist.md +0 -169
  126. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/instructions.md +0 -332
  127. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/template.md +0 -146
  128. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/workflow.yaml +0 -62
  129. package/.bmad/bmm/workflows/4-implementation/code-review/backlog_template.md +0 -12
  130. package/.bmad/bmm/workflows/4-implementation/code-review/checklist.md +0 -22
  131. package/.bmad/bmm/workflows/4-implementation/code-review/instructions.md +0 -398
  132. package/.bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +0 -60
  133. package/.bmad/bmm/workflows/4-implementation/correct-course/checklist.md +0 -279
  134. package/.bmad/bmm/workflows/4-implementation/correct-course/instructions.md +0 -206
  135. package/.bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +0 -56
  136. package/.bmad/bmm/workflows/4-implementation/create-story/checklist.md +0 -240
  137. package/.bmad/bmm/workflows/4-implementation/create-story/instructions.md +0 -256
  138. package/.bmad/bmm/workflows/4-implementation/create-story/template.md +0 -51
  139. package/.bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +0 -71
  140. package/.bmad/bmm/workflows/4-implementation/dev-story/checklist.md +0 -38
  141. package/.bmad/bmm/workflows/4-implementation/dev-story/instructions.md +0 -267
  142. package/.bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +0 -56
  143. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/checklist.md +0 -17
  144. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/instructions.md +0 -164
  145. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/template.md +0 -76
  146. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/workflow.yaml +0 -57
  147. package/.bmad/bmm/workflows/4-implementation/retrospective/instructions.md +0 -1443
  148. package/.bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +0 -56
  149. package/.bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +0 -33
  150. package/.bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +0 -234
  151. package/.bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +0 -55
  152. package/.bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +0 -49
  153. package/.bmad/bmm/workflows/4-implementation/story-context/checklist.md +0 -16
  154. package/.bmad/bmm/workflows/4-implementation/story-context/context-template.xml +0 -34
  155. package/.bmad/bmm/workflows/4-implementation/story-context/instructions.md +0 -209
  156. package/.bmad/bmm/workflows/4-implementation/story-context/workflow.yaml +0 -61
  157. package/.bmad/bmm/workflows/4-implementation/story-done/instructions.md +0 -111
  158. package/.bmad/bmm/workflows/4-implementation/story-done/workflow.yaml +0 -26
  159. package/.bmad/bmm/workflows/4-implementation/story-ready/instructions.md +0 -117
  160. package/.bmad/bmm/workflows/4-implementation/story-ready/workflow.yaml +0 -23
  161. package/.bmad/bmm/workflows/document-project/checklist.md +0 -245
  162. package/.bmad/bmm/workflows/document-project/documentation-requirements.csv +0 -12
  163. package/.bmad/bmm/workflows/document-project/instructions.md +0 -222
  164. package/.bmad/bmm/workflows/document-project/templates/deep-dive-template.md +0 -345
  165. package/.bmad/bmm/workflows/document-project/templates/index-template.md +0 -169
  166. package/.bmad/bmm/workflows/document-project/templates/project-overview-template.md +0 -103
  167. package/.bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +0 -160
  168. package/.bmad/bmm/workflows/document-project/templates/source-tree-template.md +0 -135
  169. package/.bmad/bmm/workflows/document-project/workflow.yaml +0 -29
  170. package/.bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +0 -298
  171. package/.bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +0 -31
  172. package/.bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +0 -1106
  173. package/.bmad/bmm/workflows/document-project/workflows/full-scan.yaml +0 -31
  174. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-helpers.md +0 -127
  175. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-library.json +0 -90
  176. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-templates.yaml +0 -127
  177. package/.bmad/bmm/workflows/frame-expert/_shared/validate-json-instructions.md +0 -79
  178. package/.bmad/bmm/workflows/frame-expert/create-dataflow/checklist.md +0 -39
  179. package/.bmad/bmm/workflows/frame-expert/create-dataflow/instructions.md +0 -131
  180. package/.bmad/bmm/workflows/frame-expert/create-dataflow/workflow.yaml +0 -23
  181. package/.bmad/bmm/workflows/frame-expert/create-diagram/checklist.md +0 -43
  182. package/.bmad/bmm/workflows/frame-expert/create-diagram/instructions.md +0 -142
  183. package/.bmad/bmm/workflows/frame-expert/create-diagram/workflow.yaml +0 -24
  184. package/.bmad/bmm/workflows/frame-expert/create-flowchart/checklist.md +0 -49
  185. package/.bmad/bmm/workflows/frame-expert/create-flowchart/instructions.md +0 -242
  186. package/.bmad/bmm/workflows/frame-expert/create-flowchart/workflow.yaml +0 -27
  187. package/.bmad/bmm/workflows/frame-expert/create-wireframe/checklist.md +0 -38
  188. package/.bmad/bmm/workflows/frame-expert/create-wireframe/instructions.md +0 -133
  189. package/.bmad/bmm/workflows/frame-expert/create-wireframe/workflow.yaml +0 -23
  190. package/.bmad/bmm/workflows/techdoc/documentation-standards.md +0 -262
  191. package/.bmad/bmm/workflows/testarch/atdd/atdd-checklist-template.md +0 -363
  192. package/.bmad/bmm/workflows/testarch/atdd/checklist.md +0 -373
  193. package/.bmad/bmm/workflows/testarch/atdd/instructions.md +0 -785
  194. package/.bmad/bmm/workflows/testarch/atdd/workflow.yaml +0 -45
  195. package/.bmad/bmm/workflows/testarch/automate/checklist.md +0 -580
  196. package/.bmad/bmm/workflows/testarch/automate/instructions.md +0 -1303
  197. package/.bmad/bmm/workflows/testarch/automate/workflow.yaml +0 -52
  198. package/.bmad/bmm/workflows/testarch/ci/checklist.md +0 -246
  199. package/.bmad/bmm/workflows/testarch/ci/github-actions-template.yaml +0 -165
  200. package/.bmad/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +0 -128
  201. package/.bmad/bmm/workflows/testarch/ci/instructions.md +0 -517
  202. package/.bmad/bmm/workflows/testarch/ci/workflow.yaml +0 -45
  203. package/.bmad/bmm/workflows/testarch/framework/checklist.md +0 -321
  204. package/.bmad/bmm/workflows/testarch/framework/instructions.md +0 -455
  205. package/.bmad/bmm/workflows/testarch/framework/workflow.yaml +0 -47
  206. package/.bmad/bmm/workflows/testarch/nfr-assess/checklist.md +0 -405
  207. package/.bmad/bmm/workflows/testarch/nfr-assess/instructions.md +0 -722
  208. package/.bmad/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +0 -443
  209. package/.bmad/bmm/workflows/testarch/nfr-assess/workflow.yaml +0 -47
  210. package/.bmad/bmm/workflows/testarch/test-design/checklist.md +0 -234
  211. package/.bmad/bmm/workflows/testarch/test-design/instructions.md +0 -782
  212. package/.bmad/bmm/workflows/testarch/test-design/test-design-template.md +0 -285
  213. package/.bmad/bmm/workflows/testarch/test-design/workflow.yaml +0 -48
  214. package/.bmad/bmm/workflows/testarch/test-review/checklist.md +0 -470
  215. package/.bmad/bmm/workflows/testarch/test-review/instructions.md +0 -608
  216. package/.bmad/bmm/workflows/testarch/test-review/test-review-template.md +0 -388
  217. package/.bmad/bmm/workflows/testarch/test-review/workflow.yaml +0 -46
  218. package/.bmad/bmm/workflows/testarch/trace/checklist.md +0 -654
  219. package/.bmad/bmm/workflows/testarch/trace/instructions.md +0 -1045
  220. package/.bmad/bmm/workflows/testarch/trace/trace-template.md +0 -673
  221. package/.bmad/bmm/workflows/testarch/trace/workflow.yaml +0 -55
  222. package/.bmad/bmm/workflows/workflow-status/init/instructions.md +0 -334
  223. package/.bmad/bmm/workflows/workflow-status/init/workflow.yaml +0 -28
  224. package/.bmad/bmm/workflows/workflow-status/instructions.md +0 -388
  225. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-brownfield.yaml +0 -138
  226. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-greenfield.yaml +0 -126
  227. package/.bmad/bmm/workflows/workflow-status/paths/game-design.yaml +0 -52
  228. package/.bmad/bmm/workflows/workflow-status/paths/method-brownfield.yaml +0 -122
  229. package/.bmad/bmm/workflows/workflow-status/paths/method-greenfield.yaml +0 -113
  230. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-brownfield.yaml +0 -58
  231. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-greenfield.yaml +0 -47
  232. package/.bmad/bmm/workflows/workflow-status/project-levels.yaml +0 -59
  233. package/.bmad/bmm/workflows/workflow-status/workflow-status-template.yaml +0 -24
  234. package/.bmad/bmm/workflows/workflow-status/workflow.yaml +0 -28
  235. package/.bmad/core/agents/bmad-master.md +0 -72
  236. package/.bmad/core/agents/bmad-web-orchestrator.agent.xml +0 -113
  237. package/.bmad/core/config.yaml +0 -11
  238. package/.bmad/core/tasks/adv-elicit-methods.csv +0 -39
  239. package/.bmad/core/tasks/advanced-elicitation-methods.csv +0 -21
  240. package/.bmad/core/tasks/advanced-elicitation.xml +0 -106
  241. package/.bmad/core/tasks/index-docs.xml +0 -65
  242. package/.bmad/core/tasks/validate-workflow.xml +0 -89
  243. package/.bmad/core/tasks/workflow.xml +0 -270
  244. package/.bmad/core/tools/shard-doc.xml +0 -109
  245. package/.bmad/core/workflows/brainstorming/README.md +0 -261
  246. package/.bmad/core/workflows/brainstorming/brain-methods.csv +0 -36
  247. package/.bmad/core/workflows/brainstorming/instructions.md +0 -315
  248. package/.bmad/core/workflows/brainstorming/template.md +0 -106
  249. package/.bmad/core/workflows/brainstorming/workflow.yaml +0 -38
  250. package/.bmad/core/workflows/party-mode/instructions.md +0 -203
  251. package/.bmad/core/workflows/party-mode/workflow.yaml +0 -28
  252. package/.bmad/docs/claude-code-instructions.md +0 -25
  253. package/.claude/commands/BMad/analyst.md +0 -88
  254. package/.claude/commands/BMad/architect.md +0 -89
  255. package/.claude/commands/BMad/bmad-master.md +0 -114
  256. package/.claude/commands/BMad/bmad-orchestrator.md +0 -151
  257. package/.claude/commands/BMad/dev.md +0 -85
  258. package/.claude/commands/BMad/pm.md +0 -88
  259. package/.claude/commands/BMad/po.md +0 -83
  260. package/.claude/commands/BMad/qa.md +0 -91
  261. package/.claude/commands/BMad/sm.md +0 -69
  262. package/.claude/commands/BMad/tasks/advanced-elicitation.md +0 -123
  263. package/.claude/commands/BMad/tasks/apply-qa-fixes.md +0 -154
  264. package/.claude/commands/BMad/tasks/brownfield-create-epic.md +0 -166
  265. package/.claude/commands/BMad/tasks/brownfield-create-story.md +0 -153
  266. package/.claude/commands/BMad/tasks/correct-course.md +0 -76
  267. package/.claude/commands/BMad/tasks/create-brownfield-story.md +0 -318
  268. package/.claude/commands/BMad/tasks/create-deep-research-prompt.md +0 -284
  269. package/.claude/commands/BMad/tasks/create-doc.md +0 -107
  270. package/.claude/commands/BMad/tasks/create-next-story.md +0 -118
  271. package/.claude/commands/BMad/tasks/document-project.md +0 -349
  272. package/.claude/commands/BMad/tasks/execute-checklist.md +0 -92
  273. package/.claude/commands/BMad/tasks/facilitate-brainstorming-session.md +0 -142
  274. package/.claude/commands/BMad/tasks/generate-ai-frontend-prompt.md +0 -57
  275. package/.claude/commands/BMad/tasks/index-docs.md +0 -179
  276. package/.claude/commands/BMad/tasks/kb-mode-interaction.md +0 -81
  277. package/.claude/commands/BMad/tasks/nfr-assess.md +0 -349
  278. package/.claude/commands/BMad/tasks/qa-gate.md +0 -167
  279. package/.claude/commands/BMad/tasks/review-story.md +0 -320
  280. package/.claude/commands/BMad/tasks/risk-profile.md +0 -359
  281. package/.claude/commands/BMad/tasks/shard-doc.md +0 -191
  282. package/.claude/commands/BMad/tasks/test-design.md +0 -180
  283. package/.claude/commands/BMad/tasks/trace-requirements.md +0 -270
  284. package/.claude/commands/BMad/tasks/validate-next-story.md +0 -140
  285. package/.claude/commands/BMad/ux-expert.md +0 -73
  286. package/.claude/commands/bmad/bmm/agents/analyst.md +0 -14
  287. package/.claude/commands/bmad/bmm/agents/architect.md +0 -14
  288. package/.claude/commands/bmad/bmm/agents/dev.md +0 -14
  289. package/.claude/commands/bmad/bmm/agents/frame-expert.md +0 -14
  290. package/.claude/commands/bmad/bmm/agents/pm.md +0 -14
  291. package/.claude/commands/bmad/bmm/agents/sm.md +0 -14
  292. package/.claude/commands/bmad/bmm/agents/tea.md +0 -14
  293. package/.claude/commands/bmad/bmm/agents/tech-writer.md +0 -14
  294. package/.claude/commands/bmad/bmm/agents/ux-designer.md +0 -14
  295. package/.claude/commands/bmad/bmm/workflows/architecture.md +0 -13
  296. package/.claude/commands/bmad/bmm/workflows/brainstorm-project.md +0 -13
  297. package/.claude/commands/bmad/bmm/workflows/code-review.md +0 -13
  298. package/.claude/commands/bmad/bmm/workflows/correct-course.md +0 -13
  299. package/.claude/commands/bmad/bmm/workflows/create-dataflow.md +0 -13
  300. package/.claude/commands/bmad/bmm/workflows/create-diagram.md +0 -13
  301. package/.claude/commands/bmad/bmm/workflows/create-epics-and-stories.md +0 -13
  302. package/.claude/commands/bmad/bmm/workflows/create-flowchart.md +0 -13
  303. package/.claude/commands/bmad/bmm/workflows/create-story.md +0 -13
  304. package/.claude/commands/bmad/bmm/workflows/create-ux-design.md +0 -13
  305. package/.claude/commands/bmad/bmm/workflows/create-wireframe.md +0 -13
  306. package/.claude/commands/bmad/bmm/workflows/dev-story.md +0 -13
  307. package/.claude/commands/bmad/bmm/workflows/document-project.md +0 -13
  308. package/.claude/commands/bmad/bmm/workflows/domain-research.md +0 -13
  309. package/.claude/commands/bmad/bmm/workflows/epic-tech-context.md +0 -13
  310. package/.claude/commands/bmad/bmm/workflows/implementation-readiness.md +0 -13
  311. package/.claude/commands/bmad/bmm/workflows/prd.md +0 -13
  312. package/.claude/commands/bmad/bmm/workflows/product-brief.md +0 -13
  313. package/.claude/commands/bmad/bmm/workflows/research.md +0 -13
  314. package/.claude/commands/bmad/bmm/workflows/retrospective.md +0 -13
  315. package/.claude/commands/bmad/bmm/workflows/sprint-planning.md +0 -13
  316. package/.claude/commands/bmad/bmm/workflows/story-context.md +0 -13
  317. package/.claude/commands/bmad/bmm/workflows/story-done.md +0 -13
  318. package/.claude/commands/bmad/bmm/workflows/story-ready.md +0 -13
  319. package/.claude/commands/bmad/bmm/workflows/tech-spec.md +0 -13
  320. package/.claude/commands/bmad/bmm/workflows/workflow-init.md +0 -13
  321. package/.claude/commands/bmad/bmm/workflows/workflow-status.md +0 -13
  322. package/.claude/commands/bmad/core/agents/bmad-master.md +0 -14
  323. package/.claude/commands/bmad/core/tasks/advanced-elicitation.md +0 -9
  324. package/.claude/commands/bmad/core/tasks/index-docs.md +0 -9
  325. package/.claude/commands/bmad/core/tools/shard-doc.md +0 -9
  326. package/.claude/commands/bmad/core/workflows/brainstorming.md +0 -13
  327. package/.claude/commands/bmad/core/workflows/party-mode.md +0 -13
  328. package/.claude/github-star-reminder.txt +0 -1
  329. package/.claude/hooks/bmad-party-manager.sh +0 -225
  330. package/.claude/hooks/stop.sh +0 -221
  331. package/.claude/piper-voices-dir.txt +0 -1
  332. package/.mcp.json +0 -88
  333. package/RELEASE_NOTES_v2.4.0_DRAFT.md +0 -116
  334. package/RELEASE_NOTES_v2.4.1_DRAFT.md +0 -61
  335. package/docs/2025-11-15_15-14-33.snagx +0 -0
  336. package/docs/Screenshot 2025-11-15 151325.png +0 -0
  337. package/docs/Screenshot 2025-11-15 151432.png +0 -0
  338. package/docs/macos-piper-issue.md +0 -172
  339. package/docs/stargazer-cms-prd.md +0 -1918
  340. package/docs/whatsapp-plugin-github-issue.md +0 -393
  341. package/docs/whatsapp-tts-plugin-feasibility.md +0 -418
  342. package/docs/whatsapp-tts-standalone-plugin.md +0 -628
  343. package/github-profile-draft.md +0 -57
  344. package/linkedin/vibe-coding-and-pulseaudio.md +0 -121
  345. package/mcp-server/agentvibes.db +0 -0
  346. package/scripts/audio-tunnel.config +0 -17
  347. package/v4-backup/.bmad-core/agent-teams/team-all.yaml +0 -15
  348. package/v4-backup/.bmad-core/agent-teams/team-fullstack.yaml +0 -19
  349. package/v4-backup/.bmad-core/agent-teams/team-ide-minimal.yaml +0 -11
  350. package/v4-backup/.bmad-core/agent-teams/team-no-ui.yaml +0 -14
  351. package/v4-backup/.bmad-core/agents/analyst.md +0 -84
  352. package/v4-backup/.bmad-core/agents/architect.md +0 -85
  353. package/v4-backup/.bmad-core/agents/bmad-master.md +0 -110
  354. package/v4-backup/.bmad-core/agents/bmad-orchestrator.md +0 -147
  355. package/v4-backup/.bmad-core/agents/dev.md +0 -81
  356. package/v4-backup/.bmad-core/agents/pm.md +0 -84
  357. package/v4-backup/.bmad-core/agents/po.md +0 -79
  358. package/v4-backup/.bmad-core/agents/qa.md +0 -87
  359. package/v4-backup/.bmad-core/agents/sm.md +0 -65
  360. package/v4-backup/.bmad-core/agents/ux-expert.md +0 -69
  361. package/v4-backup/.bmad-core/checklists/architect-checklist.md +0 -440
  362. package/v4-backup/.bmad-core/checklists/change-checklist.md +0 -184
  363. package/v4-backup/.bmad-core/checklists/pm-checklist.md +0 -372
  364. package/v4-backup/.bmad-core/checklists/po-master-checklist.md +0 -434
  365. package/v4-backup/.bmad-core/checklists/story-dod-checklist.md +0 -96
  366. package/v4-backup/.bmad-core/checklists/story-draft-checklist.md +0 -155
  367. package/v4-backup/.bmad-core/core-config.yaml +0 -22
  368. package/v4-backup/.bmad-core/data/bmad-kb.md +0 -809
  369. package/v4-backup/.bmad-core/data/brainstorming-techniques.md +0 -38
  370. package/v4-backup/.bmad-core/data/elicitation-methods.md +0 -156
  371. package/v4-backup/.bmad-core/data/technical-preferences.md +0 -5
  372. package/v4-backup/.bmad-core/data/test-levels-framework.md +0 -148
  373. package/v4-backup/.bmad-core/data/test-priorities-matrix.md +0 -174
  374. package/v4-backup/.bmad-core/enhanced-ide-development-workflow.md +0 -248
  375. package/v4-backup/.bmad-core/install-manifest.yaml +0 -230
  376. package/v4-backup/.bmad-core/tasks/advanced-elicitation.md +0 -119
  377. package/v4-backup/.bmad-core/tasks/apply-qa-fixes.md +0 -150
  378. package/v4-backup/.bmad-core/tasks/brownfield-create-epic.md +0 -162
  379. package/v4-backup/.bmad-core/tasks/brownfield-create-story.md +0 -149
  380. package/v4-backup/.bmad-core/tasks/correct-course.md +0 -72
  381. package/v4-backup/.bmad-core/tasks/create-brownfield-story.md +0 -314
  382. package/v4-backup/.bmad-core/tasks/create-deep-research-prompt.md +0 -280
  383. package/v4-backup/.bmad-core/tasks/create-doc.md +0 -103
  384. package/v4-backup/.bmad-core/tasks/create-next-story.md +0 -114
  385. package/v4-backup/.bmad-core/tasks/document-project.md +0 -345
  386. package/v4-backup/.bmad-core/tasks/execute-checklist.md +0 -88
  387. package/v4-backup/.bmad-core/tasks/facilitate-brainstorming-session.md +0 -138
  388. package/v4-backup/.bmad-core/tasks/generate-ai-frontend-prompt.md +0 -53
  389. package/v4-backup/.bmad-core/tasks/index-docs.md +0 -175
  390. package/v4-backup/.bmad-core/tasks/kb-mode-interaction.md +0 -77
  391. package/v4-backup/.bmad-core/tasks/nfr-assess.md +0 -345
  392. package/v4-backup/.bmad-core/tasks/qa-gate.md +0 -163
  393. package/v4-backup/.bmad-core/tasks/review-story.md +0 -316
  394. package/v4-backup/.bmad-core/tasks/risk-profile.md +0 -355
  395. package/v4-backup/.bmad-core/tasks/shard-doc.md +0 -187
  396. package/v4-backup/.bmad-core/tasks/test-design.md +0 -176
  397. package/v4-backup/.bmad-core/tasks/trace-requirements.md +0 -266
  398. package/v4-backup/.bmad-core/tasks/validate-next-story.md +0 -136
  399. package/v4-backup/.bmad-core/templates/architecture-tmpl.yaml +0 -651
  400. package/v4-backup/.bmad-core/templates/brainstorming-output-tmpl.yaml +0 -156
  401. package/v4-backup/.bmad-core/templates/brownfield-architecture-tmpl.yaml +0 -477
  402. package/v4-backup/.bmad-core/templates/brownfield-prd-tmpl.yaml +0 -281
  403. package/v4-backup/.bmad-core/templates/competitor-analysis-tmpl.yaml +0 -307
  404. package/v4-backup/.bmad-core/templates/front-end-architecture-tmpl.yaml +0 -219
  405. package/v4-backup/.bmad-core/templates/front-end-spec-tmpl.yaml +0 -350
  406. package/v4-backup/.bmad-core/templates/fullstack-architecture-tmpl.yaml +0 -824
  407. package/v4-backup/.bmad-core/templates/market-research-tmpl.yaml +0 -253
  408. package/v4-backup/.bmad-core/templates/prd-tmpl.yaml +0 -203
  409. package/v4-backup/.bmad-core/templates/project-brief-tmpl.yaml +0 -222
  410. package/v4-backup/.bmad-core/templates/qa-gate-tmpl.yaml +0 -103
  411. package/v4-backup/.bmad-core/templates/story-tmpl.yaml +0 -138
  412. package/v4-backup/.bmad-core/user-guide.md +0 -577
  413. package/v4-backup/.bmad-core/utils/bmad-doc-template.md +0 -327
  414. package/v4-backup/.bmad-core/utils/workflow-management.md +0 -71
  415. package/v4-backup/.bmad-core/workflows/brownfield-fullstack.yaml +0 -298
  416. package/v4-backup/.bmad-core/workflows/brownfield-service.yaml +0 -188
  417. package/v4-backup/.bmad-core/workflows/brownfield-ui.yaml +0 -198
  418. package/v4-backup/.bmad-core/workflows/greenfield-fullstack.yaml +0 -241
  419. package/v4-backup/.bmad-core/workflows/greenfield-service.yaml +0 -207
  420. package/v4-backup/.bmad-core/workflows/greenfield-ui.yaml +0 -236
  421. package/v4-backup/.bmad-core/working-in-the-brownfield.md +0 -606
@@ -1,500 +0,0 @@
1
- # Data Factories and API-First Setup
2
-
3
- ## Principle
4
-
5
- Prefer factory functions that accept overrides and return complete objects (`createUser(overrides)`). Seed test state through APIs, tasks, or direct DB helpers before visiting the UI—never via slow UI interactions. UI is for validation only, not setup.
6
-
7
- ## Rationale
8
-
9
- Static fixtures (JSON files, hardcoded objects) create brittle tests that:
10
-
11
- - Fail when schemas evolve (missing new required fields)
12
- - Cause collisions in parallel execution (same user IDs)
13
- - Hide test intent (what matters for _this_ test?)
14
-
15
- Dynamic factories with overrides provide:
16
-
17
- - **Parallel safety**: UUIDs and timestamps prevent collisions
18
- - **Schema evolution**: Defaults adapt to schema changes automatically
19
- - **Explicit intent**: Overrides show what matters for each test
20
- - **Speed**: API setup is 10-50x faster than UI
21
-
22
- ## Pattern Examples
23
-
24
- ### Example 1: Factory Function with Overrides
25
-
26
- **Context**: When creating test data, build factory functions with sensible defaults and explicit overrides. Use `faker` for dynamic values that prevent collisions.
27
-
28
- **Implementation**:
29
-
30
- ```typescript
31
- // test-utils/factories/user-factory.ts
32
- import { faker } from '@faker-js/faker';
33
-
34
- type User = {
35
- id: string;
36
- email: string;
37
- name: string;
38
- role: 'user' | 'admin' | 'moderator';
39
- createdAt: Date;
40
- isActive: boolean;
41
- };
42
-
43
- export const createUser = (overrides: Partial<User> = {}): User => ({
44
- id: faker.string.uuid(),
45
- email: faker.internet.email(),
46
- name: faker.person.fullName(),
47
- role: 'user',
48
- createdAt: new Date(),
49
- isActive: true,
50
- ...overrides,
51
- });
52
-
53
- // test-utils/factories/product-factory.ts
54
- type Product = {
55
- id: string;
56
- name: string;
57
- price: number;
58
- stock: number;
59
- category: string;
60
- };
61
-
62
- export const createProduct = (overrides: Partial<Product> = {}): Product => ({
63
- id: faker.string.uuid(),
64
- name: faker.commerce.productName(),
65
- price: parseFloat(faker.commerce.price()),
66
- stock: faker.number.int({ min: 0, max: 100 }),
67
- category: faker.commerce.department(),
68
- ...overrides,
69
- });
70
-
71
- // Usage in tests:
72
- test('admin can delete users', async ({ page, apiRequest }) => {
73
- // Default user
74
- const user = createUser();
75
-
76
- // Admin user (explicit override shows intent)
77
- const admin = createUser({ role: 'admin' });
78
-
79
- // Seed via API (fast!)
80
- await apiRequest({ method: 'POST', url: '/api/users', data: user });
81
- await apiRequest({ method: 'POST', url: '/api/users', data: admin });
82
-
83
- // Now test UI behavior
84
- await page.goto('/admin/users');
85
- await page.click(`[data-testid="delete-user-${user.id}"]`);
86
- await expect(page.getByText(`User ${user.name} deleted`)).toBeVisible();
87
- });
88
- ```
89
-
90
- **Key Points**:
91
-
92
- - `Partial<User>` allows overriding any field without breaking type safety
93
- - Faker generates unique values—no collisions in parallel tests
94
- - Override shows test intent: `createUser({ role: 'admin' })` is explicit
95
- - Factory lives in `test-utils/factories/` for easy reuse
96
-
97
- ### Example 2: Nested Factory Pattern
98
-
99
- **Context**: When testing relationships (orders with users and products), nest factories to create complete object graphs. Control relationship data explicitly.
100
-
101
- **Implementation**:
102
-
103
- ```typescript
104
- // test-utils/factories/order-factory.ts
105
- import { createUser } from './user-factory';
106
- import { createProduct } from './product-factory';
107
-
108
- type OrderItem = {
109
- product: Product;
110
- quantity: number;
111
- price: number;
112
- };
113
-
114
- type Order = {
115
- id: string;
116
- user: User;
117
- items: OrderItem[];
118
- total: number;
119
- status: 'pending' | 'paid' | 'shipped' | 'delivered';
120
- createdAt: Date;
121
- };
122
-
123
- export const createOrderItem = (overrides: Partial<OrderItem> = {}): OrderItem => {
124
- const product = overrides.product || createProduct();
125
- const quantity = overrides.quantity || faker.number.int({ min: 1, max: 5 });
126
-
127
- return {
128
- product,
129
- quantity,
130
- price: product.price * quantity,
131
- ...overrides,
132
- };
133
- };
134
-
135
- export const createOrder = (overrides: Partial<Order> = {}): Order => {
136
- const items = overrides.items || [createOrderItem(), createOrderItem()];
137
- const total = items.reduce((sum, item) => sum + item.price, 0);
138
-
139
- return {
140
- id: faker.string.uuid(),
141
- user: overrides.user || createUser(),
142
- items,
143
- total,
144
- status: 'pending',
145
- createdAt: new Date(),
146
- ...overrides,
147
- };
148
- };
149
-
150
- // Usage in tests:
151
- test('user can view order details', async ({ page, apiRequest }) => {
152
- const user = createUser({ email: 'test@example.com' });
153
- const product1 = createProduct({ name: 'Widget A', price: 10.0 });
154
- const product2 = createProduct({ name: 'Widget B', price: 15.0 });
155
-
156
- // Explicit relationships
157
- const order = createOrder({
158
- user,
159
- items: [
160
- createOrderItem({ product: product1, quantity: 2 }), // $20
161
- createOrderItem({ product: product2, quantity: 1 }), // $15
162
- ],
163
- });
164
-
165
- // Seed via API
166
- await apiRequest({ method: 'POST', url: '/api/users', data: user });
167
- await apiRequest({ method: 'POST', url: '/api/products', data: product1 });
168
- await apiRequest({ method: 'POST', url: '/api/products', data: product2 });
169
- await apiRequest({ method: 'POST', url: '/api/orders', data: order });
170
-
171
- // Test UI
172
- await page.goto(`/orders/${order.id}`);
173
- await expect(page.getByText('Widget A x 2')).toBeVisible();
174
- await expect(page.getByText('Widget B x 1')).toBeVisible();
175
- await expect(page.getByText('Total: $35.00')).toBeVisible();
176
- });
177
- ```
178
-
179
- **Key Points**:
180
-
181
- - Nested factories handle relationships (order → user, order → products)
182
- - Overrides cascade: provide custom user/products or use defaults
183
- - Calculated fields (total) derived automatically from nested data
184
- - Explicit relationships make test data clear and maintainable
185
-
186
- ### Example 3: Factory with API Seeding
187
-
188
- **Context**: When tests need data setup, always use API calls or database tasks—never UI navigation. Wrap factory usage with seeding utilities for clean test setup.
189
-
190
- **Implementation**:
191
-
192
- ```typescript
193
- // playwright/support/helpers/seed-helpers.ts
194
- import { APIRequestContext } from '@playwright/test';
195
- import { User, createUser } from '../../test-utils/factories/user-factory';
196
- import { Product, createProduct } from '../../test-utils/factories/product-factory';
197
-
198
- export async function seedUser(request: APIRequestContext, overrides: Partial<User> = {}): Promise<User> {
199
- const user = createUser(overrides);
200
-
201
- const response = await request.post('/api/users', {
202
- data: user,
203
- });
204
-
205
- if (!response.ok()) {
206
- throw new Error(`Failed to seed user: ${response.status()}`);
207
- }
208
-
209
- return user;
210
- }
211
-
212
- export async function seedProduct(request: APIRequestContext, overrides: Partial<Product> = {}): Promise<Product> {
213
- const product = createProduct(overrides);
214
-
215
- const response = await request.post('/api/products', {
216
- data: product,
217
- });
218
-
219
- if (!response.ok()) {
220
- throw new Error(`Failed to seed product: ${response.status()}`);
221
- }
222
-
223
- return product;
224
- }
225
-
226
- // Playwright globalSetup for shared data
227
- // playwright/support/global-setup.ts
228
- import { chromium, FullConfig } from '@playwright/test';
229
- import { seedUser } from './helpers/seed-helpers';
230
-
231
- async function globalSetup(config: FullConfig) {
232
- const browser = await chromium.launch();
233
- const page = await browser.newPage();
234
- const context = page.context();
235
-
236
- // Seed admin user for all tests
237
- const admin = await seedUser(context.request, {
238
- email: 'admin@example.com',
239
- role: 'admin',
240
- });
241
-
242
- // Save auth state for reuse
243
- await context.storageState({ path: 'playwright/.auth/admin.json' });
244
-
245
- await browser.close();
246
- }
247
-
248
- export default globalSetup;
249
-
250
- // Cypress equivalent with cy.task
251
- // cypress/support/tasks.ts
252
- export const seedDatabase = async (entity: string, data: unknown) => {
253
- // Direct database insert or API call
254
- if (entity === 'users') {
255
- await db.users.create(data);
256
- }
257
- return null;
258
- };
259
-
260
- // Usage in Cypress tests:
261
- beforeEach(() => {
262
- const user = createUser({ email: 'test@example.com' });
263
- cy.task('db:seed', { entity: 'users', data: user });
264
- });
265
- ```
266
-
267
- **Key Points**:
268
-
269
- - API seeding is 10-50x faster than UI-based setup
270
- - `globalSetup` seeds shared data once (e.g., admin user)
271
- - Per-test seeding uses `seedUser()` helpers for isolation
272
- - Cypress `cy.task` allows direct database access for speed
273
-
274
- ### Example 4: Anti-Pattern - Hardcoded Test Data
275
-
276
- **Problem**:
277
-
278
- ```typescript
279
- // ❌ BAD: Hardcoded test data
280
- test('user can login', async ({ page }) => {
281
- await page.goto('/login');
282
- await page.fill('[data-testid="email"]', 'test@test.com'); // Hardcoded
283
- await page.fill('[data-testid="password"]', 'password123'); // Hardcoded
284
- await page.click('[data-testid="submit"]');
285
-
286
- // What if this user already exists? Test fails in parallel runs.
287
- // What if schema adds required fields? Test breaks.
288
- });
289
-
290
- // ❌ BAD: Static JSON fixtures
291
- // fixtures/users.json
292
- {
293
- "users": [
294
- { "id": 1, "email": "user1@test.com", "name": "User 1" },
295
- { "id": 2, "email": "user2@test.com", "name": "User 2" }
296
- ]
297
- }
298
-
299
- test('admin can delete user', async ({ page }) => {
300
- const users = require('../fixtures/users.json');
301
- // Brittle: IDs collide in parallel, schema drift breaks tests
302
- });
303
- ```
304
-
305
- **Why It Fails**:
306
-
307
- - **Parallel collisions**: Hardcoded IDs (`id: 1`, `email: 'test@test.com'`) cause failures when tests run concurrently
308
- - **Schema drift**: Adding required fields (`phoneNumber`, `address`) breaks all tests using fixtures
309
- - **Hidden intent**: Does this test need `email: 'test@test.com'` specifically, or any email?
310
- - **Slow setup**: UI-based data creation is 10-50x slower than API
311
-
312
- **Better Approach**: Use factories
313
-
314
- ```typescript
315
- // ✅ GOOD: Factory-based data
316
- test('user can login', async ({ page, apiRequest }) => {
317
- const user = createUser({ email: 'unique@example.com', password: 'secure123' });
318
-
319
- // Seed via API (fast, parallel-safe)
320
- await apiRequest({ method: 'POST', url: '/api/users', data: user });
321
-
322
- // Test UI
323
- await page.goto('/login');
324
- await page.fill('[data-testid="email"]', user.email);
325
- await page.fill('[data-testid="password"]', user.password);
326
- await page.click('[data-testid="submit"]');
327
-
328
- await expect(page).toHaveURL('/dashboard');
329
- });
330
-
331
- // ✅ GOOD: Factories adapt to schema changes automatically
332
- // When `phoneNumber` becomes required, update factory once:
333
- export const createUser = (overrides: Partial<User> = {}): User => ({
334
- id: faker.string.uuid(),
335
- email: faker.internet.email(),
336
- name: faker.person.fullName(),
337
- phoneNumber: faker.phone.number(), // NEW field, all tests get it automatically
338
- role: 'user',
339
- ...overrides,
340
- });
341
- ```
342
-
343
- **Key Points**:
344
-
345
- - Factories generate unique, parallel-safe data
346
- - Schema evolution handled in one place (factory), not every test
347
- - Test intent explicit via overrides
348
- - API seeding is fast and reliable
349
-
350
- ### Example 5: Factory Composition
351
-
352
- **Context**: When building specialized factories, compose simpler factories instead of duplicating logic. Layer overrides for specific test scenarios.
353
-
354
- **Implementation**:
355
-
356
- ```typescript
357
- // test-utils/factories/user-factory.ts (base)
358
- export const createUser = (overrides: Partial<User> = {}): User => ({
359
- id: faker.string.uuid(),
360
- email: faker.internet.email(),
361
- name: faker.person.fullName(),
362
- role: 'user',
363
- createdAt: new Date(),
364
- isActive: true,
365
- ...overrides,
366
- });
367
-
368
- // Compose specialized factories
369
- export const createAdminUser = (overrides: Partial<User> = {}): User => createUser({ role: 'admin', ...overrides });
370
-
371
- export const createModeratorUser = (overrides: Partial<User> = {}): User => createUser({ role: 'moderator', ...overrides });
372
-
373
- export const createInactiveUser = (overrides: Partial<User> = {}): User => createUser({ isActive: false, ...overrides });
374
-
375
- // Account-level factories with feature flags
376
- type Account = {
377
- id: string;
378
- owner: User;
379
- plan: 'free' | 'pro' | 'enterprise';
380
- features: string[];
381
- maxUsers: number;
382
- };
383
-
384
- export const createAccount = (overrides: Partial<Account> = {}): Account => ({
385
- id: faker.string.uuid(),
386
- owner: overrides.owner || createUser(),
387
- plan: 'free',
388
- features: [],
389
- maxUsers: 1,
390
- ...overrides,
391
- });
392
-
393
- export const createProAccount = (overrides: Partial<Account> = {}): Account =>
394
- createAccount({
395
- plan: 'pro',
396
- features: ['advanced-analytics', 'priority-support'],
397
- maxUsers: 10,
398
- ...overrides,
399
- });
400
-
401
- export const createEnterpriseAccount = (overrides: Partial<Account> = {}): Account =>
402
- createAccount({
403
- plan: 'enterprise',
404
- features: ['advanced-analytics', 'priority-support', 'sso', 'audit-logs'],
405
- maxUsers: 100,
406
- ...overrides,
407
- });
408
-
409
- // Usage in tests:
410
- test('pro accounts can access analytics', async ({ page, apiRequest }) => {
411
- const admin = createAdminUser({ email: 'admin@company.com' });
412
- const account = createProAccount({ owner: admin });
413
-
414
- await apiRequest({ method: 'POST', url: '/api/users', data: admin });
415
- await apiRequest({ method: 'POST', url: '/api/accounts', data: account });
416
-
417
- await page.goto('/analytics');
418
- await expect(page.getByText('Advanced Analytics')).toBeVisible();
419
- });
420
-
421
- test('free accounts cannot access analytics', async ({ page, apiRequest }) => {
422
- const user = createUser({ email: 'user@company.com' });
423
- const account = createAccount({ owner: user }); // Defaults to free plan
424
-
425
- await apiRequest({ method: 'POST', url: '/api/users', data: user });
426
- await apiRequest({ method: 'POST', url: '/api/accounts', data: account });
427
-
428
- await page.goto('/analytics');
429
- await expect(page.getByText('Upgrade to Pro')).toBeVisible();
430
- });
431
- ```
432
-
433
- **Key Points**:
434
-
435
- - Compose specialized factories from base factories (`createAdminUser` → `createUser`)
436
- - Defaults cascade: `createProAccount` sets plan + features automatically
437
- - Still allow overrides: `createProAccount({ maxUsers: 50 })` works
438
- - Test intent clear: `createProAccount()` vs `createAccount({ plan: 'pro', features: [...] })`
439
-
440
- ## Integration Points
441
-
442
- - **Used in workflows**: `*atdd` (test generation), `*automate` (test expansion), `*framework` (factory setup)
443
- - **Related fragments**:
444
- - `fixture-architecture.md` - Pure functions and fixtures for factory integration
445
- - `network-first.md` - API-first setup patterns
446
- - `test-quality.md` - Parallel-safe, deterministic test design
447
-
448
- ## Cleanup Strategy
449
-
450
- Ensure factories work with cleanup patterns:
451
-
452
- ```typescript
453
- // Track created IDs for cleanup
454
- const createdUsers: string[] = [];
455
-
456
- afterEach(async ({ apiRequest }) => {
457
- // Clean up all users created during test
458
- for (const userId of createdUsers) {
459
- await apiRequest({ method: 'DELETE', url: `/api/users/${userId}` });
460
- }
461
- createdUsers.length = 0;
462
- });
463
-
464
- test('user registration flow', async ({ page, apiRequest }) => {
465
- const user = createUser();
466
- createdUsers.push(user.id);
467
-
468
- await apiRequest({ method: 'POST', url: '/api/users', data: user });
469
- // ... test logic
470
- });
471
- ```
472
-
473
- ## Feature Flag Integration
474
-
475
- When working with feature flags, layer them into factories:
476
-
477
- ```typescript
478
- export const createUserWithFlags = (
479
- overrides: Partial<User> = {},
480
- flags: Record<string, boolean> = {},
481
- ): User & { flags: Record<string, boolean> } => ({
482
- ...createUser(overrides),
483
- flags: {
484
- 'new-dashboard': false,
485
- 'beta-features': false,
486
- ...flags,
487
- },
488
- });
489
-
490
- // Usage:
491
- const user = createUserWithFlags(
492
- { email: 'test@example.com' },
493
- {
494
- 'new-dashboard': true,
495
- 'beta-features': true,
496
- },
497
- );
498
- ```
499
-
500
- _Source: Murat Testing Philosophy (lines 94-120), API-first testing patterns, faker.js documentation._