agentvibes 2.13.7 → 2.13.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (430) hide show
  1. package/.claude/commands/agent-vibes/bmad.md +16 -14
  2. package/.claude/hooks/play-tts-elevenlabs.sh +3 -1
  3. package/.claude/hooks/provider-manager.sh +112 -23
  4. package/.claude/personalities/rapper.md +1 -1
  5. package/README.md +7 -8
  6. package/RELEASE_NOTES.md +145 -255
  7. package/mcp-server/install-deps.js +7 -6
  8. package/mcp-server/server.py +4 -2
  9. package/package.json +1 -1
  10. package/src/commands/bmad-voices.js +3 -15
  11. package/src/commands/install-mcp.js +15 -9
  12. package/src/installer.js +19 -29
  13. package/test/unit/provider-manager.bats +13 -9
  14. package/.bmad/_cfg/agent-manifest.csv +0 -11
  15. package/.bmad/_cfg/agent-voice-map.csv +0 -11
  16. package/.bmad/_cfg/agents/bmm-analyst.customize.yaml +0 -42
  17. package/.bmad/_cfg/agents/bmm-architect.customize.yaml +0 -42
  18. package/.bmad/_cfg/agents/bmm-dev.customize.yaml +0 -42
  19. package/.bmad/_cfg/agents/bmm-frame-expert.customize.yaml +0 -42
  20. package/.bmad/_cfg/agents/bmm-pm.customize.yaml +0 -42
  21. package/.bmad/_cfg/agents/bmm-sm.customize.yaml +0 -42
  22. package/.bmad/_cfg/agents/bmm-tea.customize.yaml +0 -42
  23. package/.bmad/_cfg/agents/bmm-tech-writer.customize.yaml +0 -42
  24. package/.bmad/_cfg/agents/bmm-ux-designer.customize.yaml +0 -42
  25. package/.bmad/_cfg/agents/core-bmad-master.customize.yaml +0 -42
  26. package/.bmad/_cfg/files-manifest.csv +0 -243
  27. package/.bmad/_cfg/ides/claude-code.yaml +0 -6
  28. package/.bmad/_cfg/manifest.yaml +0 -9
  29. package/.bmad/_cfg/task-manifest.csv +0 -5
  30. package/.bmad/_cfg/tool-manifest.csv +0 -2
  31. package/.bmad/_cfg/workflow-manifest.csv +0 -38
  32. package/.bmad/bmm/README.md +0 -128
  33. package/.bmad/bmm/agents/analyst.md +0 -79
  34. package/.bmad/bmm/agents/analyst.md.backup-pre-tts +0 -75
  35. package/.bmad/bmm/agents/architect.md +0 -80
  36. package/.bmad/bmm/agents/dev.md +0 -70
  37. package/.bmad/bmm/agents/frame-expert.md +0 -72
  38. package/.bmad/bmm/agents/pm.md +0 -84
  39. package/.bmad/bmm/agents/sm.md +0 -93
  40. package/.bmad/bmm/agents/tea.md +0 -80
  41. package/.bmad/bmm/agents/tech-writer.md +0 -84
  42. package/.bmad/bmm/agents/ux-designer.md +0 -79
  43. package/.bmad/bmm/config.yaml +0 -17
  44. package/.bmad/bmm/docs/README.md +0 -236
  45. package/.bmad/bmm/docs/agents-guide.md +0 -1058
  46. package/.bmad/bmm/docs/brownfield-guide.md +0 -762
  47. package/.bmad/bmm/docs/enterprise-agentic-development.md +0 -686
  48. package/.bmad/bmm/docs/faq.md +0 -588
  49. package/.bmad/bmm/docs/glossary.md +0 -320
  50. package/.bmad/bmm/docs/party-mode.md +0 -224
  51. package/.bmad/bmm/docs/quick-spec-flow.md +0 -652
  52. package/.bmad/bmm/docs/quick-start.md +0 -376
  53. package/.bmad/bmm/docs/scale-adaptive-system.md +0 -612
  54. package/.bmad/bmm/docs/test-architecture.md +0 -396
  55. package/.bmad/bmm/docs/workflow-architecture-reference.md +0 -366
  56. package/.bmad/bmm/docs/workflow-document-project-reference.md +0 -489
  57. package/.bmad/bmm/docs/workflows-analysis.md +0 -370
  58. package/.bmad/bmm/docs/workflows-implementation.md +0 -286
  59. package/.bmad/bmm/docs/workflows-planning.md +0 -612
  60. package/.bmad/bmm/docs/workflows-solutioning.md +0 -554
  61. package/.bmad/bmm/teams/default-party.csv +0 -20
  62. package/.bmad/bmm/teams/team-fullstack.yaml +0 -13
  63. package/.bmad/bmm/testarch/knowledge/ci-burn-in.md +0 -675
  64. package/.bmad/bmm/testarch/knowledge/component-tdd.md +0 -486
  65. package/.bmad/bmm/testarch/knowledge/contract-testing.md +0 -957
  66. package/.bmad/bmm/testarch/knowledge/data-factories.md +0 -500
  67. package/.bmad/bmm/testarch/knowledge/email-auth.md +0 -721
  68. package/.bmad/bmm/testarch/knowledge/error-handling.md +0 -725
  69. package/.bmad/bmm/testarch/knowledge/feature-flags.md +0 -750
  70. package/.bmad/bmm/testarch/knowledge/fixture-architecture.md +0 -401
  71. package/.bmad/bmm/testarch/knowledge/network-first.md +0 -486
  72. package/.bmad/bmm/testarch/knowledge/nfr-criteria.md +0 -670
  73. package/.bmad/bmm/testarch/knowledge/playwright-config.md +0 -730
  74. package/.bmad/bmm/testarch/knowledge/probability-impact.md +0 -601
  75. package/.bmad/bmm/testarch/knowledge/risk-governance.md +0 -615
  76. package/.bmad/bmm/testarch/knowledge/selective-testing.md +0 -732
  77. package/.bmad/bmm/testarch/knowledge/selector-resilience.md +0 -527
  78. package/.bmad/bmm/testarch/knowledge/test-healing-patterns.md +0 -644
  79. package/.bmad/bmm/testarch/knowledge/test-levels-framework.md +0 -473
  80. package/.bmad/bmm/testarch/knowledge/test-priorities-matrix.md +0 -373
  81. package/.bmad/bmm/testarch/knowledge/test-quality.md +0 -664
  82. package/.bmad/bmm/testarch/knowledge/timing-debugging.md +0 -372
  83. package/.bmad/bmm/testarch/knowledge/visual-debugging.md +0 -524
  84. package/.bmad/bmm/testarch/tea-index.csv +0 -22
  85. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/instructions.md +0 -112
  86. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/project-context.md +0 -25
  87. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/workflow.yaml +0 -26
  88. package/.bmad/bmm/workflows/1-analysis/domain-research/instructions.md +0 -425
  89. package/.bmad/bmm/workflows/1-analysis/domain-research/template.md +0 -180
  90. package/.bmad/bmm/workflows/1-analysis/domain-research/workflow.yaml +0 -28
  91. package/.bmad/bmm/workflows/1-analysis/product-brief/checklist.md +0 -115
  92. package/.bmad/bmm/workflows/1-analysis/product-brief/instructions.md +0 -524
  93. package/.bmad/bmm/workflows/1-analysis/product-brief/template.md +0 -181
  94. package/.bmad/bmm/workflows/1-analysis/product-brief/workflow.yaml +0 -45
  95. package/.bmad/bmm/workflows/1-analysis/research/checklist-deep-prompt.md +0 -144
  96. package/.bmad/bmm/workflows/1-analysis/research/checklist-technical.md +0 -249
  97. package/.bmad/bmm/workflows/1-analysis/research/checklist.md +0 -299
  98. package/.bmad/bmm/workflows/1-analysis/research/claude-code/injections.yaml +0 -114
  99. package/.bmad/bmm/workflows/1-analysis/research/instructions-deep-prompt.md +0 -438
  100. package/.bmad/bmm/workflows/1-analysis/research/instructions-market.md +0 -675
  101. package/.bmad/bmm/workflows/1-analysis/research/instructions-router.md +0 -134
  102. package/.bmad/bmm/workflows/1-analysis/research/instructions-technical.md +0 -534
  103. package/.bmad/bmm/workflows/1-analysis/research/template-deep-prompt.md +0 -94
  104. package/.bmad/bmm/workflows/1-analysis/research/template-market.md +0 -347
  105. package/.bmad/bmm/workflows/1-analysis/research/template-technical.md +0 -245
  106. package/.bmad/bmm/workflows/1-analysis/research/workflow.yaml +0 -44
  107. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/epics-template.md +0 -80
  108. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/instructions.md +0 -616
  109. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/workflow.yaml +0 -53
  110. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/checklist.md +0 -310
  111. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/instructions.md +0 -1308
  112. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +0 -145
  113. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.yaml +0 -61
  114. package/.bmad/bmm/workflows/2-plan-workflows/prd/checklist.md +0 -346
  115. package/.bmad/bmm/workflows/2-plan-workflows/prd/domain-complexity.csv +0 -13
  116. package/.bmad/bmm/workflows/2-plan-workflows/prd/instructions.md +0 -703
  117. package/.bmad/bmm/workflows/2-plan-workflows/prd/prd-template.md +0 -204
  118. package/.bmad/bmm/workflows/2-plan-workflows/prd/project-types.csv +0 -11
  119. package/.bmad/bmm/workflows/2-plan-workflows/prd/workflow.yaml +0 -52
  120. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/checklist.md +0 -217
  121. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/epics-template.md +0 -74
  122. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions-generate-stories.md +0 -436
  123. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions.md +0 -980
  124. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/tech-spec-template.md +0 -181
  125. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/user-story-template.md +0 -90
  126. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/workflow.yaml +0 -58
  127. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-patterns.yaml +0 -321
  128. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-template.md +0 -103
  129. package/.bmad/bmm/workflows/3-solutioning/architecture/checklist.md +0 -240
  130. package/.bmad/bmm/workflows/3-solutioning/architecture/decision-catalog.yaml +0 -222
  131. package/.bmad/bmm/workflows/3-solutioning/architecture/instructions.md +0 -768
  132. package/.bmad/bmm/workflows/3-solutioning/architecture/pattern-categories.csv +0 -13
  133. package/.bmad/bmm/workflows/3-solutioning/architecture/workflow.yaml +0 -55
  134. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/checklist.md +0 -169
  135. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/instructions.md +0 -332
  136. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/template.md +0 -146
  137. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/workflow.yaml +0 -62
  138. package/.bmad/bmm/workflows/4-implementation/code-review/backlog_template.md +0 -12
  139. package/.bmad/bmm/workflows/4-implementation/code-review/checklist.md +0 -22
  140. package/.bmad/bmm/workflows/4-implementation/code-review/instructions.md +0 -398
  141. package/.bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +0 -60
  142. package/.bmad/bmm/workflows/4-implementation/correct-course/checklist.md +0 -279
  143. package/.bmad/bmm/workflows/4-implementation/correct-course/instructions.md +0 -206
  144. package/.bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +0 -56
  145. package/.bmad/bmm/workflows/4-implementation/create-story/checklist.md +0 -240
  146. package/.bmad/bmm/workflows/4-implementation/create-story/instructions.md +0 -256
  147. package/.bmad/bmm/workflows/4-implementation/create-story/template.md +0 -51
  148. package/.bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +0 -71
  149. package/.bmad/bmm/workflows/4-implementation/dev-story/checklist.md +0 -38
  150. package/.bmad/bmm/workflows/4-implementation/dev-story/instructions.md +0 -267
  151. package/.bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +0 -56
  152. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/checklist.md +0 -17
  153. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/instructions.md +0 -164
  154. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/template.md +0 -76
  155. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/workflow.yaml +0 -57
  156. package/.bmad/bmm/workflows/4-implementation/retrospective/instructions.md +0 -1443
  157. package/.bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +0 -56
  158. package/.bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +0 -33
  159. package/.bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +0 -234
  160. package/.bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +0 -55
  161. package/.bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +0 -49
  162. package/.bmad/bmm/workflows/4-implementation/story-context/checklist.md +0 -16
  163. package/.bmad/bmm/workflows/4-implementation/story-context/context-template.xml +0 -34
  164. package/.bmad/bmm/workflows/4-implementation/story-context/instructions.md +0 -209
  165. package/.bmad/bmm/workflows/4-implementation/story-context/workflow.yaml +0 -61
  166. package/.bmad/bmm/workflows/4-implementation/story-done/instructions.md +0 -111
  167. package/.bmad/bmm/workflows/4-implementation/story-done/workflow.yaml +0 -26
  168. package/.bmad/bmm/workflows/4-implementation/story-ready/instructions.md +0 -117
  169. package/.bmad/bmm/workflows/4-implementation/story-ready/workflow.yaml +0 -23
  170. package/.bmad/bmm/workflows/document-project/checklist.md +0 -245
  171. package/.bmad/bmm/workflows/document-project/documentation-requirements.csv +0 -12
  172. package/.bmad/bmm/workflows/document-project/instructions.md +0 -222
  173. package/.bmad/bmm/workflows/document-project/templates/deep-dive-template.md +0 -345
  174. package/.bmad/bmm/workflows/document-project/templates/index-template.md +0 -169
  175. package/.bmad/bmm/workflows/document-project/templates/project-overview-template.md +0 -103
  176. package/.bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +0 -160
  177. package/.bmad/bmm/workflows/document-project/templates/source-tree-template.md +0 -135
  178. package/.bmad/bmm/workflows/document-project/workflow.yaml +0 -29
  179. package/.bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +0 -298
  180. package/.bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +0 -31
  181. package/.bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +0 -1106
  182. package/.bmad/bmm/workflows/document-project/workflows/full-scan.yaml +0 -31
  183. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-helpers.md +0 -127
  184. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-library.json +0 -90
  185. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-templates.yaml +0 -127
  186. package/.bmad/bmm/workflows/frame-expert/_shared/validate-json-instructions.md +0 -79
  187. package/.bmad/bmm/workflows/frame-expert/create-dataflow/checklist.md +0 -39
  188. package/.bmad/bmm/workflows/frame-expert/create-dataflow/instructions.md +0 -131
  189. package/.bmad/bmm/workflows/frame-expert/create-dataflow/workflow.yaml +0 -23
  190. package/.bmad/bmm/workflows/frame-expert/create-diagram/checklist.md +0 -43
  191. package/.bmad/bmm/workflows/frame-expert/create-diagram/instructions.md +0 -142
  192. package/.bmad/bmm/workflows/frame-expert/create-diagram/workflow.yaml +0 -24
  193. package/.bmad/bmm/workflows/frame-expert/create-flowchart/checklist.md +0 -49
  194. package/.bmad/bmm/workflows/frame-expert/create-flowchart/instructions.md +0 -242
  195. package/.bmad/bmm/workflows/frame-expert/create-flowchart/workflow.yaml +0 -27
  196. package/.bmad/bmm/workflows/frame-expert/create-wireframe/checklist.md +0 -38
  197. package/.bmad/bmm/workflows/frame-expert/create-wireframe/instructions.md +0 -133
  198. package/.bmad/bmm/workflows/frame-expert/create-wireframe/workflow.yaml +0 -23
  199. package/.bmad/bmm/workflows/techdoc/documentation-standards.md +0 -262
  200. package/.bmad/bmm/workflows/testarch/atdd/atdd-checklist-template.md +0 -363
  201. package/.bmad/bmm/workflows/testarch/atdd/checklist.md +0 -373
  202. package/.bmad/bmm/workflows/testarch/atdd/instructions.md +0 -785
  203. package/.bmad/bmm/workflows/testarch/atdd/workflow.yaml +0 -45
  204. package/.bmad/bmm/workflows/testarch/automate/checklist.md +0 -580
  205. package/.bmad/bmm/workflows/testarch/automate/instructions.md +0 -1303
  206. package/.bmad/bmm/workflows/testarch/automate/workflow.yaml +0 -52
  207. package/.bmad/bmm/workflows/testarch/ci/checklist.md +0 -246
  208. package/.bmad/bmm/workflows/testarch/ci/github-actions-template.yaml +0 -165
  209. package/.bmad/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +0 -128
  210. package/.bmad/bmm/workflows/testarch/ci/instructions.md +0 -517
  211. package/.bmad/bmm/workflows/testarch/ci/workflow.yaml +0 -45
  212. package/.bmad/bmm/workflows/testarch/framework/checklist.md +0 -321
  213. package/.bmad/bmm/workflows/testarch/framework/instructions.md +0 -455
  214. package/.bmad/bmm/workflows/testarch/framework/workflow.yaml +0 -47
  215. package/.bmad/bmm/workflows/testarch/nfr-assess/checklist.md +0 -405
  216. package/.bmad/bmm/workflows/testarch/nfr-assess/instructions.md +0 -722
  217. package/.bmad/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +0 -443
  218. package/.bmad/bmm/workflows/testarch/nfr-assess/workflow.yaml +0 -47
  219. package/.bmad/bmm/workflows/testarch/test-design/checklist.md +0 -234
  220. package/.bmad/bmm/workflows/testarch/test-design/instructions.md +0 -782
  221. package/.bmad/bmm/workflows/testarch/test-design/test-design-template.md +0 -285
  222. package/.bmad/bmm/workflows/testarch/test-design/workflow.yaml +0 -48
  223. package/.bmad/bmm/workflows/testarch/test-review/checklist.md +0 -470
  224. package/.bmad/bmm/workflows/testarch/test-review/instructions.md +0 -608
  225. package/.bmad/bmm/workflows/testarch/test-review/test-review-template.md +0 -388
  226. package/.bmad/bmm/workflows/testarch/test-review/workflow.yaml +0 -46
  227. package/.bmad/bmm/workflows/testarch/trace/checklist.md +0 -654
  228. package/.bmad/bmm/workflows/testarch/trace/instructions.md +0 -1045
  229. package/.bmad/bmm/workflows/testarch/trace/trace-template.md +0 -673
  230. package/.bmad/bmm/workflows/testarch/trace/workflow.yaml +0 -55
  231. package/.bmad/bmm/workflows/workflow-status/init/instructions.md +0 -334
  232. package/.bmad/bmm/workflows/workflow-status/init/workflow.yaml +0 -28
  233. package/.bmad/bmm/workflows/workflow-status/instructions.md +0 -388
  234. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-brownfield.yaml +0 -138
  235. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-greenfield.yaml +0 -126
  236. package/.bmad/bmm/workflows/workflow-status/paths/game-design.yaml +0 -52
  237. package/.bmad/bmm/workflows/workflow-status/paths/method-brownfield.yaml +0 -122
  238. package/.bmad/bmm/workflows/workflow-status/paths/method-greenfield.yaml +0 -113
  239. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-brownfield.yaml +0 -58
  240. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-greenfield.yaml +0 -47
  241. package/.bmad/bmm/workflows/workflow-status/project-levels.yaml +0 -59
  242. package/.bmad/bmm/workflows/workflow-status/workflow-status-template.yaml +0 -24
  243. package/.bmad/bmm/workflows/workflow-status/workflow.yaml +0 -28
  244. package/.bmad/core/agents/bmad-master.md +0 -72
  245. package/.bmad/core/agents/bmad-web-orchestrator.agent.xml +0 -113
  246. package/.bmad/core/config.yaml +0 -11
  247. package/.bmad/core/tasks/adv-elicit-methods.csv +0 -39
  248. package/.bmad/core/tasks/advanced-elicitation-methods.csv +0 -21
  249. package/.bmad/core/tasks/advanced-elicitation.xml +0 -106
  250. package/.bmad/core/tasks/index-docs.xml +0 -65
  251. package/.bmad/core/tasks/validate-workflow.xml +0 -89
  252. package/.bmad/core/tasks/workflow.xml +0 -270
  253. package/.bmad/core/tools/shard-doc.xml +0 -109
  254. package/.bmad/core/workflows/brainstorming/README.md +0 -261
  255. package/.bmad/core/workflows/brainstorming/brain-methods.csv +0 -36
  256. package/.bmad/core/workflows/brainstorming/instructions.md +0 -315
  257. package/.bmad/core/workflows/brainstorming/template.md +0 -106
  258. package/.bmad/core/workflows/brainstorming/workflow.yaml +0 -38
  259. package/.bmad/core/workflows/party-mode/instructions.md +0 -203
  260. package/.bmad/core/workflows/party-mode/workflow.yaml +0 -28
  261. package/.bmad/docs/claude-code-instructions.md +0 -25
  262. package/.claude/commands/BMad/analyst.md +0 -88
  263. package/.claude/commands/BMad/architect.md +0 -89
  264. package/.claude/commands/BMad/bmad-master.md +0 -114
  265. package/.claude/commands/BMad/bmad-orchestrator.md +0 -151
  266. package/.claude/commands/BMad/dev.md +0 -85
  267. package/.claude/commands/BMad/pm.md +0 -88
  268. package/.claude/commands/BMad/po.md +0 -83
  269. package/.claude/commands/BMad/qa.md +0 -91
  270. package/.claude/commands/BMad/sm.md +0 -69
  271. package/.claude/commands/BMad/tasks/advanced-elicitation.md +0 -123
  272. package/.claude/commands/BMad/tasks/apply-qa-fixes.md +0 -154
  273. package/.claude/commands/BMad/tasks/brownfield-create-epic.md +0 -166
  274. package/.claude/commands/BMad/tasks/brownfield-create-story.md +0 -153
  275. package/.claude/commands/BMad/tasks/correct-course.md +0 -76
  276. package/.claude/commands/BMad/tasks/create-brownfield-story.md +0 -318
  277. package/.claude/commands/BMad/tasks/create-deep-research-prompt.md +0 -284
  278. package/.claude/commands/BMad/tasks/create-doc.md +0 -107
  279. package/.claude/commands/BMad/tasks/create-next-story.md +0 -118
  280. package/.claude/commands/BMad/tasks/document-project.md +0 -349
  281. package/.claude/commands/BMad/tasks/execute-checklist.md +0 -92
  282. package/.claude/commands/BMad/tasks/facilitate-brainstorming-session.md +0 -142
  283. package/.claude/commands/BMad/tasks/generate-ai-frontend-prompt.md +0 -57
  284. package/.claude/commands/BMad/tasks/index-docs.md +0 -179
  285. package/.claude/commands/BMad/tasks/kb-mode-interaction.md +0 -81
  286. package/.claude/commands/BMad/tasks/nfr-assess.md +0 -349
  287. package/.claude/commands/BMad/tasks/qa-gate.md +0 -167
  288. package/.claude/commands/BMad/tasks/review-story.md +0 -320
  289. package/.claude/commands/BMad/tasks/risk-profile.md +0 -359
  290. package/.claude/commands/BMad/tasks/shard-doc.md +0 -191
  291. package/.claude/commands/BMad/tasks/test-design.md +0 -180
  292. package/.claude/commands/BMad/tasks/trace-requirements.md +0 -270
  293. package/.claude/commands/BMad/tasks/validate-next-story.md +0 -140
  294. package/.claude/commands/BMad/ux-expert.md +0 -73
  295. package/.claude/commands/bmad/bmm/agents/analyst.md +0 -14
  296. package/.claude/commands/bmad/bmm/agents/architect.md +0 -14
  297. package/.claude/commands/bmad/bmm/agents/dev.md +0 -14
  298. package/.claude/commands/bmad/bmm/agents/frame-expert.md +0 -14
  299. package/.claude/commands/bmad/bmm/agents/pm.md +0 -14
  300. package/.claude/commands/bmad/bmm/agents/sm.md +0 -14
  301. package/.claude/commands/bmad/bmm/agents/tea.md +0 -14
  302. package/.claude/commands/bmad/bmm/agents/tech-writer.md +0 -14
  303. package/.claude/commands/bmad/bmm/agents/ux-designer.md +0 -14
  304. package/.claude/commands/bmad/bmm/workflows/architecture.md +0 -13
  305. package/.claude/commands/bmad/bmm/workflows/brainstorm-project.md +0 -13
  306. package/.claude/commands/bmad/bmm/workflows/code-review.md +0 -13
  307. package/.claude/commands/bmad/bmm/workflows/correct-course.md +0 -13
  308. package/.claude/commands/bmad/bmm/workflows/create-dataflow.md +0 -13
  309. package/.claude/commands/bmad/bmm/workflows/create-diagram.md +0 -13
  310. package/.claude/commands/bmad/bmm/workflows/create-epics-and-stories.md +0 -13
  311. package/.claude/commands/bmad/bmm/workflows/create-flowchart.md +0 -13
  312. package/.claude/commands/bmad/bmm/workflows/create-story.md +0 -13
  313. package/.claude/commands/bmad/bmm/workflows/create-ux-design.md +0 -13
  314. package/.claude/commands/bmad/bmm/workflows/create-wireframe.md +0 -13
  315. package/.claude/commands/bmad/bmm/workflows/dev-story.md +0 -13
  316. package/.claude/commands/bmad/bmm/workflows/document-project.md +0 -13
  317. package/.claude/commands/bmad/bmm/workflows/domain-research.md +0 -13
  318. package/.claude/commands/bmad/bmm/workflows/epic-tech-context.md +0 -13
  319. package/.claude/commands/bmad/bmm/workflows/implementation-readiness.md +0 -13
  320. package/.claude/commands/bmad/bmm/workflows/prd.md +0 -13
  321. package/.claude/commands/bmad/bmm/workflows/product-brief.md +0 -13
  322. package/.claude/commands/bmad/bmm/workflows/research.md +0 -13
  323. package/.claude/commands/bmad/bmm/workflows/retrospective.md +0 -13
  324. package/.claude/commands/bmad/bmm/workflows/sprint-planning.md +0 -13
  325. package/.claude/commands/bmad/bmm/workflows/story-context.md +0 -13
  326. package/.claude/commands/bmad/bmm/workflows/story-done.md +0 -13
  327. package/.claude/commands/bmad/bmm/workflows/story-ready.md +0 -13
  328. package/.claude/commands/bmad/bmm/workflows/tech-spec.md +0 -13
  329. package/.claude/commands/bmad/bmm/workflows/workflow-init.md +0 -13
  330. package/.claude/commands/bmad/bmm/workflows/workflow-status.md +0 -13
  331. package/.claude/commands/bmad/core/agents/bmad-master.md +0 -14
  332. package/.claude/commands/bmad/core/tasks/advanced-elicitation.md +0 -9
  333. package/.claude/commands/bmad/core/tasks/index-docs.md +0 -9
  334. package/.claude/commands/bmad/core/tools/shard-doc.md +0 -9
  335. package/.claude/commands/bmad/core/workflows/brainstorming.md +0 -13
  336. package/.claude/commands/bmad/core/workflows/party-mode.md +0 -13
  337. package/.claude/github-star-reminder.txt +0 -1
  338. package/.claude/hooks/bmad-party-manager.sh +0 -225
  339. package/.claude/hooks/stop.sh +0 -221
  340. package/.claude/piper-voices-dir.txt +0 -1
  341. package/.mcp.json +0 -88
  342. package/RELEASE_NOTES_v2.4.0_DRAFT.md +0 -116
  343. package/RELEASE_NOTES_v2.4.1_DRAFT.md +0 -61
  344. package/docs/2025-11-15_15-14-33.snagx +0 -0
  345. package/docs/Screenshot 2025-11-15 151325.png +0 -0
  346. package/docs/Screenshot 2025-11-15 151432.png +0 -0
  347. package/docs/macos-piper-issue.md +0 -172
  348. package/docs/stargazer-cms-prd.md +0 -1918
  349. package/docs/whatsapp-plugin-github-issue.md +0 -393
  350. package/docs/whatsapp-tts-plugin-feasibility.md +0 -418
  351. package/docs/whatsapp-tts-standalone-plugin.md +0 -628
  352. package/github-profile-draft.md +0 -57
  353. package/linkedin/vibe-coding-and-pulseaudio.md +0 -121
  354. package/mcp-server/agentvibes.db +0 -0
  355. package/scripts/audio-tunnel.config +0 -17
  356. package/v4-backup/.bmad-core/agent-teams/team-all.yaml +0 -15
  357. package/v4-backup/.bmad-core/agent-teams/team-fullstack.yaml +0 -19
  358. package/v4-backup/.bmad-core/agent-teams/team-ide-minimal.yaml +0 -11
  359. package/v4-backup/.bmad-core/agent-teams/team-no-ui.yaml +0 -14
  360. package/v4-backup/.bmad-core/agents/analyst.md +0 -84
  361. package/v4-backup/.bmad-core/agents/architect.md +0 -85
  362. package/v4-backup/.bmad-core/agents/bmad-master.md +0 -110
  363. package/v4-backup/.bmad-core/agents/bmad-orchestrator.md +0 -147
  364. package/v4-backup/.bmad-core/agents/dev.md +0 -81
  365. package/v4-backup/.bmad-core/agents/pm.md +0 -84
  366. package/v4-backup/.bmad-core/agents/po.md +0 -79
  367. package/v4-backup/.bmad-core/agents/qa.md +0 -87
  368. package/v4-backup/.bmad-core/agents/sm.md +0 -65
  369. package/v4-backup/.bmad-core/agents/ux-expert.md +0 -69
  370. package/v4-backup/.bmad-core/checklists/architect-checklist.md +0 -440
  371. package/v4-backup/.bmad-core/checklists/change-checklist.md +0 -184
  372. package/v4-backup/.bmad-core/checklists/pm-checklist.md +0 -372
  373. package/v4-backup/.bmad-core/checklists/po-master-checklist.md +0 -434
  374. package/v4-backup/.bmad-core/checklists/story-dod-checklist.md +0 -96
  375. package/v4-backup/.bmad-core/checklists/story-draft-checklist.md +0 -155
  376. package/v4-backup/.bmad-core/core-config.yaml +0 -22
  377. package/v4-backup/.bmad-core/data/bmad-kb.md +0 -809
  378. package/v4-backup/.bmad-core/data/brainstorming-techniques.md +0 -38
  379. package/v4-backup/.bmad-core/data/elicitation-methods.md +0 -156
  380. package/v4-backup/.bmad-core/data/technical-preferences.md +0 -5
  381. package/v4-backup/.bmad-core/data/test-levels-framework.md +0 -148
  382. package/v4-backup/.bmad-core/data/test-priorities-matrix.md +0 -174
  383. package/v4-backup/.bmad-core/enhanced-ide-development-workflow.md +0 -248
  384. package/v4-backup/.bmad-core/install-manifest.yaml +0 -230
  385. package/v4-backup/.bmad-core/tasks/advanced-elicitation.md +0 -119
  386. package/v4-backup/.bmad-core/tasks/apply-qa-fixes.md +0 -150
  387. package/v4-backup/.bmad-core/tasks/brownfield-create-epic.md +0 -162
  388. package/v4-backup/.bmad-core/tasks/brownfield-create-story.md +0 -149
  389. package/v4-backup/.bmad-core/tasks/correct-course.md +0 -72
  390. package/v4-backup/.bmad-core/tasks/create-brownfield-story.md +0 -314
  391. package/v4-backup/.bmad-core/tasks/create-deep-research-prompt.md +0 -280
  392. package/v4-backup/.bmad-core/tasks/create-doc.md +0 -103
  393. package/v4-backup/.bmad-core/tasks/create-next-story.md +0 -114
  394. package/v4-backup/.bmad-core/tasks/document-project.md +0 -345
  395. package/v4-backup/.bmad-core/tasks/execute-checklist.md +0 -88
  396. package/v4-backup/.bmad-core/tasks/facilitate-brainstorming-session.md +0 -138
  397. package/v4-backup/.bmad-core/tasks/generate-ai-frontend-prompt.md +0 -53
  398. package/v4-backup/.bmad-core/tasks/index-docs.md +0 -175
  399. package/v4-backup/.bmad-core/tasks/kb-mode-interaction.md +0 -77
  400. package/v4-backup/.bmad-core/tasks/nfr-assess.md +0 -345
  401. package/v4-backup/.bmad-core/tasks/qa-gate.md +0 -163
  402. package/v4-backup/.bmad-core/tasks/review-story.md +0 -316
  403. package/v4-backup/.bmad-core/tasks/risk-profile.md +0 -355
  404. package/v4-backup/.bmad-core/tasks/shard-doc.md +0 -187
  405. package/v4-backup/.bmad-core/tasks/test-design.md +0 -176
  406. package/v4-backup/.bmad-core/tasks/trace-requirements.md +0 -266
  407. package/v4-backup/.bmad-core/tasks/validate-next-story.md +0 -136
  408. package/v4-backup/.bmad-core/templates/architecture-tmpl.yaml +0 -651
  409. package/v4-backup/.bmad-core/templates/brainstorming-output-tmpl.yaml +0 -156
  410. package/v4-backup/.bmad-core/templates/brownfield-architecture-tmpl.yaml +0 -477
  411. package/v4-backup/.bmad-core/templates/brownfield-prd-tmpl.yaml +0 -281
  412. package/v4-backup/.bmad-core/templates/competitor-analysis-tmpl.yaml +0 -307
  413. package/v4-backup/.bmad-core/templates/front-end-architecture-tmpl.yaml +0 -219
  414. package/v4-backup/.bmad-core/templates/front-end-spec-tmpl.yaml +0 -350
  415. package/v4-backup/.bmad-core/templates/fullstack-architecture-tmpl.yaml +0 -824
  416. package/v4-backup/.bmad-core/templates/market-research-tmpl.yaml +0 -253
  417. package/v4-backup/.bmad-core/templates/prd-tmpl.yaml +0 -203
  418. package/v4-backup/.bmad-core/templates/project-brief-tmpl.yaml +0 -222
  419. package/v4-backup/.bmad-core/templates/qa-gate-tmpl.yaml +0 -103
  420. package/v4-backup/.bmad-core/templates/story-tmpl.yaml +0 -138
  421. package/v4-backup/.bmad-core/user-guide.md +0 -577
  422. package/v4-backup/.bmad-core/utils/bmad-doc-template.md +0 -327
  423. package/v4-backup/.bmad-core/utils/workflow-management.md +0 -71
  424. package/v4-backup/.bmad-core/workflows/brownfield-fullstack.yaml +0 -298
  425. package/v4-backup/.bmad-core/workflows/brownfield-service.yaml +0 -188
  426. package/v4-backup/.bmad-core/workflows/brownfield-ui.yaml +0 -198
  427. package/v4-backup/.bmad-core/workflows/greenfield-fullstack.yaml +0 -241
  428. package/v4-backup/.bmad-core/workflows/greenfield-service.yaml +0 -207
  429. package/v4-backup/.bmad-core/workflows/greenfield-ui.yaml +0 -236
  430. package/v4-backup/.bmad-core/working-in-the-brownfield.md +0 -606
