agentvibes 2.12.4 → 2.12.6

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 (429) hide show
  1. package/.claude/hooks/bmad-voice-manager.sh +21 -5
  2. package/.claude/hooks/play-tts.sh +12 -0
  3. package/.claude/hooks/tts-queue.sh +34 -6
  4. package/README.md +17 -10
  5. package/RELEASE_NOTES.md +320 -697
  6. package/mcp-server/install-deps.js +19 -0
  7. package/mcp-server/server.py +58 -36
  8. package/package.json +1 -1
  9. package/scripts/fix-audio-tunnel.sh +22 -6
  10. package/src/commands/bmad-voices.js +14 -1
  11. package/src/installer.js +157 -72
  12. package/test/unit/play-tts.bats +1 -1
  13. package/.bmad/_cfg/agent-manifest.csv +0 -11
  14. package/.bmad/_cfg/agent-voice-map.csv +0 -11
  15. package/.bmad/_cfg/agents/bmm-analyst.customize.yaml +0 -42
  16. package/.bmad/_cfg/agents/bmm-architect.customize.yaml +0 -42
  17. package/.bmad/_cfg/agents/bmm-dev.customize.yaml +0 -42
  18. package/.bmad/_cfg/agents/bmm-frame-expert.customize.yaml +0 -42
  19. package/.bmad/_cfg/agents/bmm-pm.customize.yaml +0 -42
  20. package/.bmad/_cfg/agents/bmm-sm.customize.yaml +0 -42
  21. package/.bmad/_cfg/agents/bmm-tea.customize.yaml +0 -42
  22. package/.bmad/_cfg/agents/bmm-tech-writer.customize.yaml +0 -42
  23. package/.bmad/_cfg/agents/bmm-ux-designer.customize.yaml +0 -42
  24. package/.bmad/_cfg/agents/core-bmad-master.customize.yaml +0 -42
  25. package/.bmad/_cfg/files-manifest.csv +0 -243
  26. package/.bmad/_cfg/ides/claude-code.yaml +0 -6
  27. package/.bmad/_cfg/manifest.yaml +0 -9
  28. package/.bmad/_cfg/task-manifest.csv +0 -5
  29. package/.bmad/_cfg/tool-manifest.csv +0 -2
  30. package/.bmad/_cfg/workflow-manifest.csv +0 -38
  31. package/.bmad/bmm/README.md +0 -128
  32. package/.bmad/bmm/agents/analyst.md +0 -79
  33. package/.bmad/bmm/agents/analyst.md.backup-pre-tts +0 -75
  34. package/.bmad/bmm/agents/architect.md +0 -80
  35. package/.bmad/bmm/agents/dev.md +0 -70
  36. package/.bmad/bmm/agents/frame-expert.md +0 -72
  37. package/.bmad/bmm/agents/pm.md +0 -84
  38. package/.bmad/bmm/agents/sm.md +0 -93
  39. package/.bmad/bmm/agents/tea.md +0 -80
  40. package/.bmad/bmm/agents/tech-writer.md +0 -84
  41. package/.bmad/bmm/agents/ux-designer.md +0 -79
  42. package/.bmad/bmm/config.yaml +0 -17
  43. package/.bmad/bmm/docs/README.md +0 -236
  44. package/.bmad/bmm/docs/agents-guide.md +0 -1058
  45. package/.bmad/bmm/docs/brownfield-guide.md +0 -762
  46. package/.bmad/bmm/docs/enterprise-agentic-development.md +0 -686
  47. package/.bmad/bmm/docs/faq.md +0 -588
  48. package/.bmad/bmm/docs/glossary.md +0 -320
  49. package/.bmad/bmm/docs/party-mode.md +0 -224
  50. package/.bmad/bmm/docs/quick-spec-flow.md +0 -652
  51. package/.bmad/bmm/docs/quick-start.md +0 -376
  52. package/.bmad/bmm/docs/scale-adaptive-system.md +0 -612
  53. package/.bmad/bmm/docs/test-architecture.md +0 -396
  54. package/.bmad/bmm/docs/workflow-architecture-reference.md +0 -366
  55. package/.bmad/bmm/docs/workflow-document-project-reference.md +0 -489
  56. package/.bmad/bmm/docs/workflows-analysis.md +0 -370
  57. package/.bmad/bmm/docs/workflows-implementation.md +0 -286
  58. package/.bmad/bmm/docs/workflows-planning.md +0 -612
  59. package/.bmad/bmm/docs/workflows-solutioning.md +0 -554
  60. package/.bmad/bmm/teams/default-party.csv +0 -20
  61. package/.bmad/bmm/teams/team-fullstack.yaml +0 -13
  62. package/.bmad/bmm/testarch/knowledge/ci-burn-in.md +0 -675
  63. package/.bmad/bmm/testarch/knowledge/component-tdd.md +0 -486
  64. package/.bmad/bmm/testarch/knowledge/contract-testing.md +0 -957
  65. package/.bmad/bmm/testarch/knowledge/data-factories.md +0 -500
  66. package/.bmad/bmm/testarch/knowledge/email-auth.md +0 -721
  67. package/.bmad/bmm/testarch/knowledge/error-handling.md +0 -725
  68. package/.bmad/bmm/testarch/knowledge/feature-flags.md +0 -750
  69. package/.bmad/bmm/testarch/knowledge/fixture-architecture.md +0 -401
  70. package/.bmad/bmm/testarch/knowledge/network-first.md +0 -486
  71. package/.bmad/bmm/testarch/knowledge/nfr-criteria.md +0 -670
  72. package/.bmad/bmm/testarch/knowledge/playwright-config.md +0 -730
  73. package/.bmad/bmm/testarch/knowledge/probability-impact.md +0 -601
  74. package/.bmad/bmm/testarch/knowledge/risk-governance.md +0 -615
  75. package/.bmad/bmm/testarch/knowledge/selective-testing.md +0 -732
  76. package/.bmad/bmm/testarch/knowledge/selector-resilience.md +0 -527
  77. package/.bmad/bmm/testarch/knowledge/test-healing-patterns.md +0 -644
  78. package/.bmad/bmm/testarch/knowledge/test-levels-framework.md +0 -473
  79. package/.bmad/bmm/testarch/knowledge/test-priorities-matrix.md +0 -373
  80. package/.bmad/bmm/testarch/knowledge/test-quality.md +0 -664
  81. package/.bmad/bmm/testarch/knowledge/timing-debugging.md +0 -372
  82. package/.bmad/bmm/testarch/knowledge/visual-debugging.md +0 -524
  83. package/.bmad/bmm/testarch/tea-index.csv +0 -22
  84. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/instructions.md +0 -112
  85. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/project-context.md +0 -25
  86. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/workflow.yaml +0 -26
  87. package/.bmad/bmm/workflows/1-analysis/domain-research/instructions.md +0 -425
  88. package/.bmad/bmm/workflows/1-analysis/domain-research/template.md +0 -180
  89. package/.bmad/bmm/workflows/1-analysis/domain-research/workflow.yaml +0 -28
  90. package/.bmad/bmm/workflows/1-analysis/product-brief/checklist.md +0 -115
  91. package/.bmad/bmm/workflows/1-analysis/product-brief/instructions.md +0 -524
  92. package/.bmad/bmm/workflows/1-analysis/product-brief/template.md +0 -181
  93. package/.bmad/bmm/workflows/1-analysis/product-brief/workflow.yaml +0 -45
  94. package/.bmad/bmm/workflows/1-analysis/research/checklist-deep-prompt.md +0 -144
  95. package/.bmad/bmm/workflows/1-analysis/research/checklist-technical.md +0 -249
  96. package/.bmad/bmm/workflows/1-analysis/research/checklist.md +0 -299
  97. package/.bmad/bmm/workflows/1-analysis/research/claude-code/injections.yaml +0 -114
  98. package/.bmad/bmm/workflows/1-analysis/research/instructions-deep-prompt.md +0 -438
  99. package/.bmad/bmm/workflows/1-analysis/research/instructions-market.md +0 -675
  100. package/.bmad/bmm/workflows/1-analysis/research/instructions-router.md +0 -134
  101. package/.bmad/bmm/workflows/1-analysis/research/instructions-technical.md +0 -534
  102. package/.bmad/bmm/workflows/1-analysis/research/template-deep-prompt.md +0 -94
  103. package/.bmad/bmm/workflows/1-analysis/research/template-market.md +0 -347
  104. package/.bmad/bmm/workflows/1-analysis/research/template-technical.md +0 -245
  105. package/.bmad/bmm/workflows/1-analysis/research/workflow.yaml +0 -44
  106. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/epics-template.md +0 -80
  107. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/instructions.md +0 -616
  108. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/workflow.yaml +0 -53
  109. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/checklist.md +0 -310
  110. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/instructions.md +0 -1308
  111. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +0 -145
  112. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.yaml +0 -61
  113. package/.bmad/bmm/workflows/2-plan-workflows/prd/checklist.md +0 -346
  114. package/.bmad/bmm/workflows/2-plan-workflows/prd/domain-complexity.csv +0 -13
  115. package/.bmad/bmm/workflows/2-plan-workflows/prd/instructions.md +0 -703
  116. package/.bmad/bmm/workflows/2-plan-workflows/prd/prd-template.md +0 -204
  117. package/.bmad/bmm/workflows/2-plan-workflows/prd/project-types.csv +0 -11
  118. package/.bmad/bmm/workflows/2-plan-workflows/prd/workflow.yaml +0 -52
  119. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/checklist.md +0 -217
  120. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/epics-template.md +0 -74
  121. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions-generate-stories.md +0 -436
  122. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions.md +0 -980
  123. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/tech-spec-template.md +0 -181
  124. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/user-story-template.md +0 -90
  125. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/workflow.yaml +0 -58
  126. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-patterns.yaml +0 -321
  127. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-template.md +0 -103
  128. package/.bmad/bmm/workflows/3-solutioning/architecture/checklist.md +0 -240
  129. package/.bmad/bmm/workflows/3-solutioning/architecture/decision-catalog.yaml +0 -222
  130. package/.bmad/bmm/workflows/3-solutioning/architecture/instructions.md +0 -768
  131. package/.bmad/bmm/workflows/3-solutioning/architecture/pattern-categories.csv +0 -13
  132. package/.bmad/bmm/workflows/3-solutioning/architecture/workflow.yaml +0 -55
  133. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/checklist.md +0 -169
  134. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/instructions.md +0 -332
  135. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/template.md +0 -146
  136. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/workflow.yaml +0 -62
  137. package/.bmad/bmm/workflows/4-implementation/code-review/backlog_template.md +0 -12
  138. package/.bmad/bmm/workflows/4-implementation/code-review/checklist.md +0 -22
  139. package/.bmad/bmm/workflows/4-implementation/code-review/instructions.md +0 -398
  140. package/.bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +0 -60
  141. package/.bmad/bmm/workflows/4-implementation/correct-course/checklist.md +0 -279
  142. package/.bmad/bmm/workflows/4-implementation/correct-course/instructions.md +0 -206
  143. package/.bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +0 -56
  144. package/.bmad/bmm/workflows/4-implementation/create-story/checklist.md +0 -240
  145. package/.bmad/bmm/workflows/4-implementation/create-story/instructions.md +0 -256
  146. package/.bmad/bmm/workflows/4-implementation/create-story/template.md +0 -51
  147. package/.bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +0 -71
  148. package/.bmad/bmm/workflows/4-implementation/dev-story/checklist.md +0 -38
  149. package/.bmad/bmm/workflows/4-implementation/dev-story/instructions.md +0 -267
  150. package/.bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +0 -56
  151. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/checklist.md +0 -17
  152. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/instructions.md +0 -164
  153. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/template.md +0 -76
  154. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/workflow.yaml +0 -57
  155. package/.bmad/bmm/workflows/4-implementation/retrospective/instructions.md +0 -1443
  156. package/.bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +0 -56
  157. package/.bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +0 -33
  158. package/.bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +0 -234
  159. package/.bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +0 -55
  160. package/.bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +0 -49
  161. package/.bmad/bmm/workflows/4-implementation/story-context/checklist.md +0 -16
  162. package/.bmad/bmm/workflows/4-implementation/story-context/context-template.xml +0 -34
  163. package/.bmad/bmm/workflows/4-implementation/story-context/instructions.md +0 -209
  164. package/.bmad/bmm/workflows/4-implementation/story-context/workflow.yaml +0 -61
  165. package/.bmad/bmm/workflows/4-implementation/story-done/instructions.md +0 -111
  166. package/.bmad/bmm/workflows/4-implementation/story-done/workflow.yaml +0 -26
  167. package/.bmad/bmm/workflows/4-implementation/story-ready/instructions.md +0 -117
  168. package/.bmad/bmm/workflows/4-implementation/story-ready/workflow.yaml +0 -23
  169. package/.bmad/bmm/workflows/document-project/checklist.md +0 -245
  170. package/.bmad/bmm/workflows/document-project/documentation-requirements.csv +0 -12
  171. package/.bmad/bmm/workflows/document-project/instructions.md +0 -222
  172. package/.bmad/bmm/workflows/document-project/templates/deep-dive-template.md +0 -345
  173. package/.bmad/bmm/workflows/document-project/templates/index-template.md +0 -169
  174. package/.bmad/bmm/workflows/document-project/templates/project-overview-template.md +0 -103
  175. package/.bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +0 -160
  176. package/.bmad/bmm/workflows/document-project/templates/source-tree-template.md +0 -135
  177. package/.bmad/bmm/workflows/document-project/workflow.yaml +0 -29
  178. package/.bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +0 -298
  179. package/.bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +0 -31
  180. package/.bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +0 -1106
  181. package/.bmad/bmm/workflows/document-project/workflows/full-scan.yaml +0 -31
  182. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-helpers.md +0 -127
  183. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-library.json +0 -90
  184. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-templates.yaml +0 -127
  185. package/.bmad/bmm/workflows/frame-expert/_shared/validate-json-instructions.md +0 -79
  186. package/.bmad/bmm/workflows/frame-expert/create-dataflow/checklist.md +0 -39
  187. package/.bmad/bmm/workflows/frame-expert/create-dataflow/instructions.md +0 -131
  188. package/.bmad/bmm/workflows/frame-expert/create-dataflow/workflow.yaml +0 -23
  189. package/.bmad/bmm/workflows/frame-expert/create-diagram/checklist.md +0 -43
  190. package/.bmad/bmm/workflows/frame-expert/create-diagram/instructions.md +0 -142
  191. package/.bmad/bmm/workflows/frame-expert/create-diagram/workflow.yaml +0 -24
  192. package/.bmad/bmm/workflows/frame-expert/create-flowchart/checklist.md +0 -49
  193. package/.bmad/bmm/workflows/frame-expert/create-flowchart/instructions.md +0 -242
  194. package/.bmad/bmm/workflows/frame-expert/create-flowchart/workflow.yaml +0 -27
  195. package/.bmad/bmm/workflows/frame-expert/create-wireframe/checklist.md +0 -38
  196. package/.bmad/bmm/workflows/frame-expert/create-wireframe/instructions.md +0 -133
  197. package/.bmad/bmm/workflows/frame-expert/create-wireframe/workflow.yaml +0 -23
  198. package/.bmad/bmm/workflows/techdoc/documentation-standards.md +0 -262
  199. package/.bmad/bmm/workflows/testarch/atdd/atdd-checklist-template.md +0 -363
  200. package/.bmad/bmm/workflows/testarch/atdd/checklist.md +0 -373
  201. package/.bmad/bmm/workflows/testarch/atdd/instructions.md +0 -785
  202. package/.bmad/bmm/workflows/testarch/atdd/workflow.yaml +0 -45
  203. package/.bmad/bmm/workflows/testarch/automate/checklist.md +0 -580
  204. package/.bmad/bmm/workflows/testarch/automate/instructions.md +0 -1303
  205. package/.bmad/bmm/workflows/testarch/automate/workflow.yaml +0 -52
  206. package/.bmad/bmm/workflows/testarch/ci/checklist.md +0 -246
  207. package/.bmad/bmm/workflows/testarch/ci/github-actions-template.yaml +0 -165
  208. package/.bmad/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +0 -128
  209. package/.bmad/bmm/workflows/testarch/ci/instructions.md +0 -517
  210. package/.bmad/bmm/workflows/testarch/ci/workflow.yaml +0 -45
  211. package/.bmad/bmm/workflows/testarch/framework/checklist.md +0 -321
  212. package/.bmad/bmm/workflows/testarch/framework/instructions.md +0 -455
  213. package/.bmad/bmm/workflows/testarch/framework/workflow.yaml +0 -47
  214. package/.bmad/bmm/workflows/testarch/nfr-assess/checklist.md +0 -405
  215. package/.bmad/bmm/workflows/testarch/nfr-assess/instructions.md +0 -722
  216. package/.bmad/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +0 -443
  217. package/.bmad/bmm/workflows/testarch/nfr-assess/workflow.yaml +0 -47
  218. package/.bmad/bmm/workflows/testarch/test-design/checklist.md +0 -234
  219. package/.bmad/bmm/workflows/testarch/test-design/instructions.md +0 -782
  220. package/.bmad/bmm/workflows/testarch/test-design/test-design-template.md +0 -285
  221. package/.bmad/bmm/workflows/testarch/test-design/workflow.yaml +0 -48
  222. package/.bmad/bmm/workflows/testarch/test-review/checklist.md +0 -470
  223. package/.bmad/bmm/workflows/testarch/test-review/instructions.md +0 -608
  224. package/.bmad/bmm/workflows/testarch/test-review/test-review-template.md +0 -388
  225. package/.bmad/bmm/workflows/testarch/test-review/workflow.yaml +0 -46
  226. package/.bmad/bmm/workflows/testarch/trace/checklist.md +0 -654
  227. package/.bmad/bmm/workflows/testarch/trace/instructions.md +0 -1045
  228. package/.bmad/bmm/workflows/testarch/trace/trace-template.md +0 -673
  229. package/.bmad/bmm/workflows/testarch/trace/workflow.yaml +0 -55
  230. package/.bmad/bmm/workflows/workflow-status/init/instructions.md +0 -334
  231. package/.bmad/bmm/workflows/workflow-status/init/workflow.yaml +0 -28
  232. package/.bmad/bmm/workflows/workflow-status/instructions.md +0 -388
  233. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-brownfield.yaml +0 -138
  234. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-greenfield.yaml +0 -126
  235. package/.bmad/bmm/workflows/workflow-status/paths/game-design.yaml +0 -52
  236. package/.bmad/bmm/workflows/workflow-status/paths/method-brownfield.yaml +0 -122
  237. package/.bmad/bmm/workflows/workflow-status/paths/method-greenfield.yaml +0 -113
  238. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-brownfield.yaml +0 -58
  239. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-greenfield.yaml +0 -47
  240. package/.bmad/bmm/workflows/workflow-status/project-levels.yaml +0 -59
  241. package/.bmad/bmm/workflows/workflow-status/workflow-status-template.yaml +0 -24
  242. package/.bmad/bmm/workflows/workflow-status/workflow.yaml +0 -28
  243. package/.bmad/core/agents/bmad-master.md +0 -72
  244. package/.bmad/core/agents/bmad-web-orchestrator.agent.xml +0 -113
  245. package/.bmad/core/config.yaml +0 -11
  246. package/.bmad/core/tasks/adv-elicit-methods.csv +0 -39
  247. package/.bmad/core/tasks/advanced-elicitation-methods.csv +0 -21
  248. package/.bmad/core/tasks/advanced-elicitation.xml +0 -106
  249. package/.bmad/core/tasks/index-docs.xml +0 -65
  250. package/.bmad/core/tasks/validate-workflow.xml +0 -89
  251. package/.bmad/core/tasks/workflow.xml +0 -270
  252. package/.bmad/core/tools/shard-doc.xml +0 -109
  253. package/.bmad/core/workflows/brainstorming/README.md +0 -261
  254. package/.bmad/core/workflows/brainstorming/brain-methods.csv +0 -36
  255. package/.bmad/core/workflows/brainstorming/instructions.md +0 -315
  256. package/.bmad/core/workflows/brainstorming/template.md +0 -106
  257. package/.bmad/core/workflows/brainstorming/workflow.yaml +0 -38
  258. package/.bmad/core/workflows/party-mode/instructions.md +0 -203
  259. package/.bmad/core/workflows/party-mode/workflow.yaml +0 -28
  260. package/.bmad/docs/claude-code-instructions.md +0 -25
  261. package/.claude/commands/BMad/analyst.md +0 -88
  262. package/.claude/commands/BMad/architect.md +0 -89
  263. package/.claude/commands/BMad/bmad-master.md +0 -114
  264. package/.claude/commands/BMad/bmad-orchestrator.md +0 -151
  265. package/.claude/commands/BMad/dev.md +0 -85
  266. package/.claude/commands/BMad/pm.md +0 -88
  267. package/.claude/commands/BMad/po.md +0 -83
  268. package/.claude/commands/BMad/qa.md +0 -91
  269. package/.claude/commands/BMad/sm.md +0 -69
  270. package/.claude/commands/BMad/tasks/advanced-elicitation.md +0 -123
  271. package/.claude/commands/BMad/tasks/apply-qa-fixes.md +0 -154
  272. package/.claude/commands/BMad/tasks/brownfield-create-epic.md +0 -166
  273. package/.claude/commands/BMad/tasks/brownfield-create-story.md +0 -153
  274. package/.claude/commands/BMad/tasks/correct-course.md +0 -76
  275. package/.claude/commands/BMad/tasks/create-brownfield-story.md +0 -318
  276. package/.claude/commands/BMad/tasks/create-deep-research-prompt.md +0 -284
  277. package/.claude/commands/BMad/tasks/create-doc.md +0 -107
  278. package/.claude/commands/BMad/tasks/create-next-story.md +0 -118
  279. package/.claude/commands/BMad/tasks/document-project.md +0 -349
  280. package/.claude/commands/BMad/tasks/execute-checklist.md +0 -92
  281. package/.claude/commands/BMad/tasks/facilitate-brainstorming-session.md +0 -142
  282. package/.claude/commands/BMad/tasks/generate-ai-frontend-prompt.md +0 -57
  283. package/.claude/commands/BMad/tasks/index-docs.md +0 -179
  284. package/.claude/commands/BMad/tasks/kb-mode-interaction.md +0 -81
  285. package/.claude/commands/BMad/tasks/nfr-assess.md +0 -349
  286. package/.claude/commands/BMad/tasks/qa-gate.md +0 -167
  287. package/.claude/commands/BMad/tasks/review-story.md +0 -320
  288. package/.claude/commands/BMad/tasks/risk-profile.md +0 -359
  289. package/.claude/commands/BMad/tasks/shard-doc.md +0 -191
  290. package/.claude/commands/BMad/tasks/test-design.md +0 -180
  291. package/.claude/commands/BMad/tasks/trace-requirements.md +0 -270
  292. package/.claude/commands/BMad/tasks/validate-next-story.md +0 -140
  293. package/.claude/commands/BMad/ux-expert.md +0 -73
  294. package/.claude/commands/bmad/bmm/agents/analyst.md +0 -14
  295. package/.claude/commands/bmad/bmm/agents/architect.md +0 -14
  296. package/.claude/commands/bmad/bmm/agents/dev.md +0 -14
  297. package/.claude/commands/bmad/bmm/agents/frame-expert.md +0 -14
  298. package/.claude/commands/bmad/bmm/agents/pm.md +0 -14
  299. package/.claude/commands/bmad/bmm/agents/sm.md +0 -14
  300. package/.claude/commands/bmad/bmm/agents/tea.md +0 -14
  301. package/.claude/commands/bmad/bmm/agents/tech-writer.md +0 -14
  302. package/.claude/commands/bmad/bmm/agents/ux-designer.md +0 -14
  303. package/.claude/commands/bmad/bmm/workflows/architecture.md +0 -13
  304. package/.claude/commands/bmad/bmm/workflows/brainstorm-project.md +0 -13
  305. package/.claude/commands/bmad/bmm/workflows/code-review.md +0 -13
  306. package/.claude/commands/bmad/bmm/workflows/correct-course.md +0 -13
  307. package/.claude/commands/bmad/bmm/workflows/create-dataflow.md +0 -13
  308. package/.claude/commands/bmad/bmm/workflows/create-diagram.md +0 -13
  309. package/.claude/commands/bmad/bmm/workflows/create-epics-and-stories.md +0 -13
  310. package/.claude/commands/bmad/bmm/workflows/create-flowchart.md +0 -13
  311. package/.claude/commands/bmad/bmm/workflows/create-story.md +0 -13
  312. package/.claude/commands/bmad/bmm/workflows/create-ux-design.md +0 -13
  313. package/.claude/commands/bmad/bmm/workflows/create-wireframe.md +0 -13
  314. package/.claude/commands/bmad/bmm/workflows/dev-story.md +0 -13
  315. package/.claude/commands/bmad/bmm/workflows/document-project.md +0 -13
  316. package/.claude/commands/bmad/bmm/workflows/domain-research.md +0 -13
  317. package/.claude/commands/bmad/bmm/workflows/epic-tech-context.md +0 -13
  318. package/.claude/commands/bmad/bmm/workflows/implementation-readiness.md +0 -13
  319. package/.claude/commands/bmad/bmm/workflows/prd.md +0 -13
  320. package/.claude/commands/bmad/bmm/workflows/product-brief.md +0 -13
  321. package/.claude/commands/bmad/bmm/workflows/research.md +0 -13
  322. package/.claude/commands/bmad/bmm/workflows/retrospective.md +0 -13
  323. package/.claude/commands/bmad/bmm/workflows/sprint-planning.md +0 -13
  324. package/.claude/commands/bmad/bmm/workflows/story-context.md +0 -13
  325. package/.claude/commands/bmad/bmm/workflows/story-done.md +0 -13
  326. package/.claude/commands/bmad/bmm/workflows/story-ready.md +0 -13
  327. package/.claude/commands/bmad/bmm/workflows/tech-spec.md +0 -13
  328. package/.claude/commands/bmad/bmm/workflows/workflow-init.md +0 -13
  329. package/.claude/commands/bmad/bmm/workflows/workflow-status.md +0 -13
  330. package/.claude/commands/bmad/core/agents/bmad-master.md +0 -14
  331. package/.claude/commands/bmad/core/tasks/advanced-elicitation.md +0 -9
  332. package/.claude/commands/bmad/core/tasks/index-docs.md +0 -9
  333. package/.claude/commands/bmad/core/tools/shard-doc.md +0 -9
  334. package/.claude/commands/bmad/core/workflows/brainstorming.md +0 -13
  335. package/.claude/commands/bmad/core/workflows/party-mode.md +0 -13
  336. package/.claude/github-star-reminder.txt +0 -1
  337. package/.claude/hooks/bmad-party-manager.sh +0 -225
  338. package/.claude/hooks/stop.sh +0 -221
  339. package/.claude/piper-voices-dir.txt +0 -1
  340. package/.mcp.json +0 -88
  341. package/RELEASE_NOTES_v2.4.0_DRAFT.md +0 -116
  342. package/RELEASE_NOTES_v2.4.1_DRAFT.md +0 -61
  343. package/docs/2025-11-15_15-14-33.snagx +0 -0
  344. package/docs/Screenshot 2025-11-15 151325.png +0 -0
  345. package/docs/Screenshot 2025-11-15 151432.png +0 -0
  346. package/docs/macos-piper-issue.md +0 -172
  347. package/docs/stargazer-cms-prd.md +0 -1918
  348. package/docs/whatsapp-plugin-github-issue.md +0 -393
  349. package/docs/whatsapp-tts-plugin-feasibility.md +0 -418
  350. package/docs/whatsapp-tts-standalone-plugin.md +0 -628
  351. package/github-profile-draft.md +0 -57
  352. package/linkedin/vibe-coding-and-pulseaudio.md +0 -121
  353. package/mcp-server/agentvibes.db +0 -0
  354. package/scripts/audio-tunnel.config +0 -17
  355. package/v4-backup/.bmad-core/agent-teams/team-all.yaml +0 -15
  356. package/v4-backup/.bmad-core/agent-teams/team-fullstack.yaml +0 -19
  357. package/v4-backup/.bmad-core/agent-teams/team-ide-minimal.yaml +0 -11
  358. package/v4-backup/.bmad-core/agent-teams/team-no-ui.yaml +0 -14
  359. package/v4-backup/.bmad-core/agents/analyst.md +0 -84
  360. package/v4-backup/.bmad-core/agents/architect.md +0 -85
  361. package/v4-backup/.bmad-core/agents/bmad-master.md +0 -110
  362. package/v4-backup/.bmad-core/agents/bmad-orchestrator.md +0 -147
  363. package/v4-backup/.bmad-core/agents/dev.md +0 -81
  364. package/v4-backup/.bmad-core/agents/pm.md +0 -84
  365. package/v4-backup/.bmad-core/agents/po.md +0 -79
  366. package/v4-backup/.bmad-core/agents/qa.md +0 -87
  367. package/v4-backup/.bmad-core/agents/sm.md +0 -65
  368. package/v4-backup/.bmad-core/agents/ux-expert.md +0 -69
  369. package/v4-backup/.bmad-core/checklists/architect-checklist.md +0 -440
  370. package/v4-backup/.bmad-core/checklists/change-checklist.md +0 -184
  371. package/v4-backup/.bmad-core/checklists/pm-checklist.md +0 -372
  372. package/v4-backup/.bmad-core/checklists/po-master-checklist.md +0 -434
  373. package/v4-backup/.bmad-core/checklists/story-dod-checklist.md +0 -96
  374. package/v4-backup/.bmad-core/checklists/story-draft-checklist.md +0 -155
  375. package/v4-backup/.bmad-core/core-config.yaml +0 -22
  376. package/v4-backup/.bmad-core/data/bmad-kb.md +0 -809
  377. package/v4-backup/.bmad-core/data/brainstorming-techniques.md +0 -38
  378. package/v4-backup/.bmad-core/data/elicitation-methods.md +0 -156
  379. package/v4-backup/.bmad-core/data/technical-preferences.md +0 -5
  380. package/v4-backup/.bmad-core/data/test-levels-framework.md +0 -148
  381. package/v4-backup/.bmad-core/data/test-priorities-matrix.md +0 -174
  382. package/v4-backup/.bmad-core/enhanced-ide-development-workflow.md +0 -248
  383. package/v4-backup/.bmad-core/install-manifest.yaml +0 -230
  384. package/v4-backup/.bmad-core/tasks/advanced-elicitation.md +0 -119
  385. package/v4-backup/.bmad-core/tasks/apply-qa-fixes.md +0 -150
  386. package/v4-backup/.bmad-core/tasks/brownfield-create-epic.md +0 -162
  387. package/v4-backup/.bmad-core/tasks/brownfield-create-story.md +0 -149
  388. package/v4-backup/.bmad-core/tasks/correct-course.md +0 -72
  389. package/v4-backup/.bmad-core/tasks/create-brownfield-story.md +0 -314
  390. package/v4-backup/.bmad-core/tasks/create-deep-research-prompt.md +0 -280
  391. package/v4-backup/.bmad-core/tasks/create-doc.md +0 -103
  392. package/v4-backup/.bmad-core/tasks/create-next-story.md +0 -114
  393. package/v4-backup/.bmad-core/tasks/document-project.md +0 -345
  394. package/v4-backup/.bmad-core/tasks/execute-checklist.md +0 -88
  395. package/v4-backup/.bmad-core/tasks/facilitate-brainstorming-session.md +0 -138
  396. package/v4-backup/.bmad-core/tasks/generate-ai-frontend-prompt.md +0 -53
  397. package/v4-backup/.bmad-core/tasks/index-docs.md +0 -175
  398. package/v4-backup/.bmad-core/tasks/kb-mode-interaction.md +0 -77
  399. package/v4-backup/.bmad-core/tasks/nfr-assess.md +0 -345
  400. package/v4-backup/.bmad-core/tasks/qa-gate.md +0 -163
  401. package/v4-backup/.bmad-core/tasks/review-story.md +0 -316
  402. package/v4-backup/.bmad-core/tasks/risk-profile.md +0 -355
  403. package/v4-backup/.bmad-core/tasks/shard-doc.md +0 -187
  404. package/v4-backup/.bmad-core/tasks/test-design.md +0 -176
  405. package/v4-backup/.bmad-core/tasks/trace-requirements.md +0 -266
  406. package/v4-backup/.bmad-core/tasks/validate-next-story.md +0 -136
  407. package/v4-backup/.bmad-core/templates/architecture-tmpl.yaml +0 -651
  408. package/v4-backup/.bmad-core/templates/brainstorming-output-tmpl.yaml +0 -156
  409. package/v4-backup/.bmad-core/templates/brownfield-architecture-tmpl.yaml +0 -477
  410. package/v4-backup/.bmad-core/templates/brownfield-prd-tmpl.yaml +0 -281
  411. package/v4-backup/.bmad-core/templates/competitor-analysis-tmpl.yaml +0 -307
  412. package/v4-backup/.bmad-core/templates/front-end-architecture-tmpl.yaml +0 -219
  413. package/v4-backup/.bmad-core/templates/front-end-spec-tmpl.yaml +0 -350
  414. package/v4-backup/.bmad-core/templates/fullstack-architecture-tmpl.yaml +0 -824
  415. package/v4-backup/.bmad-core/templates/market-research-tmpl.yaml +0 -253
  416. package/v4-backup/.bmad-core/templates/prd-tmpl.yaml +0 -203
  417. package/v4-backup/.bmad-core/templates/project-brief-tmpl.yaml +0 -222
  418. package/v4-backup/.bmad-core/templates/qa-gate-tmpl.yaml +0 -103
  419. package/v4-backup/.bmad-core/templates/story-tmpl.yaml +0 -138
  420. package/v4-backup/.bmad-core/user-guide.md +0 -577
  421. package/v4-backup/.bmad-core/utils/bmad-doc-template.md +0 -327
  422. package/v4-backup/.bmad-core/utils/workflow-management.md +0 -71
  423. package/v4-backup/.bmad-core/workflows/brownfield-fullstack.yaml +0 -298
  424. package/v4-backup/.bmad-core/workflows/brownfield-service.yaml +0 -188
  425. package/v4-backup/.bmad-core/workflows/brownfield-ui.yaml +0 -198
  426. package/v4-backup/.bmad-core/workflows/greenfield-fullstack.yaml +0 -241
  427. package/v4-backup/.bmad-core/workflows/greenfield-service.yaml +0 -207
  428. package/v4-backup/.bmad-core/workflows/greenfield-ui.yaml +0 -236
  429. package/v4-backup/.bmad-core/working-in-the-brownfield.md +0 -606
