agentvibes 2.13.6 → 2.13.8

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