agentvibes 2.13.6 → 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 (422) hide show
  1. package/.claude/personalities/rapper.md +1 -1
  2. package/CLAUDE.md +156 -0
  3. package/README.md +7 -8
  4. package/package.json +1 -1
  5. package/src/installer.js +20 -25
  6. package/.bmad/_cfg/agent-manifest.csv +0 -11
  7. package/.bmad/_cfg/agent-voice-map.csv +0 -11
  8. package/.bmad/_cfg/agents/bmm-analyst.customize.yaml +0 -42
  9. package/.bmad/_cfg/agents/bmm-architect.customize.yaml +0 -42
  10. package/.bmad/_cfg/agents/bmm-dev.customize.yaml +0 -42
  11. package/.bmad/_cfg/agents/bmm-frame-expert.customize.yaml +0 -42
  12. package/.bmad/_cfg/agents/bmm-pm.customize.yaml +0 -42
  13. package/.bmad/_cfg/agents/bmm-sm.customize.yaml +0 -42
  14. package/.bmad/_cfg/agents/bmm-tea.customize.yaml +0 -42
  15. package/.bmad/_cfg/agents/bmm-tech-writer.customize.yaml +0 -42
  16. package/.bmad/_cfg/agents/bmm-ux-designer.customize.yaml +0 -42
  17. package/.bmad/_cfg/agents/core-bmad-master.customize.yaml +0 -42
  18. package/.bmad/_cfg/files-manifest.csv +0 -243
  19. package/.bmad/_cfg/ides/claude-code.yaml +0 -6
  20. package/.bmad/_cfg/manifest.yaml +0 -9
  21. package/.bmad/_cfg/task-manifest.csv +0 -5
  22. package/.bmad/_cfg/tool-manifest.csv +0 -2
  23. package/.bmad/_cfg/workflow-manifest.csv +0 -38
  24. package/.bmad/bmm/README.md +0 -128
  25. package/.bmad/bmm/agents/analyst.md +0 -79
  26. package/.bmad/bmm/agents/analyst.md.backup-pre-tts +0 -75
  27. package/.bmad/bmm/agents/architect.md +0 -80
  28. package/.bmad/bmm/agents/dev.md +0 -70
  29. package/.bmad/bmm/agents/frame-expert.md +0 -72
  30. package/.bmad/bmm/agents/pm.md +0 -84
  31. package/.bmad/bmm/agents/sm.md +0 -93
  32. package/.bmad/bmm/agents/tea.md +0 -80
  33. package/.bmad/bmm/agents/tech-writer.md +0 -84
  34. package/.bmad/bmm/agents/ux-designer.md +0 -79
  35. package/.bmad/bmm/config.yaml +0 -17
  36. package/.bmad/bmm/docs/README.md +0 -236
  37. package/.bmad/bmm/docs/agents-guide.md +0 -1058
  38. package/.bmad/bmm/docs/brownfield-guide.md +0 -762
  39. package/.bmad/bmm/docs/enterprise-agentic-development.md +0 -686
  40. package/.bmad/bmm/docs/faq.md +0 -588
  41. package/.bmad/bmm/docs/glossary.md +0 -320
  42. package/.bmad/bmm/docs/party-mode.md +0 -224
  43. package/.bmad/bmm/docs/quick-spec-flow.md +0 -652
  44. package/.bmad/bmm/docs/quick-start.md +0 -376
  45. package/.bmad/bmm/docs/scale-adaptive-system.md +0 -612
  46. package/.bmad/bmm/docs/test-architecture.md +0 -396
  47. package/.bmad/bmm/docs/workflow-architecture-reference.md +0 -366
  48. package/.bmad/bmm/docs/workflow-document-project-reference.md +0 -489
  49. package/.bmad/bmm/docs/workflows-analysis.md +0 -370
  50. package/.bmad/bmm/docs/workflows-implementation.md +0 -286
  51. package/.bmad/bmm/docs/workflows-planning.md +0 -612
  52. package/.bmad/bmm/docs/workflows-solutioning.md +0 -554
  53. package/.bmad/bmm/teams/default-party.csv +0 -20
  54. package/.bmad/bmm/teams/team-fullstack.yaml +0 -13
  55. package/.bmad/bmm/testarch/knowledge/ci-burn-in.md +0 -675
  56. package/.bmad/bmm/testarch/knowledge/component-tdd.md +0 -486
  57. package/.bmad/bmm/testarch/knowledge/contract-testing.md +0 -957
  58. package/.bmad/bmm/testarch/knowledge/data-factories.md +0 -500
  59. package/.bmad/bmm/testarch/knowledge/email-auth.md +0 -721
  60. package/.bmad/bmm/testarch/knowledge/error-handling.md +0 -725
  61. package/.bmad/bmm/testarch/knowledge/feature-flags.md +0 -750
  62. package/.bmad/bmm/testarch/knowledge/fixture-architecture.md +0 -401
  63. package/.bmad/bmm/testarch/knowledge/network-first.md +0 -486
  64. package/.bmad/bmm/testarch/knowledge/nfr-criteria.md +0 -670
  65. package/.bmad/bmm/testarch/knowledge/playwright-config.md +0 -730
  66. package/.bmad/bmm/testarch/knowledge/probability-impact.md +0 -601
  67. package/.bmad/bmm/testarch/knowledge/risk-governance.md +0 -615
  68. package/.bmad/bmm/testarch/knowledge/selective-testing.md +0 -732
  69. package/.bmad/bmm/testarch/knowledge/selector-resilience.md +0 -527
  70. package/.bmad/bmm/testarch/knowledge/test-healing-patterns.md +0 -644
  71. package/.bmad/bmm/testarch/knowledge/test-levels-framework.md +0 -473
  72. package/.bmad/bmm/testarch/knowledge/test-priorities-matrix.md +0 -373
  73. package/.bmad/bmm/testarch/knowledge/test-quality.md +0 -664
  74. package/.bmad/bmm/testarch/knowledge/timing-debugging.md +0 -372
  75. package/.bmad/bmm/testarch/knowledge/visual-debugging.md +0 -524
  76. package/.bmad/bmm/testarch/tea-index.csv +0 -22
  77. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/instructions.md +0 -112
  78. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/project-context.md +0 -25
  79. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/workflow.yaml +0 -26
  80. package/.bmad/bmm/workflows/1-analysis/domain-research/instructions.md +0 -425
  81. package/.bmad/bmm/workflows/1-analysis/domain-research/template.md +0 -180
  82. package/.bmad/bmm/workflows/1-analysis/domain-research/workflow.yaml +0 -28
  83. package/.bmad/bmm/workflows/1-analysis/product-brief/checklist.md +0 -115
  84. package/.bmad/bmm/workflows/1-analysis/product-brief/instructions.md +0 -524
  85. package/.bmad/bmm/workflows/1-analysis/product-brief/template.md +0 -181
  86. package/.bmad/bmm/workflows/1-analysis/product-brief/workflow.yaml +0 -45
  87. package/.bmad/bmm/workflows/1-analysis/research/checklist-deep-prompt.md +0 -144
  88. package/.bmad/bmm/workflows/1-analysis/research/checklist-technical.md +0 -249
  89. package/.bmad/bmm/workflows/1-analysis/research/checklist.md +0 -299
  90. package/.bmad/bmm/workflows/1-analysis/research/claude-code/injections.yaml +0 -114
  91. package/.bmad/bmm/workflows/1-analysis/research/instructions-deep-prompt.md +0 -438
  92. package/.bmad/bmm/workflows/1-analysis/research/instructions-market.md +0 -675
  93. package/.bmad/bmm/workflows/1-analysis/research/instructions-router.md +0 -134
  94. package/.bmad/bmm/workflows/1-analysis/research/instructions-technical.md +0 -534
  95. package/.bmad/bmm/workflows/1-analysis/research/template-deep-prompt.md +0 -94
  96. package/.bmad/bmm/workflows/1-analysis/research/template-market.md +0 -347
  97. package/.bmad/bmm/workflows/1-analysis/research/template-technical.md +0 -245
  98. package/.bmad/bmm/workflows/1-analysis/research/workflow.yaml +0 -44
  99. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/epics-template.md +0 -80
  100. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/instructions.md +0 -616
  101. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/workflow.yaml +0 -53
  102. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/checklist.md +0 -310
  103. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/instructions.md +0 -1308
  104. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +0 -145
  105. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.yaml +0 -61
  106. package/.bmad/bmm/workflows/2-plan-workflows/prd/checklist.md +0 -346
  107. package/.bmad/bmm/workflows/2-plan-workflows/prd/domain-complexity.csv +0 -13
  108. package/.bmad/bmm/workflows/2-plan-workflows/prd/instructions.md +0 -703
  109. package/.bmad/bmm/workflows/2-plan-workflows/prd/prd-template.md +0 -204
  110. package/.bmad/bmm/workflows/2-plan-workflows/prd/project-types.csv +0 -11
  111. package/.bmad/bmm/workflows/2-plan-workflows/prd/workflow.yaml +0 -52
  112. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/checklist.md +0 -217
  113. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/epics-template.md +0 -74
  114. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions-generate-stories.md +0 -436
  115. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions.md +0 -980
  116. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/tech-spec-template.md +0 -181
  117. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/user-story-template.md +0 -90
  118. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/workflow.yaml +0 -58
  119. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-patterns.yaml +0 -321
  120. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-template.md +0 -103
  121. package/.bmad/bmm/workflows/3-solutioning/architecture/checklist.md +0 -240
  122. package/.bmad/bmm/workflows/3-solutioning/architecture/decision-catalog.yaml +0 -222
  123. package/.bmad/bmm/workflows/3-solutioning/architecture/instructions.md +0 -768
  124. package/.bmad/bmm/workflows/3-solutioning/architecture/pattern-categories.csv +0 -13
  125. package/.bmad/bmm/workflows/3-solutioning/architecture/workflow.yaml +0 -55
  126. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/checklist.md +0 -169
  127. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/instructions.md +0 -332
  128. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/template.md +0 -146
  129. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/workflow.yaml +0 -62
  130. package/.bmad/bmm/workflows/4-implementation/code-review/backlog_template.md +0 -12
  131. package/.bmad/bmm/workflows/4-implementation/code-review/checklist.md +0 -22
  132. package/.bmad/bmm/workflows/4-implementation/code-review/instructions.md +0 -398
  133. package/.bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +0 -60
  134. package/.bmad/bmm/workflows/4-implementation/correct-course/checklist.md +0 -279
  135. package/.bmad/bmm/workflows/4-implementation/correct-course/instructions.md +0 -206
  136. package/.bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +0 -56
  137. package/.bmad/bmm/workflows/4-implementation/create-story/checklist.md +0 -240
  138. package/.bmad/bmm/workflows/4-implementation/create-story/instructions.md +0 -256
  139. package/.bmad/bmm/workflows/4-implementation/create-story/template.md +0 -51
  140. package/.bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +0 -71
  141. package/.bmad/bmm/workflows/4-implementation/dev-story/checklist.md +0 -38
  142. package/.bmad/bmm/workflows/4-implementation/dev-story/instructions.md +0 -267
  143. package/.bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +0 -56
  144. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/checklist.md +0 -17
  145. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/instructions.md +0 -164
  146. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/template.md +0 -76
  147. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/workflow.yaml +0 -57
  148. package/.bmad/bmm/workflows/4-implementation/retrospective/instructions.md +0 -1443
  149. package/.bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +0 -56
  150. package/.bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +0 -33
  151. package/.bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +0 -234
  152. package/.bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +0 -55
  153. package/.bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +0 -49
  154. package/.bmad/bmm/workflows/4-implementation/story-context/checklist.md +0 -16
  155. package/.bmad/bmm/workflows/4-implementation/story-context/context-template.xml +0 -34
  156. package/.bmad/bmm/workflows/4-implementation/story-context/instructions.md +0 -209
  157. package/.bmad/bmm/workflows/4-implementation/story-context/workflow.yaml +0 -61
  158. package/.bmad/bmm/workflows/4-implementation/story-done/instructions.md +0 -111
  159. package/.bmad/bmm/workflows/4-implementation/story-done/workflow.yaml +0 -26
  160. package/.bmad/bmm/workflows/4-implementation/story-ready/instructions.md +0 -117
  161. package/.bmad/bmm/workflows/4-implementation/story-ready/workflow.yaml +0 -23
  162. package/.bmad/bmm/workflows/document-project/checklist.md +0 -245
  163. package/.bmad/bmm/workflows/document-project/documentation-requirements.csv +0 -12
  164. package/.bmad/bmm/workflows/document-project/instructions.md +0 -222
  165. package/.bmad/bmm/workflows/document-project/templates/deep-dive-template.md +0 -345
  166. package/.bmad/bmm/workflows/document-project/templates/index-template.md +0 -169
  167. package/.bmad/bmm/workflows/document-project/templates/project-overview-template.md +0 -103
  168. package/.bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +0 -160
  169. package/.bmad/bmm/workflows/document-project/templates/source-tree-template.md +0 -135
  170. package/.bmad/bmm/workflows/document-project/workflow.yaml +0 -29
  171. package/.bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +0 -298
  172. package/.bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +0 -31
  173. package/.bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +0 -1106
  174. package/.bmad/bmm/workflows/document-project/workflows/full-scan.yaml +0 -31
  175. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-helpers.md +0 -127
  176. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-library.json +0 -90
  177. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-templates.yaml +0 -127
  178. package/.bmad/bmm/workflows/frame-expert/_shared/validate-json-instructions.md +0 -79
  179. package/.bmad/bmm/workflows/frame-expert/create-dataflow/checklist.md +0 -39
  180. package/.bmad/bmm/workflows/frame-expert/create-dataflow/instructions.md +0 -131
  181. package/.bmad/bmm/workflows/frame-expert/create-dataflow/workflow.yaml +0 -23
  182. package/.bmad/bmm/workflows/frame-expert/create-diagram/checklist.md +0 -43
  183. package/.bmad/bmm/workflows/frame-expert/create-diagram/instructions.md +0 -142
  184. package/.bmad/bmm/workflows/frame-expert/create-diagram/workflow.yaml +0 -24
  185. package/.bmad/bmm/workflows/frame-expert/create-flowchart/checklist.md +0 -49
  186. package/.bmad/bmm/workflows/frame-expert/create-flowchart/instructions.md +0 -242
  187. package/.bmad/bmm/workflows/frame-expert/create-flowchart/workflow.yaml +0 -27
  188. package/.bmad/bmm/workflows/frame-expert/create-wireframe/checklist.md +0 -38
  189. package/.bmad/bmm/workflows/frame-expert/create-wireframe/instructions.md +0 -133
  190. package/.bmad/bmm/workflows/frame-expert/create-wireframe/workflow.yaml +0 -23
  191. package/.bmad/bmm/workflows/techdoc/documentation-standards.md +0 -262
  192. package/.bmad/bmm/workflows/testarch/atdd/atdd-checklist-template.md +0 -363
  193. package/.bmad/bmm/workflows/testarch/atdd/checklist.md +0 -373
  194. package/.bmad/bmm/workflows/testarch/atdd/instructions.md +0 -785
  195. package/.bmad/bmm/workflows/testarch/atdd/workflow.yaml +0 -45
  196. package/.bmad/bmm/workflows/testarch/automate/checklist.md +0 -580
  197. package/.bmad/bmm/workflows/testarch/automate/instructions.md +0 -1303
  198. package/.bmad/bmm/workflows/testarch/automate/workflow.yaml +0 -52
  199. package/.bmad/bmm/workflows/testarch/ci/checklist.md +0 -246
  200. package/.bmad/bmm/workflows/testarch/ci/github-actions-template.yaml +0 -165
  201. package/.bmad/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +0 -128
  202. package/.bmad/bmm/workflows/testarch/ci/instructions.md +0 -517
  203. package/.bmad/bmm/workflows/testarch/ci/workflow.yaml +0 -45
  204. package/.bmad/bmm/workflows/testarch/framework/checklist.md +0 -321
  205. package/.bmad/bmm/workflows/testarch/framework/instructions.md +0 -455
  206. package/.bmad/bmm/workflows/testarch/framework/workflow.yaml +0 -47
  207. package/.bmad/bmm/workflows/testarch/nfr-assess/checklist.md +0 -405
  208. package/.bmad/bmm/workflows/testarch/nfr-assess/instructions.md +0 -722
  209. package/.bmad/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +0 -443
  210. package/.bmad/bmm/workflows/testarch/nfr-assess/workflow.yaml +0 -47
  211. package/.bmad/bmm/workflows/testarch/test-design/checklist.md +0 -234
  212. package/.bmad/bmm/workflows/testarch/test-design/instructions.md +0 -782
  213. package/.bmad/bmm/workflows/testarch/test-design/test-design-template.md +0 -285
  214. package/.bmad/bmm/workflows/testarch/test-design/workflow.yaml +0 -48
  215. package/.bmad/bmm/workflows/testarch/test-review/checklist.md +0 -470
  216. package/.bmad/bmm/workflows/testarch/test-review/instructions.md +0 -608
  217. package/.bmad/bmm/workflows/testarch/test-review/test-review-template.md +0 -388
  218. package/.bmad/bmm/workflows/testarch/test-review/workflow.yaml +0 -46
  219. package/.bmad/bmm/workflows/testarch/trace/checklist.md +0 -654
  220. package/.bmad/bmm/workflows/testarch/trace/instructions.md +0 -1045
  221. package/.bmad/bmm/workflows/testarch/trace/trace-template.md +0 -673
  222. package/.bmad/bmm/workflows/testarch/trace/workflow.yaml +0 -55
  223. package/.bmad/bmm/workflows/workflow-status/init/instructions.md +0 -334
  224. package/.bmad/bmm/workflows/workflow-status/init/workflow.yaml +0 -28
  225. package/.bmad/bmm/workflows/workflow-status/instructions.md +0 -388
  226. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-brownfield.yaml +0 -138
  227. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-greenfield.yaml +0 -126
  228. package/.bmad/bmm/workflows/workflow-status/paths/game-design.yaml +0 -52
  229. package/.bmad/bmm/workflows/workflow-status/paths/method-brownfield.yaml +0 -122
  230. package/.bmad/bmm/workflows/workflow-status/paths/method-greenfield.yaml +0 -113
  231. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-brownfield.yaml +0 -58
  232. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-greenfield.yaml +0 -47
  233. package/.bmad/bmm/workflows/workflow-status/project-levels.yaml +0 -59
  234. package/.bmad/bmm/workflows/workflow-status/workflow-status-template.yaml +0 -24
  235. package/.bmad/bmm/workflows/workflow-status/workflow.yaml +0 -28
  236. package/.bmad/core/agents/bmad-master.md +0 -72
  237. package/.bmad/core/agents/bmad-web-orchestrator.agent.xml +0 -113
  238. package/.bmad/core/config.yaml +0 -11
  239. package/.bmad/core/tasks/adv-elicit-methods.csv +0 -39
  240. package/.bmad/core/tasks/advanced-elicitation-methods.csv +0 -21
  241. package/.bmad/core/tasks/advanced-elicitation.xml +0 -106
  242. package/.bmad/core/tasks/index-docs.xml +0 -65
  243. package/.bmad/core/tasks/validate-workflow.xml +0 -89
  244. package/.bmad/core/tasks/workflow.xml +0 -270
  245. package/.bmad/core/tools/shard-doc.xml +0 -109
  246. package/.bmad/core/workflows/brainstorming/README.md +0 -261
  247. package/.bmad/core/workflows/brainstorming/brain-methods.csv +0 -36
  248. package/.bmad/core/workflows/brainstorming/instructions.md +0 -315
  249. package/.bmad/core/workflows/brainstorming/template.md +0 -106
  250. package/.bmad/core/workflows/brainstorming/workflow.yaml +0 -38
  251. package/.bmad/core/workflows/party-mode/instructions.md +0 -203
  252. package/.bmad/core/workflows/party-mode/workflow.yaml +0 -28
  253. package/.bmad/docs/claude-code-instructions.md +0 -25
  254. package/.claude/commands/BMad/analyst.md +0 -88
  255. package/.claude/commands/BMad/architect.md +0 -89
  256. package/.claude/commands/BMad/bmad-master.md +0 -114
  257. package/.claude/commands/BMad/bmad-orchestrator.md +0 -151
  258. package/.claude/commands/BMad/dev.md +0 -85
  259. package/.claude/commands/BMad/pm.md +0 -88
  260. package/.claude/commands/BMad/po.md +0 -83
  261. package/.claude/commands/BMad/qa.md +0 -91
  262. package/.claude/commands/BMad/sm.md +0 -69
  263. package/.claude/commands/BMad/tasks/advanced-elicitation.md +0 -123
  264. package/.claude/commands/BMad/tasks/apply-qa-fixes.md +0 -154
  265. package/.claude/commands/BMad/tasks/brownfield-create-epic.md +0 -166
  266. package/.claude/commands/BMad/tasks/brownfield-create-story.md +0 -153
  267. package/.claude/commands/BMad/tasks/correct-course.md +0 -76
  268. package/.claude/commands/BMad/tasks/create-brownfield-story.md +0 -318
  269. package/.claude/commands/BMad/tasks/create-deep-research-prompt.md +0 -284
  270. package/.claude/commands/BMad/tasks/create-doc.md +0 -107
  271. package/.claude/commands/BMad/tasks/create-next-story.md +0 -118
  272. package/.claude/commands/BMad/tasks/document-project.md +0 -349
  273. package/.claude/commands/BMad/tasks/execute-checklist.md +0 -92
  274. package/.claude/commands/BMad/tasks/facilitate-brainstorming-session.md +0 -142
  275. package/.claude/commands/BMad/tasks/generate-ai-frontend-prompt.md +0 -57
  276. package/.claude/commands/BMad/tasks/index-docs.md +0 -179
  277. package/.claude/commands/BMad/tasks/kb-mode-interaction.md +0 -81
  278. package/.claude/commands/BMad/tasks/nfr-assess.md +0 -349
  279. package/.claude/commands/BMad/tasks/qa-gate.md +0 -167
  280. package/.claude/commands/BMad/tasks/review-story.md +0 -320
  281. package/.claude/commands/BMad/tasks/risk-profile.md +0 -359
  282. package/.claude/commands/BMad/tasks/shard-doc.md +0 -191
  283. package/.claude/commands/BMad/tasks/test-design.md +0 -180
  284. package/.claude/commands/BMad/tasks/trace-requirements.md +0 -270
  285. package/.claude/commands/BMad/tasks/validate-next-story.md +0 -140
  286. package/.claude/commands/BMad/ux-expert.md +0 -73
  287. package/.claude/commands/bmad/bmm/agents/analyst.md +0 -14
  288. package/.claude/commands/bmad/bmm/agents/architect.md +0 -14
  289. package/.claude/commands/bmad/bmm/agents/dev.md +0 -14
  290. package/.claude/commands/bmad/bmm/agents/frame-expert.md +0 -14
  291. package/.claude/commands/bmad/bmm/agents/pm.md +0 -14
  292. package/.claude/commands/bmad/bmm/agents/sm.md +0 -14
  293. package/.claude/commands/bmad/bmm/agents/tea.md +0 -14
  294. package/.claude/commands/bmad/bmm/agents/tech-writer.md +0 -14
  295. package/.claude/commands/bmad/bmm/agents/ux-designer.md +0 -14
  296. package/.claude/commands/bmad/bmm/workflows/architecture.md +0 -13
  297. package/.claude/commands/bmad/bmm/workflows/brainstorm-project.md +0 -13
  298. package/.claude/commands/bmad/bmm/workflows/code-review.md +0 -13
  299. package/.claude/commands/bmad/bmm/workflows/correct-course.md +0 -13
  300. package/.claude/commands/bmad/bmm/workflows/create-dataflow.md +0 -13
  301. package/.claude/commands/bmad/bmm/workflows/create-diagram.md +0 -13
  302. package/.claude/commands/bmad/bmm/workflows/create-epics-and-stories.md +0 -13
  303. package/.claude/commands/bmad/bmm/workflows/create-flowchart.md +0 -13
  304. package/.claude/commands/bmad/bmm/workflows/create-story.md +0 -13
  305. package/.claude/commands/bmad/bmm/workflows/create-ux-design.md +0 -13
  306. package/.claude/commands/bmad/bmm/workflows/create-wireframe.md +0 -13
  307. package/.claude/commands/bmad/bmm/workflows/dev-story.md +0 -13
  308. package/.claude/commands/bmad/bmm/workflows/document-project.md +0 -13
  309. package/.claude/commands/bmad/bmm/workflows/domain-research.md +0 -13
  310. package/.claude/commands/bmad/bmm/workflows/epic-tech-context.md +0 -13
  311. package/.claude/commands/bmad/bmm/workflows/implementation-readiness.md +0 -13
  312. package/.claude/commands/bmad/bmm/workflows/prd.md +0 -13
  313. package/.claude/commands/bmad/bmm/workflows/product-brief.md +0 -13
  314. package/.claude/commands/bmad/bmm/workflows/research.md +0 -13
  315. package/.claude/commands/bmad/bmm/workflows/retrospective.md +0 -13
  316. package/.claude/commands/bmad/bmm/workflows/sprint-planning.md +0 -13
  317. package/.claude/commands/bmad/bmm/workflows/story-context.md +0 -13
  318. package/.claude/commands/bmad/bmm/workflows/story-done.md +0 -13
  319. package/.claude/commands/bmad/bmm/workflows/story-ready.md +0 -13
  320. package/.claude/commands/bmad/bmm/workflows/tech-spec.md +0 -13
  321. package/.claude/commands/bmad/bmm/workflows/workflow-init.md +0 -13
  322. package/.claude/commands/bmad/bmm/workflows/workflow-status.md +0 -13
  323. package/.claude/commands/bmad/core/agents/bmad-master.md +0 -14
  324. package/.claude/commands/bmad/core/tasks/advanced-elicitation.md +0 -9
  325. package/.claude/commands/bmad/core/tasks/index-docs.md +0 -9
  326. package/.claude/commands/bmad/core/tools/shard-doc.md +0 -9
  327. package/.claude/commands/bmad/core/workflows/brainstorming.md +0 -13
  328. package/.claude/commands/bmad/core/workflows/party-mode.md +0 -13
  329. package/.claude/github-star-reminder.txt +0 -1
  330. package/.claude/hooks/bmad-party-manager.sh +0 -225
  331. package/.claude/hooks/stop.sh +0 -221
  332. package/.claude/piper-voices-dir.txt +0 -1
  333. package/.mcp.json +0 -88
  334. package/RELEASE_NOTES_v2.4.0_DRAFT.md +0 -116
  335. package/RELEASE_NOTES_v2.4.1_DRAFT.md +0 -61
  336. package/docs/2025-11-15_15-14-33.snagx +0 -0
  337. package/docs/Screenshot 2025-11-15 151325.png +0 -0
  338. package/docs/Screenshot 2025-11-15 151432.png +0 -0
  339. package/docs/macos-piper-issue.md +0 -172
  340. package/docs/stargazer-cms-prd.md +0 -1918
  341. package/docs/whatsapp-plugin-github-issue.md +0 -393
  342. package/docs/whatsapp-tts-plugin-feasibility.md +0 -418
  343. package/docs/whatsapp-tts-standalone-plugin.md +0 -628
  344. package/github-profile-draft.md +0 -57
  345. package/linkedin/vibe-coding-and-pulseaudio.md +0 -121
  346. package/mcp-server/agentvibes.db +0 -0
  347. package/scripts/audio-tunnel.config +0 -17
  348. package/v4-backup/.bmad-core/agent-teams/team-all.yaml +0 -15
  349. package/v4-backup/.bmad-core/agent-teams/team-fullstack.yaml +0 -19
  350. package/v4-backup/.bmad-core/agent-teams/team-ide-minimal.yaml +0 -11
  351. package/v4-backup/.bmad-core/agent-teams/team-no-ui.yaml +0 -14
  352. package/v4-backup/.bmad-core/agents/analyst.md +0 -84
  353. package/v4-backup/.bmad-core/agents/architect.md +0 -85
  354. package/v4-backup/.bmad-core/agents/bmad-master.md +0 -110
  355. package/v4-backup/.bmad-core/agents/bmad-orchestrator.md +0 -147
  356. package/v4-backup/.bmad-core/agents/dev.md +0 -81
  357. package/v4-backup/.bmad-core/agents/pm.md +0 -84
  358. package/v4-backup/.bmad-core/agents/po.md +0 -79
  359. package/v4-backup/.bmad-core/agents/qa.md +0 -87
  360. package/v4-backup/.bmad-core/agents/sm.md +0 -65
  361. package/v4-backup/.bmad-core/agents/ux-expert.md +0 -69
  362. package/v4-backup/.bmad-core/checklists/architect-checklist.md +0 -440
  363. package/v4-backup/.bmad-core/checklists/change-checklist.md +0 -184
  364. package/v4-backup/.bmad-core/checklists/pm-checklist.md +0 -372
  365. package/v4-backup/.bmad-core/checklists/po-master-checklist.md +0 -434
  366. package/v4-backup/.bmad-core/checklists/story-dod-checklist.md +0 -96
  367. package/v4-backup/.bmad-core/checklists/story-draft-checklist.md +0 -155
  368. package/v4-backup/.bmad-core/core-config.yaml +0 -22
  369. package/v4-backup/.bmad-core/data/bmad-kb.md +0 -809
  370. package/v4-backup/.bmad-core/data/brainstorming-techniques.md +0 -38
  371. package/v4-backup/.bmad-core/data/elicitation-methods.md +0 -156
  372. package/v4-backup/.bmad-core/data/technical-preferences.md +0 -5
  373. package/v4-backup/.bmad-core/data/test-levels-framework.md +0 -148
  374. package/v4-backup/.bmad-core/data/test-priorities-matrix.md +0 -174
  375. package/v4-backup/.bmad-core/enhanced-ide-development-workflow.md +0 -248
  376. package/v4-backup/.bmad-core/install-manifest.yaml +0 -230
  377. package/v4-backup/.bmad-core/tasks/advanced-elicitation.md +0 -119
  378. package/v4-backup/.bmad-core/tasks/apply-qa-fixes.md +0 -150
  379. package/v4-backup/.bmad-core/tasks/brownfield-create-epic.md +0 -162
  380. package/v4-backup/.bmad-core/tasks/brownfield-create-story.md +0 -149
  381. package/v4-backup/.bmad-core/tasks/correct-course.md +0 -72
  382. package/v4-backup/.bmad-core/tasks/create-brownfield-story.md +0 -314
  383. package/v4-backup/.bmad-core/tasks/create-deep-research-prompt.md +0 -280
  384. package/v4-backup/.bmad-core/tasks/create-doc.md +0 -103
  385. package/v4-backup/.bmad-core/tasks/create-next-story.md +0 -114
  386. package/v4-backup/.bmad-core/tasks/document-project.md +0 -345
  387. package/v4-backup/.bmad-core/tasks/execute-checklist.md +0 -88
  388. package/v4-backup/.bmad-core/tasks/facilitate-brainstorming-session.md +0 -138
  389. package/v4-backup/.bmad-core/tasks/generate-ai-frontend-prompt.md +0 -53
  390. package/v4-backup/.bmad-core/tasks/index-docs.md +0 -175
  391. package/v4-backup/.bmad-core/tasks/kb-mode-interaction.md +0 -77
  392. package/v4-backup/.bmad-core/tasks/nfr-assess.md +0 -345
  393. package/v4-backup/.bmad-core/tasks/qa-gate.md +0 -163
  394. package/v4-backup/.bmad-core/tasks/review-story.md +0 -316
  395. package/v4-backup/.bmad-core/tasks/risk-profile.md +0 -355
  396. package/v4-backup/.bmad-core/tasks/shard-doc.md +0 -187
  397. package/v4-backup/.bmad-core/tasks/test-design.md +0 -176
  398. package/v4-backup/.bmad-core/tasks/trace-requirements.md +0 -266
  399. package/v4-backup/.bmad-core/tasks/validate-next-story.md +0 -136
  400. package/v4-backup/.bmad-core/templates/architecture-tmpl.yaml +0 -651
  401. package/v4-backup/.bmad-core/templates/brainstorming-output-tmpl.yaml +0 -156
  402. package/v4-backup/.bmad-core/templates/brownfield-architecture-tmpl.yaml +0 -477
  403. package/v4-backup/.bmad-core/templates/brownfield-prd-tmpl.yaml +0 -281
  404. package/v4-backup/.bmad-core/templates/competitor-analysis-tmpl.yaml +0 -307
  405. package/v4-backup/.bmad-core/templates/front-end-architecture-tmpl.yaml +0 -219
  406. package/v4-backup/.bmad-core/templates/front-end-spec-tmpl.yaml +0 -350
  407. package/v4-backup/.bmad-core/templates/fullstack-architecture-tmpl.yaml +0 -824
  408. package/v4-backup/.bmad-core/templates/market-research-tmpl.yaml +0 -253
  409. package/v4-backup/.bmad-core/templates/prd-tmpl.yaml +0 -203
  410. package/v4-backup/.bmad-core/templates/project-brief-tmpl.yaml +0 -222
  411. package/v4-backup/.bmad-core/templates/qa-gate-tmpl.yaml +0 -103
  412. package/v4-backup/.bmad-core/templates/story-tmpl.yaml +0 -138
  413. package/v4-backup/.bmad-core/user-guide.md +0 -577
  414. package/v4-backup/.bmad-core/utils/bmad-doc-template.md +0 -327
  415. package/v4-backup/.bmad-core/utils/workflow-management.md +0 -71
  416. package/v4-backup/.bmad-core/workflows/brownfield-fullstack.yaml +0 -298
  417. package/v4-backup/.bmad-core/workflows/brownfield-service.yaml +0 -188
  418. package/v4-backup/.bmad-core/workflows/brownfield-ui.yaml +0 -198
  419. package/v4-backup/.bmad-core/workflows/greenfield-fullstack.yaml +0 -241
  420. package/v4-backup/.bmad-core/workflows/greenfield-service.yaml +0 -207
  421. package/v4-backup/.bmad-core/workflows/greenfield-ui.yaml +0 -236
  422. 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._