agentvibes 2.9.7 → 2.12.0

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