@@ -1,473 +0,0 @@
1
- <!-- Powered by BMAD-CORE™ -->
2
-
3
- # Test Levels Framework
4
-
5
- Comprehensive guide for determining appropriate test levels (unit, integration, E2E) for different scenarios.
6
-
7
- ## Test Level Decision Matrix
8
-
9
- ### Unit Tests
10
-
11
- **When to use:**
12
-
13
- - Testing pure functions and business logic
14
- - Algorithm correctness
15
- - Input validation and data transformation
16
- - Error handling in isolated components
17
- - Complex calculations or state machines
18
-
19
- **Characteristics:**
20
-
21
- - Fast execution (immediate feedback)
22
- - No external dependencies (DB, API, file system)
23
- - Highly maintainable and stable
24
- - Easy to debug failures
25
-
26
- **Example scenarios:**
27
-
28
- ```yaml
29
- unit_test:
30
- component: 'PriceCalculator'
31
- scenario: 'Calculate discount with multiple rules'
32
- justification: 'Complex business logic with multiple branches'
33
- mock_requirements: 'None - pure function'
34
- ```
35
-
36
- ### Integration Tests
37
-
38
- **When to use:**
39
-
40
- - Component interaction verification
41
- - Database operations and transactions
42
- - API endpoint contracts
43
- - Service-to-service communication
44
- - Middleware and interceptor behavior
45
-
46
- **Characteristics:**
47
-
48
- - Moderate execution time
49
- - Tests component boundaries
50
- - May use test databases or containers
51
- - Validates system integration points
52
-
53
- **Example scenarios:**
54
-
55
- ```yaml
56
- integration_test:
57
- components: ['UserService', 'AuthRepository']
58
- scenario: 'Create user with role assignment'
59
- justification: 'Critical data flow between service and persistence'
60
- test_environment: 'In-memory database'
61
- ```
62
-
63
- ### End-to-End Tests
64
-
65
- **When to use:**
66
-
67
- - Critical user journeys
68
- - Cross-system workflows
69
- - Visual regression testing
70
- - Compliance and regulatory requirements
71
- - Final validation before release
72
-
73
- **Characteristics:**
74
-
75
- - Slower execution
76
- - Tests complete workflows
77
- - Requires full environment setup
78
- - Most realistic but most brittle
79
-
80
- **Example scenarios:**
81
-
82
- ```yaml
83
- e2e_test:
84
- journey: 'Complete checkout process'
85
- scenario: 'User purchases with saved payment method'
86
- justification: 'Revenue-critical path requiring full validation'
87
- environment: 'Staging with test payment gateway'
88
- ```
89
-
90
- ## Test Level Selection Rules
91
-
92
- ### Favor Unit Tests When:
93
-
94
- - Logic can be isolated
95
- - No side effects involved
96
- - Fast feedback needed
97
- - High cyclomatic complexity
98
-
99
- ### Favor Integration Tests When:
100
-
101
- - Testing persistence layer
102
- - Validating service contracts
103
- - Testing middleware/interceptors
104
- - Component boundaries critical
105
-
106
- ### Favor E2E Tests When:
107
-
108
- - User-facing critical paths
109
- - Multi-system interactions
110
- - Regulatory compliance scenarios
111
- - Visual regression important
112
-
113
- ## Anti-patterns to Avoid
114
-
115
- - E2E testing for business logic validation
116
- - Unit testing framework behavior
117
- - Integration testing third-party libraries
118
- - Duplicate coverage across levels
119
-
120
- ## Duplicate Coverage Guard
121
-
122
- **Before adding any test, check:**
123
-
124
- 1. Is this already tested at a lower level?
125
- 2. Can a unit test cover this instead of integration?
126
- 3. Can an integration test cover this instead of E2E?
127
-
128
- **Coverage overlap is only acceptable when:**
129
-
130
- - Testing different aspects (unit: logic, integration: interaction, e2e: user experience)
131
- - Critical paths requiring defense in depth
132
- - Regression prevention for previously broken functionality
133
-
134
- ## Test Naming Conventions
135
-
136
- - Unit: `test_{component}_{scenario}`
137
- - Integration: `test_{flow}_{interaction}`
138
- - E2E: `test_{journey}_{outcome}`
139
-
140
- ## Test ID Format
141
-
142
- `{EPIC}.{STORY}-{LEVEL}-{SEQ}`
143
-
144
- Examples:
145
-
146
- - `1.3-UNIT-001`
147
- - `1.3-INT-002`
148
- - `1.3-E2E-001`
149
-
150
- ## Real Code Examples
151
-
152
- ### Example 1: E2E Test (Full User Journey)
153
-
154
- **Scenario**: User logs in, navigates to dashboard, and places an order.
155
-
156
- ```typescript
157
- // tests/e2e/checkout-flow.spec.ts
158
- import { test, expect } from '@playwright/test';
159
- import { createUser, createProduct } from '../test-utils/factories';
160
-
161
- test.describe('Checkout Flow', () => {
162
- test('user can complete purchase with saved payment method', async ({ page, apiRequest }) => {
163
- // Setup: Seed data via API (fast!)
164
- const user = createUser({ email: 'buyer@example.com', hasSavedCard: true });
165
- const product = createProduct({ name: 'Widget', price: 29.99, stock: 10 });
166
-
167
- await apiRequest.post('/api/users', { data: user });
168
- await apiRequest.post('/api/products', { data: product });
169
-
170
- // Network-first: Intercept BEFORE action
171
- const loginPromise = page.waitForResponse('**/api/auth/login');
172
- const cartPromise = page.waitForResponse('**/api/cart');
173
- const orderPromise = page.waitForResponse('**/api/orders');
174
-
175
- // Step 1: Login
176
- await page.goto('/login');
177
- await page.fill('[data-testid="email"]', user.email);
178
- await page.fill('[data-testid="password"]', 'password123');
179
- await page.click('[data-testid="login-button"]');
180
- await loginPromise;
181
-
182
- // Assert: Dashboard visible
183
- await expect(page).toHaveURL('/dashboard');
184
- await expect(page.getByText(`Welcome, ${user.name}`)).toBeVisible();
185
-
186
- // Step 2: Add product to cart
187
- await page.goto(`/products/${product.id}`);
188
- await page.click('[data-testid="add-to-cart"]');
189
- await cartPromise;
190
- await expect(page.getByText('Added to cart')).toBeVisible();
191
-
192
- // Step 3: Checkout with saved payment
193
- await page.goto('/checkout');
194
- await expect(page.getByText('Visa ending in 1234')).toBeVisible(); // Saved card
195
- await page.click('[data-testid="use-saved-card"]');
196
- await page.click('[data-testid="place-order"]');
197
- await orderPromise;
198
-
199
- // Assert: Order confirmation
200
- await expect(page.getByText('Order Confirmed')).toBeVisible();
201
- await expect(page.getByText(/Order #\d+/)).toBeVisible();
202
- await expect(page.getByText('$29.99')).toBeVisible();
203
- });
204
- });
205
- ```
206
-
207
- **Key Points (E2E)**:
208
-
209
- - Tests complete user journey across multiple pages
210
- - API setup for data (fast), UI for assertions (user-centric)
211
- - Network-first interception to prevent flakiness
212
- - Validates critical revenue path end-to-end
213
-
214
- ### Example 2: Integration Test (API/Service Layer)
215
-
216
- **Scenario**: UserService creates user and assigns role via AuthRepository.
217
-
218
- ```typescript
219
- // tests/integration/user-service.spec.ts
220
- import { test, expect } from '@playwright/test';
221
- import { createUser } from '../test-utils/factories';
222
-
223
- test.describe('UserService Integration', () => {
224
- test('should create user with admin role via API', async ({ request }) => {
225
- const userData = createUser({ role: 'admin' });
226
-
227
- // Direct API call (no UI)
228
- const response = await request.post('/api/users', {
229
- data: userData,
230
- });
231
-
232
- expect(response.status()).toBe(201);
233
-
234
- const createdUser = await response.json();
235
- expect(createdUser.id).toBeTruthy();
236
- expect(createdUser.email).toBe(userData.email);
237
- expect(createdUser.role).toBe('admin');
238
-
239
- // Verify database state
240
- const getResponse = await request.get(`/api/users/${createdUser.id}`);
241
- expect(getResponse.status()).toBe(200);
242
-
243
- const fetchedUser = await getResponse.json();
244
- expect(fetchedUser.role).toBe('admin');
245
- expect(fetchedUser.permissions).toContain('user:delete');
246
- expect(fetchedUser.permissions).toContain('user:update');
247
-
248
- // Cleanup
249
- await request.delete(`/api/users/${createdUser.id}`);
250
- });
251
-
252
- test('should validate email uniqueness constraint', async ({ request }) => {
253
- const userData = createUser({ email: 'duplicate@example.com' });
254
-
255
- // Create first user
256
- const response1 = await request.post('/api/users', { data: userData });
257
- expect(response1.status()).toBe(201);
258
-
259
- const user1 = await response1.json();
260
-
261
- // Attempt duplicate email
262
- const response2 = await request.post('/api/users', { data: userData });
263
- expect(response2.status()).toBe(409); // Conflict
264
- const error = await response2.json();
265
- expect(error.message).toContain('Email already exists');
266
-
267
- // Cleanup
268
- await request.delete(`/api/users/${user1.id}`);
269
- });
270
- });
271
- ```
272
-
273
- **Key Points (Integration)**:
274
-
275
- - Tests service layer + database interaction
276
- - No UI involved—pure API validation
277
- - Business logic focus (role assignment, constraints)
278
- - Faster than E2E, more realistic than unit tests
279
-
280
- ### Example 3: Component Test (Isolated UI Component)
281
-
282
- **Scenario**: Test button component in isolation with props and user interactions.
283
-
284
- ```typescript
285
- // src/components/Button.cy.tsx (Cypress Component Test)
286
- import { Button } from './Button';
287
-
288
- describe('Button Component', () => {
289
- it('should render with correct label', () => {
290
- cy.mount(<Button label="Click Me" />);
291
- cy.contains('Click Me').should('be.visible');
292
- });
293
-
294
- it('should call onClick handler when clicked', () => {
295
- const onClickSpy = cy.stub().as('onClick');
296
- cy.mount(<Button label="Submit" onClick={onClickSpy} />);
297
-
298
- cy.get('button').click();
299
- cy.get('@onClick').should('have.been.calledOnce');
300
- });
301
-
302
- it('should be disabled when disabled prop is true', () => {
303
- cy.mount(<Button label="Disabled" disabled={true} />);
304
- cy.get('button').should('be.disabled');
305
- cy.get('button').should('have.attr', 'aria-disabled', 'true');
306
- });
307
-
308
- it('should show loading spinner when loading', () => {
309
- cy.mount(<Button label="Loading" loading={true} />);
310
- cy.get('[data-testid="spinner"]').should('be.visible');
311
- cy.get('button').should('be.disabled');
312
- });
313
-
314
- it('should apply variant styles correctly', () => {
315
- cy.mount(<Button label="Primary" variant="primary" />);
316
- cy.get('button').should('have.class', 'btn-primary');
317
-
318
- cy.mount(<Button label="Secondary" variant="secondary" />);
319
- cy.get('button').should('have.class', 'btn-secondary');
320
- });
321
- });
322
-
323
- // Playwright Component Test equivalent
324
- import { test, expect } from '@playwright/experimental-ct-react';
325
- import { Button } from './Button';
326
-
327
- test.describe('Button Component', () => {
328
- test('should call onClick handler when clicked', async ({ mount }) => {
329
- let clicked = false;
330
- const component = await mount(
331
- <Button label="Submit" onClick={() => { clicked = true; }} />
332
- );
333
-
334
- await component.getByRole('button').click();
335
- expect(clicked).toBe(true);
336
- });
337
-
338
- test('should be disabled when loading', async ({ mount }) => {
339
- const component = await mount(<Button label="Loading" loading={true} />);
340
- await expect(component.getByRole('button')).toBeDisabled();
341
- await expect(component.getByTestId('spinner')).toBeVisible();
342
- });
343
- });
344
- ```
345
-
346
- **Key Points (Component)**:
347
-
348
- - Tests UI component in isolation (no full app)
349
- - Props + user interactions + visual states
350
- - Faster than E2E, more realistic than unit tests for UI
351
- - Great for design system components
352
-
353
- ### Example 4: Unit Test (Pure Function)
354
-
355
- **Scenario**: Test pure business logic function without framework dependencies.
356
-
357
- ```typescript
358
- // src/utils/price-calculator.test.ts (Jest/Vitest)
359
- import { calculateDiscount, applyTaxes, calculateTotal } from './price-calculator';
360
-
361
- describe('PriceCalculator', () => {
362
- describe('calculateDiscount', () => {
363
- it('should apply percentage discount correctly', () => {
364
- const result = calculateDiscount(100, { type: 'percentage', value: 20 });
365
- expect(result).toBe(80);
366
- });
367
-
368
- it('should apply fixed amount discount correctly', () => {
369
- const result = calculateDiscount(100, { type: 'fixed', value: 15 });
370
- expect(result).toBe(85);
371
- });
372
-
373
- it('should not apply discount below zero', () => {
374
- const result = calculateDiscount(10, { type: 'fixed', value: 20 });
375
- expect(result).toBe(0);
376
- });
377
-
378
- it('should handle no discount', () => {
379
- const result = calculateDiscount(100, { type: 'none', value: 0 });
380
- expect(result).toBe(100);
381
- });
382
- });
383
-
384
- describe('applyTaxes', () => {
385
- it('should calculate tax correctly for US', () => {
386
- const result = applyTaxes(100, { country: 'US', rate: 0.08 });
387
- expect(result).toBe(108);
388
- });
389
-
390
- it('should calculate tax correctly for EU (VAT)', () => {
391
- const result = applyTaxes(100, { country: 'DE', rate: 0.19 });
392
- expect(result).toBe(119);
393
- });
394
-
395
- it('should handle zero tax rate', () => {
396
- const result = applyTaxes(100, { country: 'US', rate: 0 });
397
- expect(result).toBe(100);
398
- });
399
- });
400
-
401
- describe('calculateTotal', () => {
402
- it('should calculate total with discount and taxes', () => {
403
- const items = [
404
- { price: 50, quantity: 2 }, // 100
405
- { price: 30, quantity: 1 }, // 30
406
- ];
407
- const discount = { type: 'percentage', value: 10 }; // -13
408
- const tax = { country: 'US', rate: 0.08 }; // +9.36
409
-
410
- const result = calculateTotal(items, discount, tax);
411
- expect(result).toBeCloseTo(126.36, 2);
412
- });
413
-
414
- it('should handle empty items array', () => {
415
- const result = calculateTotal([], { type: 'none', value: 0 }, { country: 'US', rate: 0 });
416
- expect(result).toBe(0);
417
- });
418
-
419
- it('should calculate correctly without discount or tax', () => {
420
- const items = [{ price: 25, quantity: 4 }];
421
- const result = calculateTotal(items, { type: 'none', value: 0 }, { country: 'US', rate: 0 });
422
- expect(result).toBe(100);
423
- });
424
- });
425
- });
426
- ```
427
-
428
- **Key Points (Unit)**:
429
-
430
- - Pure function testing—no framework dependencies
431
- - Fast execution (milliseconds)
432
- - Edge case coverage (zero, negative, empty inputs)
433
- - High cyclomatic complexity handled at unit level
434
-
435
- ## When to Use Which Level
436
-
437
- | Scenario | Unit | Integration | E2E |
438
- | ---------------------- | ------------- | ----------------- | ------------- |
439
- | Pure business logic | ✅ Primary | ❌ Overkill | ❌ Overkill |
440
- | Database operations | ❌ Can't test | ✅ Primary | ❌ Overkill |
441
- | API contracts | ❌ Can't test | ✅ Primary | ⚠️ Supplement |
442
- | User journeys | ❌ Can't test | ❌ Can't test | ✅ Primary |
443
- | Component props/events | ✅ Partial | ⚠️ Component test | ❌ Overkill |
444
- | Visual regression | ❌ Can't test | ⚠️ Component test | ✅ Primary |
445
- | Error handling (logic) | ✅ Primary | ⚠️ Integration | ❌ Overkill |
446
- | Error handling (UI) | ❌ Partial | ⚠️ Component test | ✅ Primary |
447
-
448
- ## Anti-Pattern Examples
449
-
450
- **❌ BAD: E2E test for business logic**
451
-
452
- ```typescript
453
- // DON'T DO THIS
454
- test('calculate discount via UI', async ({ page }) => {
455
- await page.goto('/calculator');
456
- await page.fill('[data-testid="price"]', '100');
457
- await page.fill('[data-testid="discount"]', '20');
458
- await page.click('[data-testid="calculate"]');
459
- await expect(page.getByText('$80')).toBeVisible();
460
- });
461
- // Problem: Slow, brittle, tests logic that should be unit tested
462
- ```
463
-
464
- **✅ GOOD: Unit test for business logic**
465
-
466
- ```typescript
467
- test('calculate discount', () => {
468
- expect(calculateDiscount(100, 20)).toBe(80);
469
- });
470
- // Fast, reliable, isolated
471
- ```
472
-
473
- _Source: Murat Testing Philosophy (test pyramid), existing test-levels-framework.md structure._