@@ -1,486 +0,0 @@
1
- # Component Test-Driven Development Loop
2
-
3
- ## Principle
4
-
5
- Start every UI change with a failing component test (`cy.mount`, Playwright component test, or RTL `render`). Follow the Red-Green-Refactor cycle: write a failing test (red), make it pass with minimal code (green), then improve the implementation (refactor). Ship only after the cycle completes. Keep component tests under 100 lines, isolated with fresh providers per test, and validate accessibility alongside functionality.
6
-
7
- ## Rationale
8
-
9
- Component TDD provides immediate feedback during development. Failing tests (red) clarify requirements before writing code. Minimal implementations (green) prevent over-engineering. Refactoring with passing tests ensures changes don't break functionality. Isolated tests with fresh providers prevent state bleed in parallel runs. Accessibility assertions catch usability issues early. Visual debugging (Cypress runner, Storybook, Playwright trace viewer) accelerates diagnosis when tests fail.
10
-
11
- ## Pattern Examples
12
-
13
- ### Example 1: Red-Green-Refactor Loop
14
-
15
- **Context**: When building a new component, start with a failing test that describes the desired behavior. Implement just enough to pass, then refactor for quality.
16
-
17
- **Implementation**:
18
-
19
- ```typescript
20
- // Step 1: RED - Write failing test
21
- // Button.cy.tsx (Cypress Component Test)
22
- import { Button } from './Button';
23
-
24
- describe('Button Component', () => {
25
- it('should render with label', () => {
26
- cy.mount(<Button label="Click Me" />);
27
- cy.contains('Click Me').should('be.visible');
28
- });
29
-
30
- it('should call onClick when clicked', () => {
31
- const onClickSpy = cy.stub().as('onClick');
32
- cy.mount(<Button label="Submit" onClick={onClickSpy} />);
33
-
34
- cy.get('button').click();
35
- cy.get('@onClick').should('have.been.calledOnce');
36
- });
37
- });
38
-
39
- // Run test: FAILS - Button component doesn't exist yet
40
- // Error: "Cannot find module './Button'"
41
-
42
- // Step 2: GREEN - Minimal implementation
43
- // Button.tsx
44
- type ButtonProps = {
45
- label: string;
46
- onClick?: () => void;
47
- };
48
-
49
- export const Button = ({ label, onClick }: ButtonProps) => {
50
- return <button onClick={onClick}>{label}</button>;
51
- };
52
-
53
- // Run test: PASSES - Component renders and handles clicks
54
-
55
- // Step 3: REFACTOR - Improve implementation
56
- // Add disabled state, loading state, variants
57
- type ButtonProps = {
58
- label: string;
59
- onClick?: () => void;
60
- disabled?: boolean;
61
- loading?: boolean;
62
- variant?: 'primary' | 'secondary' | 'danger';
63
- };
64
-
65
- export const Button = ({
66
- label,
67
- onClick,
68
- disabled = false,
69
- loading = false,
70
- variant = 'primary'
71
- }: ButtonProps) => {
72
- return (
73
- <button
74
- onClick={onClick}
75
- disabled={disabled || loading}
76
- className={`btn btn-${variant}`}
77
- data-testid="button"
78
- >
79
- {loading ? <Spinner /> : label}
80
- </button>
81
- );
82
- };
83
-
84
- // Step 4: Expand tests for new features
85
- describe('Button Component', () => {
86
- it('should render with label', () => {
87
- cy.mount(<Button label="Click Me" />);
88
- cy.contains('Click Me').should('be.visible');
89
- });
90
-
91
- it('should call onClick when clicked', () => {
92
- const onClickSpy = cy.stub().as('onClick');
93
- cy.mount(<Button label="Submit" onClick={onClickSpy} />);
94
-
95
- cy.get('button').click();
96
- cy.get('@onClick').should('have.been.calledOnce');
97
- });
98
-
99
- it('should be disabled when disabled prop is true', () => {
100
- cy.mount(<Button label="Submit" disabled={true} />);
101
- cy.get('button').should('be.disabled');
102
- });
103
-
104
- it('should show spinner when loading', () => {
105
- cy.mount(<Button label="Submit" loading={true} />);
106
- cy.get('[data-testid="spinner"]').should('be.visible');
107
- cy.get('button').should('be.disabled');
108
- });
109
-
110
- it('should apply variant styles', () => {
111
- cy.mount(<Button label="Delete" variant="danger" />);
112
- cy.get('button').should('have.class', 'btn-danger');
113
- });
114
- });
115
-
116
- // Run tests: ALL PASS - Refactored component still works
117
-
118
- // Playwright Component Test equivalent
119
- import { test, expect } from '@playwright/experimental-ct-react';
120
- import { Button } from './Button';
121
-
122
- test.describe('Button Component', () => {
123
- test('should call onClick when clicked', async ({ mount }) => {
124
- let clicked = false;
125
- const component = await mount(
126
- <Button label="Submit" onClick={() => { clicked = true; }} />
127
- );
128
-
129
- await component.getByRole('button').click();
130
- expect(clicked).toBe(true);
131
- });
132
-
133
- test('should be disabled when loading', async ({ mount }) => {
134
- const component = await mount(<Button label="Submit" loading={true} />);
135
- await expect(component.getByRole('button')).toBeDisabled();
136
- await expect(component.getByTestId('spinner')).toBeVisible();
137
- });
138
- });
139
- ```
140
-
141
- **Key Points**:
142
-
143
- - Red: Write failing test first - clarifies requirements before coding
144
- - Green: Implement minimal code to pass - prevents over-engineering
145
- - Refactor: Improve code quality while keeping tests green
146
- - Expand: Add tests for new features after refactoring
147
- - Cycle repeats: Each new feature starts with a failing test
148
-
149
- ### Example 2: Provider Isolation Pattern
150
-
151
- **Context**: When testing components that depend on context providers (React Query, Auth, Router), wrap them with required providers in each test to prevent state bleed between tests.
152
-
153
- **Implementation**:
154
-
155
- ```typescript
156
- // test-utils/AllTheProviders.tsx
157
- import { FC, ReactNode } from 'react';
158
- import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
159
- import { BrowserRouter } from 'react-router-dom';
160
- import { AuthProvider } from '../contexts/AuthContext';
161
-
162
- type Props = {
163
- children: ReactNode;
164
- initialAuth?: { user: User | null; token: string | null };
165
- };
166
-
167
- export const AllTheProviders: FC<Props> = ({ children, initialAuth }) => {
168
- // Create NEW QueryClient per test (prevent state bleed)
169
- const queryClient = new QueryClient({
170
- defaultOptions: {
171
- queries: { retry: false },
172
- mutations: { retry: false }
173
- }
174
- });
175
-
176
- return (
177
- <QueryClientProvider client={queryClient}>
178
- <BrowserRouter>
179
- <AuthProvider initialAuth={initialAuth}>
180
- {children}
181
- </AuthProvider>
182
- </BrowserRouter>
183
- </QueryClientProvider>
184
- );
185
- };
186
-
187
- // Cypress custom mount command
188
- // cypress/support/component.tsx
189
- import { mount } from 'cypress/react18';
190
- import { AllTheProviders } from '../../test-utils/AllTheProviders';
191
-
192
- Cypress.Commands.add('wrappedMount', (component, options = {}) => {
193
- const { initialAuth, ...mountOptions } = options;
194
-
195
- return mount(
196
- <AllTheProviders initialAuth={initialAuth}>
197
- {component}
198
- </AllTheProviders>,
199
- mountOptions
200
- );
201
- });
202
-
203
- // Usage in tests
204
- // UserProfile.cy.tsx
205
- import { UserProfile } from './UserProfile';
206
-
207
- describe('UserProfile Component', () => {
208
- it('should display user when authenticated', () => {
209
- const user = { id: 1, name: 'John Doe', email: 'john@example.com' };
210
-
211
- cy.wrappedMount(<UserProfile />, {
212
- initialAuth: { user, token: 'fake-token' }
213
- });
214
-
215
- cy.contains('John Doe').should('be.visible');
216
- cy.contains('john@example.com').should('be.visible');
217
- });
218
-
219
- it('should show login prompt when not authenticated', () => {
220
- cy.wrappedMount(<UserProfile />, {
221
- initialAuth: { user: null, token: null }
222
- });
223
-
224
- cy.contains('Please log in').should('be.visible');
225
- });
226
- });
227
-
228
- // Playwright Component Test with providers
229
- import { test, expect } from '@playwright/experimental-ct-react';
230
- import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
231
- import { UserProfile } from './UserProfile';
232
- import { AuthProvider } from '../contexts/AuthContext';
233
-
234
- test.describe('UserProfile Component', () => {
235
- test('should display user when authenticated', async ({ mount }) => {
236
- const user = { id: 1, name: 'John Doe', email: 'john@example.com' };
237
- const queryClient = new QueryClient();
238
-
239
- const component = await mount(
240
- <QueryClientProvider client={queryClient}>
241
- <AuthProvider initialAuth={{ user, token: 'fake-token' }}>
242
- <UserProfile />
243
- </AuthProvider>
244
- </QueryClientProvider>
245
- );
246
-
247
- await expect(component.getByText('John Doe')).toBeVisible();
248
- await expect(component.getByText('john@example.com')).toBeVisible();
249
- });
250
- });
251
- ```
252
-
253
- **Key Points**:
254
-
255
- - Create NEW providers per test (QueryClient, Router, Auth)
256
- - Prevents state pollution between tests
257
- - `initialAuth` prop allows testing different auth states
258
- - Custom mount command (`wrappedMount`) reduces boilerplate
259
- - Providers wrap component, not the entire test suite
260
-
261
- ### Example 3: Accessibility Assertions
262
-
263
- **Context**: When testing components, validate accessibility alongside functionality using axe-core, ARIA roles, labels, and keyboard navigation.
264
-
265
- **Implementation**:
266
-
267
- ```typescript
268
- // Cypress with axe-core
269
- // cypress/support/component.tsx
270
- import 'cypress-axe';
271
-
272
- // Form.cy.tsx
273
- import { Form } from './Form';
274
-
275
- describe('Form Component Accessibility', () => {
276
- beforeEach(() => {
277
- cy.wrappedMount(<Form />);
278
- cy.injectAxe(); // Inject axe-core
279
- });
280
-
281
- it('should have no accessibility violations', () => {
282
- cy.checkA11y(); // Run axe scan
283
- });
284
-
285
- it('should have proper ARIA labels', () => {
286
- cy.get('input[name="email"]').should('have.attr', 'aria-label', 'Email address');
287
- cy.get('input[name="password"]').should('have.attr', 'aria-label', 'Password');
288
- cy.get('button[type="submit"]').should('have.attr', 'aria-label', 'Submit form');
289
- });
290
-
291
- it('should support keyboard navigation', () => {
292
- // Tab through form fields
293
- cy.get('input[name="email"]').focus().type('test@example.com');
294
- cy.realPress('Tab'); // cypress-real-events plugin
295
- cy.focused().should('have.attr', 'name', 'password');
296
-
297
- cy.focused().type('password123');
298
- cy.realPress('Tab');
299
- cy.focused().should('have.attr', 'type', 'submit');
300
-
301
- cy.realPress('Enter'); // Submit via keyboard
302
- cy.contains('Form submitted').should('be.visible');
303
- });
304
-
305
- it('should announce errors to screen readers', () => {
306
- cy.get('button[type="submit"]').click(); // Submit without data
307
-
308
- // Error has role="alert" and aria-live="polite"
309
- cy.get('[role="alert"]')
310
- .should('be.visible')
311
- .and('have.attr', 'aria-live', 'polite')
312
- .and('contain', 'Email is required');
313
- });
314
-
315
- it('should have sufficient color contrast', () => {
316
- cy.checkA11y(null, {
317
- rules: {
318
- 'color-contrast': { enabled: true }
319
- }
320
- });
321
- });
322
- });
323
-
324
- // Playwright with axe-playwright
325
- import { test, expect } from '@playwright/experimental-ct-react';
326
- import AxeBuilder from '@axe-core/playwright';
327
- import { Form } from './Form';
328
-
329
- test.describe('Form Component Accessibility', () => {
330
- test('should have no accessibility violations', async ({ mount, page }) => {
331
- await mount(<Form />);
332
-
333
- const accessibilityScanResults = await new AxeBuilder({ page })
334
- .analyze();
335
-
336
- expect(accessibilityScanResults.violations).toEqual([]);
337
- });
338
-
339
- test('should support keyboard navigation', async ({ mount, page }) => {
340
- const component = await mount(<Form />);
341
-
342
- await component.getByLabel('Email address').fill('test@example.com');
343
- await page.keyboard.press('Tab');
344
-
345
- await expect(component.getByLabel('Password')).toBeFocused();
346
-
347
- await component.getByLabel('Password').fill('password123');
348
- await page.keyboard.press('Tab');
349
-
350
- await expect(component.getByRole('button', { name: 'Submit form' })).toBeFocused();
351
-
352
- await page.keyboard.press('Enter');
353
- await expect(component.getByText('Form submitted')).toBeVisible();
354
- });
355
- });
356
- ```
357
-
358
- **Key Points**:
359
-
360
- - Use `cy.checkA11y()` (Cypress) or `AxeBuilder` (Playwright) for automated accessibility scanning
361
- - Validate ARIA roles, labels, and live regions
362
- - Test keyboard navigation (Tab, Enter, Escape)
363
- - Ensure errors are announced to screen readers (`role="alert"`, `aria-live`)
364
- - Check color contrast meets WCAG standards
365
-
366
- ### Example 4: Visual Regression Test
367
-
368
- **Context**: When testing components, capture screenshots to detect unintended visual changes. Use Playwright visual comparison or Cypress snapshot plugins.
369
-
370
- **Implementation**:
371
-
372
- ```typescript
373
- // Playwright visual regression
374
- import { test, expect } from '@playwright/experimental-ct-react';
375
- import { Button } from './Button';
376
-
377
- test.describe('Button Visual Regression', () => {
378
- test('should match primary button snapshot', async ({ mount }) => {
379
- const component = await mount(<Button label="Primary" variant="primary" />);
380
-
381
- // Capture and compare screenshot
382
- await expect(component).toHaveScreenshot('button-primary.png');
383
- });
384
-
385
- test('should match secondary button snapshot', async ({ mount }) => {
386
- const component = await mount(<Button label="Secondary" variant="secondary" />);
387
- await expect(component).toHaveScreenshot('button-secondary.png');
388
- });
389
-
390
- test('should match disabled button snapshot', async ({ mount }) => {
391
- const component = await mount(<Button label="Disabled" disabled={true} />);
392
- await expect(component).toHaveScreenshot('button-disabled.png');
393
- });
394
-
395
- test('should match loading button snapshot', async ({ mount }) => {
396
- const component = await mount(<Button label="Loading" loading={true} />);
397
- await expect(component).toHaveScreenshot('button-loading.png');
398
- });
399
- });
400
-
401
- // Cypress visual regression with percy or snapshot plugins
402
- import { Button } from './Button';
403
-
404
- describe('Button Visual Regression', () => {
405
- it('should match primary button snapshot', () => {
406
- cy.wrappedMount(<Button label="Primary" variant="primary" />);
407
-
408
- // Option 1: Percy (cloud-based visual testing)
409
- cy.percySnapshot('Button - Primary');
410
-
411
- // Option 2: cypress-plugin-snapshots (local snapshots)
412
- cy.get('button').toMatchImageSnapshot({
413
- name: 'button-primary',
414
- threshold: 0.01 // 1% threshold for pixel differences
415
- });
416
- });
417
-
418
- it('should match hover state', () => {
419
- cy.wrappedMount(<Button label="Hover Me" />);
420
- cy.get('button').realHover(); // cypress-real-events
421
- cy.percySnapshot('Button - Hover State');
422
- });
423
-
424
- it('should match focus state', () => {
425
- cy.wrappedMount(<Button label="Focus Me" />);
426
- cy.get('button').focus();
427
- cy.percySnapshot('Button - Focus State');
428
- });
429
- });
430
-
431
- // Playwright configuration for visual regression
432
- // playwright.config.ts
433
- export default defineConfig({
434
- expect: {
435
- toHaveScreenshot: {
436
- maxDiffPixels: 100, // Allow 100 pixels difference
437
- threshold: 0.2 // 20% threshold
438
- }
439
- },
440
- use: {
441
- screenshot: 'only-on-failure'
442
- }
443
- });
444
-
445
- // Update snapshots when intentional changes are made
446
- // npx playwright test --update-snapshots
447
- ```
448
-
449
- **Key Points**:
450
-
451
- - Playwright: Use `toHaveScreenshot()` for built-in visual comparison
452
- - Cypress: Use Percy (cloud) or snapshot plugins (local) for visual testing
453
- - Capture different states: default, hover, focus, disabled, loading
454
- - Set threshold for acceptable pixel differences (avoid false positives)
455
- - Update snapshots when visual changes are intentional
456
- - Visual tests catch unintended CSS/layout regressions
457
-
458
- ## Integration Points
459
-
460
- - **Used in workflows**: `*atdd` (component test generation), `*automate` (component test expansion), `*framework` (component testing setup)
461
- - **Related fragments**:
462
- - `test-quality.md` - Keep component tests <100 lines, isolated, focused
463
- - `fixture-architecture.md` - Provider wrapping patterns, custom mount commands
464
- - `data-factories.md` - Factory functions for component props
465
- - `test-levels-framework.md` - When to use component tests vs E2E tests
466
-
467
- ## TDD Workflow Summary
468
-
469
- **Red-Green-Refactor Cycle**:
470
-
471
- 1. **Red**: Write failing test describing desired behavior
472
- 2. **Green**: Implement minimal code to make test pass
473
- 3. **Refactor**: Improve code quality, tests stay green
474
- 4. **Repeat**: Each new feature starts with failing test
475
-
476
- **Component Test Checklist**:
477
-
478
- - [ ] Test renders with required props
479
- - [ ] Test user interactions (click, type, submit)
480
- - [ ] Test different states (loading, error, disabled)
481
- - [ ] Test accessibility (ARIA, keyboard navigation)
482
- - [ ] Test visual regression (snapshots)
483
- - [ ] Isolate with fresh providers (no state bleed)
484
- - [ ] Keep tests <100 lines (split by intent)
485
-
486
- _Source: CCTDD repository, Murat component testing talks, Playwright/Cypress component testing docs._