agentvibes 2.12.4 → 2.12.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (429) hide show
  1. package/.claude/hooks/bmad-voice-manager.sh +21 -5
  2. package/.claude/hooks/play-tts.sh +12 -0
  3. package/.claude/hooks/tts-queue.sh +34 -6
  4. package/README.md +17 -10
  5. package/RELEASE_NOTES.md +320 -697
  6. package/mcp-server/install-deps.js +19 -0
  7. package/mcp-server/server.py +58 -36
  8. package/package.json +1 -1
  9. package/scripts/fix-audio-tunnel.sh +22 -6
  10. package/src/commands/bmad-voices.js +14 -1
  11. package/src/installer.js +157 -72
  12. package/test/unit/play-tts.bats +1 -1
  13. package/.bmad/_cfg/agent-manifest.csv +0 -11
  14. package/.bmad/_cfg/agent-voice-map.csv +0 -11
  15. package/.bmad/_cfg/agents/bmm-analyst.customize.yaml +0 -42
  16. package/.bmad/_cfg/agents/bmm-architect.customize.yaml +0 -42
  17. package/.bmad/_cfg/agents/bmm-dev.customize.yaml +0 -42
  18. package/.bmad/_cfg/agents/bmm-frame-expert.customize.yaml +0 -42
  19. package/.bmad/_cfg/agents/bmm-pm.customize.yaml +0 -42
  20. package/.bmad/_cfg/agents/bmm-sm.customize.yaml +0 -42
  21. package/.bmad/_cfg/agents/bmm-tea.customize.yaml +0 -42
  22. package/.bmad/_cfg/agents/bmm-tech-writer.customize.yaml +0 -42
  23. package/.bmad/_cfg/agents/bmm-ux-designer.customize.yaml +0 -42
  24. package/.bmad/_cfg/agents/core-bmad-master.customize.yaml +0 -42
  25. package/.bmad/_cfg/files-manifest.csv +0 -243
  26. package/.bmad/_cfg/ides/claude-code.yaml +0 -6
  27. package/.bmad/_cfg/manifest.yaml +0 -9
  28. package/.bmad/_cfg/task-manifest.csv +0 -5
  29. package/.bmad/_cfg/tool-manifest.csv +0 -2
  30. package/.bmad/_cfg/workflow-manifest.csv +0 -38
  31. package/.bmad/bmm/README.md +0 -128
  32. package/.bmad/bmm/agents/analyst.md +0 -79
  33. package/.bmad/bmm/agents/analyst.md.backup-pre-tts +0 -75
  34. package/.bmad/bmm/agents/architect.md +0 -80
  35. package/.bmad/bmm/agents/dev.md +0 -70
  36. package/.bmad/bmm/agents/frame-expert.md +0 -72
  37. package/.bmad/bmm/agents/pm.md +0 -84
  38. package/.bmad/bmm/agents/sm.md +0 -93
  39. package/.bmad/bmm/agents/tea.md +0 -80
  40. package/.bmad/bmm/agents/tech-writer.md +0 -84
  41. package/.bmad/bmm/agents/ux-designer.md +0 -79
  42. package/.bmad/bmm/config.yaml +0 -17
  43. package/.bmad/bmm/docs/README.md +0 -236
  44. package/.bmad/bmm/docs/agents-guide.md +0 -1058
  45. package/.bmad/bmm/docs/brownfield-guide.md +0 -762
  46. package/.bmad/bmm/docs/enterprise-agentic-development.md +0 -686
  47. package/.bmad/bmm/docs/faq.md +0 -588
  48. package/.bmad/bmm/docs/glossary.md +0 -320
  49. package/.bmad/bmm/docs/party-mode.md +0 -224
  50. package/.bmad/bmm/docs/quick-spec-flow.md +0 -652
  51. package/.bmad/bmm/docs/quick-start.md +0 -376
  52. package/.bmad/bmm/docs/scale-adaptive-system.md +0 -612
  53. package/.bmad/bmm/docs/test-architecture.md +0 -396
  54. package/.bmad/bmm/docs/workflow-architecture-reference.md +0 -366
  55. package/.bmad/bmm/docs/workflow-document-project-reference.md +0 -489
  56. package/.bmad/bmm/docs/workflows-analysis.md +0 -370
  57. package/.bmad/bmm/docs/workflows-implementation.md +0 -286
  58. package/.bmad/bmm/docs/workflows-planning.md +0 -612
  59. package/.bmad/bmm/docs/workflows-solutioning.md +0 -554
  60. package/.bmad/bmm/teams/default-party.csv +0 -20
  61. package/.bmad/bmm/teams/team-fullstack.yaml +0 -13
  62. package/.bmad/bmm/testarch/knowledge/ci-burn-in.md +0 -675
  63. package/.bmad/bmm/testarch/knowledge/component-tdd.md +0 -486
  64. package/.bmad/bmm/testarch/knowledge/contract-testing.md +0 -957
  65. package/.bmad/bmm/testarch/knowledge/data-factories.md +0 -500
  66. package/.bmad/bmm/testarch/knowledge/email-auth.md +0 -721
  67. package/.bmad/bmm/testarch/knowledge/error-handling.md +0 -725
  68. package/.bmad/bmm/testarch/knowledge/feature-flags.md +0 -750
  69. package/.bmad/bmm/testarch/knowledge/fixture-architecture.md +0 -401
  70. package/.bmad/bmm/testarch/knowledge/network-first.md +0 -486
  71. package/.bmad/bmm/testarch/knowledge/nfr-criteria.md +0 -670
  72. package/.bmad/bmm/testarch/knowledge/playwright-config.md +0 -730
  73. package/.bmad/bmm/testarch/knowledge/probability-impact.md +0 -601
  74. package/.bmad/bmm/testarch/knowledge/risk-governance.md +0 -615
  75. package/.bmad/bmm/testarch/knowledge/selective-testing.md +0 -732
  76. package/.bmad/bmm/testarch/knowledge/selector-resilience.md +0 -527
  77. package/.bmad/bmm/testarch/knowledge/test-healing-patterns.md +0 -644
  78. package/.bmad/bmm/testarch/knowledge/test-levels-framework.md +0 -473
  79. package/.bmad/bmm/testarch/knowledge/test-priorities-matrix.md +0 -373
  80. package/.bmad/bmm/testarch/knowledge/test-quality.md +0 -664
  81. package/.bmad/bmm/testarch/knowledge/timing-debugging.md +0 -372
  82. package/.bmad/bmm/testarch/knowledge/visual-debugging.md +0 -524
  83. package/.bmad/bmm/testarch/tea-index.csv +0 -22
  84. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/instructions.md +0 -112
  85. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/project-context.md +0 -25
  86. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/workflow.yaml +0 -26
  87. package/.bmad/bmm/workflows/1-analysis/domain-research/instructions.md +0 -425
  88. package/.bmad/bmm/workflows/1-analysis/domain-research/template.md +0 -180
  89. package/.bmad/bmm/workflows/1-analysis/domain-research/workflow.yaml +0 -28
  90. package/.bmad/bmm/workflows/1-analysis/product-brief/checklist.md +0 -115
  91. package/.bmad/bmm/workflows/1-analysis/product-brief/instructions.md +0 -524
  92. package/.bmad/bmm/workflows/1-analysis/product-brief/template.md +0 -181
  93. package/.bmad/bmm/workflows/1-analysis/product-brief/workflow.yaml +0 -45
  94. package/.bmad/bmm/workflows/1-analysis/research/checklist-deep-prompt.md +0 -144
  95. package/.bmad/bmm/workflows/1-analysis/research/checklist-technical.md +0 -249
  96. package/.bmad/bmm/workflows/1-analysis/research/checklist.md +0 -299
  97. package/.bmad/bmm/workflows/1-analysis/research/claude-code/injections.yaml +0 -114
  98. package/.bmad/bmm/workflows/1-analysis/research/instructions-deep-prompt.md +0 -438
  99. package/.bmad/bmm/workflows/1-analysis/research/instructions-market.md +0 -675
  100. package/.bmad/bmm/workflows/1-analysis/research/instructions-router.md +0 -134
  101. package/.bmad/bmm/workflows/1-analysis/research/instructions-technical.md +0 -534
  102. package/.bmad/bmm/workflows/1-analysis/research/template-deep-prompt.md +0 -94
  103. package/.bmad/bmm/workflows/1-analysis/research/template-market.md +0 -347
  104. package/.bmad/bmm/workflows/1-analysis/research/template-technical.md +0 -245
  105. package/.bmad/bmm/workflows/1-analysis/research/workflow.yaml +0 -44
  106. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/epics-template.md +0 -80
  107. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/instructions.md +0 -616
  108. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/workflow.yaml +0 -53
  109. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/checklist.md +0 -310
  110. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/instructions.md +0 -1308
  111. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +0 -145
  112. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.yaml +0 -61
  113. package/.bmad/bmm/workflows/2-plan-workflows/prd/checklist.md +0 -346
  114. package/.bmad/bmm/workflows/2-plan-workflows/prd/domain-complexity.csv +0 -13
  115. package/.bmad/bmm/workflows/2-plan-workflows/prd/instructions.md +0 -703
  116. package/.bmad/bmm/workflows/2-plan-workflows/prd/prd-template.md +0 -204
  117. package/.bmad/bmm/workflows/2-plan-workflows/prd/project-types.csv +0 -11
  118. package/.bmad/bmm/workflows/2-plan-workflows/prd/workflow.yaml +0 -52
  119. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/checklist.md +0 -217
  120. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/epics-template.md +0 -74
  121. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions-generate-stories.md +0 -436
  122. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions.md +0 -980
  123. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/tech-spec-template.md +0 -181
  124. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/user-story-template.md +0 -90
  125. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/workflow.yaml +0 -58
  126. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-patterns.yaml +0 -321
  127. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-template.md +0 -103
  128. package/.bmad/bmm/workflows/3-solutioning/architecture/checklist.md +0 -240
  129. package/.bmad/bmm/workflows/3-solutioning/architecture/decision-catalog.yaml +0 -222
  130. package/.bmad/bmm/workflows/3-solutioning/architecture/instructions.md +0 -768
  131. package/.bmad/bmm/workflows/3-solutioning/architecture/pattern-categories.csv +0 -13
  132. package/.bmad/bmm/workflows/3-solutioning/architecture/workflow.yaml +0 -55
  133. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/checklist.md +0 -169
  134. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/instructions.md +0 -332
  135. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/template.md +0 -146
  136. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/workflow.yaml +0 -62
  137. package/.bmad/bmm/workflows/4-implementation/code-review/backlog_template.md +0 -12
  138. package/.bmad/bmm/workflows/4-implementation/code-review/checklist.md +0 -22
  139. package/.bmad/bmm/workflows/4-implementation/code-review/instructions.md +0 -398
  140. package/.bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +0 -60
  141. package/.bmad/bmm/workflows/4-implementation/correct-course/checklist.md +0 -279
  142. package/.bmad/bmm/workflows/4-implementation/correct-course/instructions.md +0 -206
  143. package/.bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +0 -56
  144. package/.bmad/bmm/workflows/4-implementation/create-story/checklist.md +0 -240
  145. package/.bmad/bmm/workflows/4-implementation/create-story/instructions.md +0 -256
  146. package/.bmad/bmm/workflows/4-implementation/create-story/template.md +0 -51
  147. package/.bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +0 -71
  148. package/.bmad/bmm/workflows/4-implementation/dev-story/checklist.md +0 -38
  149. package/.bmad/bmm/workflows/4-implementation/dev-story/instructions.md +0 -267
  150. package/.bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +0 -56
  151. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/checklist.md +0 -17
  152. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/instructions.md +0 -164
  153. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/template.md +0 -76
  154. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/workflow.yaml +0 -57
  155. package/.bmad/bmm/workflows/4-implementation/retrospective/instructions.md +0 -1443
  156. package/.bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +0 -56
  157. package/.bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +0 -33
  158. package/.bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +0 -234
  159. package/.bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +0 -55
  160. package/.bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +0 -49
  161. package/.bmad/bmm/workflows/4-implementation/story-context/checklist.md +0 -16
  162. package/.bmad/bmm/workflows/4-implementation/story-context/context-template.xml +0 -34
  163. package/.bmad/bmm/workflows/4-implementation/story-context/instructions.md +0 -209
  164. package/.bmad/bmm/workflows/4-implementation/story-context/workflow.yaml +0 -61
  165. package/.bmad/bmm/workflows/4-implementation/story-done/instructions.md +0 -111
  166. package/.bmad/bmm/workflows/4-implementation/story-done/workflow.yaml +0 -26
  167. package/.bmad/bmm/workflows/4-implementation/story-ready/instructions.md +0 -117
  168. package/.bmad/bmm/workflows/4-implementation/story-ready/workflow.yaml +0 -23
  169. package/.bmad/bmm/workflows/document-project/checklist.md +0 -245
  170. package/.bmad/bmm/workflows/document-project/documentation-requirements.csv +0 -12
  171. package/.bmad/bmm/workflows/document-project/instructions.md +0 -222
  172. package/.bmad/bmm/workflows/document-project/templates/deep-dive-template.md +0 -345
  173. package/.bmad/bmm/workflows/document-project/templates/index-template.md +0 -169
  174. package/.bmad/bmm/workflows/document-project/templates/project-overview-template.md +0 -103
  175. package/.bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +0 -160
  176. package/.bmad/bmm/workflows/document-project/templates/source-tree-template.md +0 -135
  177. package/.bmad/bmm/workflows/document-project/workflow.yaml +0 -29
  178. package/.bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +0 -298
  179. package/.bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +0 -31
  180. package/.bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +0 -1106
  181. package/.bmad/bmm/workflows/document-project/workflows/full-scan.yaml +0 -31
  182. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-helpers.md +0 -127
  183. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-library.json +0 -90
  184. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-templates.yaml +0 -127
  185. package/.bmad/bmm/workflows/frame-expert/_shared/validate-json-instructions.md +0 -79
  186. package/.bmad/bmm/workflows/frame-expert/create-dataflow/checklist.md +0 -39
  187. package/.bmad/bmm/workflows/frame-expert/create-dataflow/instructions.md +0 -131
  188. package/.bmad/bmm/workflows/frame-expert/create-dataflow/workflow.yaml +0 -23
  189. package/.bmad/bmm/workflows/frame-expert/create-diagram/checklist.md +0 -43
  190. package/.bmad/bmm/workflows/frame-expert/create-diagram/instructions.md +0 -142
  191. package/.bmad/bmm/workflows/frame-expert/create-diagram/workflow.yaml +0 -24
  192. package/.bmad/bmm/workflows/frame-expert/create-flowchart/checklist.md +0 -49
  193. package/.bmad/bmm/workflows/frame-expert/create-flowchart/instructions.md +0 -242
  194. package/.bmad/bmm/workflows/frame-expert/create-flowchart/workflow.yaml +0 -27
  195. package/.bmad/bmm/workflows/frame-expert/create-wireframe/checklist.md +0 -38
  196. package/.bmad/bmm/workflows/frame-expert/create-wireframe/instructions.md +0 -133
  197. package/.bmad/bmm/workflows/frame-expert/create-wireframe/workflow.yaml +0 -23
  198. package/.bmad/bmm/workflows/techdoc/documentation-standards.md +0 -262
  199. package/.bmad/bmm/workflows/testarch/atdd/atdd-checklist-template.md +0 -363
  200. package/.bmad/bmm/workflows/testarch/atdd/checklist.md +0 -373
  201. package/.bmad/bmm/workflows/testarch/atdd/instructions.md +0 -785
  202. package/.bmad/bmm/workflows/testarch/atdd/workflow.yaml +0 -45
  203. package/.bmad/bmm/workflows/testarch/automate/checklist.md +0 -580
  204. package/.bmad/bmm/workflows/testarch/automate/instructions.md +0 -1303
  205. package/.bmad/bmm/workflows/testarch/automate/workflow.yaml +0 -52
  206. package/.bmad/bmm/workflows/testarch/ci/checklist.md +0 -246
  207. package/.bmad/bmm/workflows/testarch/ci/github-actions-template.yaml +0 -165
  208. package/.bmad/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +0 -128
  209. package/.bmad/bmm/workflows/testarch/ci/instructions.md +0 -517
  210. package/.bmad/bmm/workflows/testarch/ci/workflow.yaml +0 -45
  211. package/.bmad/bmm/workflows/testarch/framework/checklist.md +0 -321
  212. package/.bmad/bmm/workflows/testarch/framework/instructions.md +0 -455
  213. package/.bmad/bmm/workflows/testarch/framework/workflow.yaml +0 -47
  214. package/.bmad/bmm/workflows/testarch/nfr-assess/checklist.md +0 -405
  215. package/.bmad/bmm/workflows/testarch/nfr-assess/instructions.md +0 -722
  216. package/.bmad/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +0 -443
  217. package/.bmad/bmm/workflows/testarch/nfr-assess/workflow.yaml +0 -47
  218. package/.bmad/bmm/workflows/testarch/test-design/checklist.md +0 -234
  219. package/.bmad/bmm/workflows/testarch/test-design/instructions.md +0 -782
  220. package/.bmad/bmm/workflows/testarch/test-design/test-design-template.md +0 -285
  221. package/.bmad/bmm/workflows/testarch/test-design/workflow.yaml +0 -48
  222. package/.bmad/bmm/workflows/testarch/test-review/checklist.md +0 -470
  223. package/.bmad/bmm/workflows/testarch/test-review/instructions.md +0 -608
  224. package/.bmad/bmm/workflows/testarch/test-review/test-review-template.md +0 -388
  225. package/.bmad/bmm/workflows/testarch/test-review/workflow.yaml +0 -46
  226. package/.bmad/bmm/workflows/testarch/trace/checklist.md +0 -654
  227. package/.bmad/bmm/workflows/testarch/trace/instructions.md +0 -1045
  228. package/.bmad/bmm/workflows/testarch/trace/trace-template.md +0 -673
  229. package/.bmad/bmm/workflows/testarch/trace/workflow.yaml +0 -55
  230. package/.bmad/bmm/workflows/workflow-status/init/instructions.md +0 -334
  231. package/.bmad/bmm/workflows/workflow-status/init/workflow.yaml +0 -28
  232. package/.bmad/bmm/workflows/workflow-status/instructions.md +0 -388
  233. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-brownfield.yaml +0 -138
  234. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-greenfield.yaml +0 -126
  235. package/.bmad/bmm/workflows/workflow-status/paths/game-design.yaml +0 -52
  236. package/.bmad/bmm/workflows/workflow-status/paths/method-brownfield.yaml +0 -122
  237. package/.bmad/bmm/workflows/workflow-status/paths/method-greenfield.yaml +0 -113
  238. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-brownfield.yaml +0 -58
  239. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-greenfield.yaml +0 -47
  240. package/.bmad/bmm/workflows/workflow-status/project-levels.yaml +0 -59
  241. package/.bmad/bmm/workflows/workflow-status/workflow-status-template.yaml +0 -24
  242. package/.bmad/bmm/workflows/workflow-status/workflow.yaml +0 -28
  243. package/.bmad/core/agents/bmad-master.md +0 -72
  244. package/.bmad/core/agents/bmad-web-orchestrator.agent.xml +0 -113
  245. package/.bmad/core/config.yaml +0 -11
  246. package/.bmad/core/tasks/adv-elicit-methods.csv +0 -39
  247. package/.bmad/core/tasks/advanced-elicitation-methods.csv +0 -21
  248. package/.bmad/core/tasks/advanced-elicitation.xml +0 -106
  249. package/.bmad/core/tasks/index-docs.xml +0 -65
  250. package/.bmad/core/tasks/validate-workflow.xml +0 -89
  251. package/.bmad/core/tasks/workflow.xml +0 -270
  252. package/.bmad/core/tools/shard-doc.xml +0 -109
  253. package/.bmad/core/workflows/brainstorming/README.md +0 -261
  254. package/.bmad/core/workflows/brainstorming/brain-methods.csv +0 -36
  255. package/.bmad/core/workflows/brainstorming/instructions.md +0 -315
  256. package/.bmad/core/workflows/brainstorming/template.md +0 -106
  257. package/.bmad/core/workflows/brainstorming/workflow.yaml +0 -38
  258. package/.bmad/core/workflows/party-mode/instructions.md +0 -203
  259. package/.bmad/core/workflows/party-mode/workflow.yaml +0 -28
  260. package/.bmad/docs/claude-code-instructions.md +0 -25
  261. package/.claude/commands/BMad/analyst.md +0 -88
  262. package/.claude/commands/BMad/architect.md +0 -89
  263. package/.claude/commands/BMad/bmad-master.md +0 -114
  264. package/.claude/commands/BMad/bmad-orchestrator.md +0 -151
  265. package/.claude/commands/BMad/dev.md +0 -85
  266. package/.claude/commands/BMad/pm.md +0 -88
  267. package/.claude/commands/BMad/po.md +0 -83
  268. package/.claude/commands/BMad/qa.md +0 -91
  269. package/.claude/commands/BMad/sm.md +0 -69
  270. package/.claude/commands/BMad/tasks/advanced-elicitation.md +0 -123
  271. package/.claude/commands/BMad/tasks/apply-qa-fixes.md +0 -154
  272. package/.claude/commands/BMad/tasks/brownfield-create-epic.md +0 -166
  273. package/.claude/commands/BMad/tasks/brownfield-create-story.md +0 -153
  274. package/.claude/commands/BMad/tasks/correct-course.md +0 -76
  275. package/.claude/commands/BMad/tasks/create-brownfield-story.md +0 -318
  276. package/.claude/commands/BMad/tasks/create-deep-research-prompt.md +0 -284
  277. package/.claude/commands/BMad/tasks/create-doc.md +0 -107
  278. package/.claude/commands/BMad/tasks/create-next-story.md +0 -118
  279. package/.claude/commands/BMad/tasks/document-project.md +0 -349
  280. package/.claude/commands/BMad/tasks/execute-checklist.md +0 -92
  281. package/.claude/commands/BMad/tasks/facilitate-brainstorming-session.md +0 -142
  282. package/.claude/commands/BMad/tasks/generate-ai-frontend-prompt.md +0 -57
  283. package/.claude/commands/BMad/tasks/index-docs.md +0 -179
  284. package/.claude/commands/BMad/tasks/kb-mode-interaction.md +0 -81
  285. package/.claude/commands/BMad/tasks/nfr-assess.md +0 -349
  286. package/.claude/commands/BMad/tasks/qa-gate.md +0 -167
  287. package/.claude/commands/BMad/tasks/review-story.md +0 -320
  288. package/.claude/commands/BMad/tasks/risk-profile.md +0 -359
  289. package/.claude/commands/BMad/tasks/shard-doc.md +0 -191
  290. package/.claude/commands/BMad/tasks/test-design.md +0 -180
  291. package/.claude/commands/BMad/tasks/trace-requirements.md +0 -270
  292. package/.claude/commands/BMad/tasks/validate-next-story.md +0 -140
  293. package/.claude/commands/BMad/ux-expert.md +0 -73
  294. package/.claude/commands/bmad/bmm/agents/analyst.md +0 -14
  295. package/.claude/commands/bmad/bmm/agents/architect.md +0 -14
  296. package/.claude/commands/bmad/bmm/agents/dev.md +0 -14
  297. package/.claude/commands/bmad/bmm/agents/frame-expert.md +0 -14
  298. package/.claude/commands/bmad/bmm/agents/pm.md +0 -14
  299. package/.claude/commands/bmad/bmm/agents/sm.md +0 -14
  300. package/.claude/commands/bmad/bmm/agents/tea.md +0 -14
  301. package/.claude/commands/bmad/bmm/agents/tech-writer.md +0 -14
  302. package/.claude/commands/bmad/bmm/agents/ux-designer.md +0 -14
  303. package/.claude/commands/bmad/bmm/workflows/architecture.md +0 -13
  304. package/.claude/commands/bmad/bmm/workflows/brainstorm-project.md +0 -13
  305. package/.claude/commands/bmad/bmm/workflows/code-review.md +0 -13
  306. package/.claude/commands/bmad/bmm/workflows/correct-course.md +0 -13
  307. package/.claude/commands/bmad/bmm/workflows/create-dataflow.md +0 -13
  308. package/.claude/commands/bmad/bmm/workflows/create-diagram.md +0 -13
  309. package/.claude/commands/bmad/bmm/workflows/create-epics-and-stories.md +0 -13
  310. package/.claude/commands/bmad/bmm/workflows/create-flowchart.md +0 -13
  311. package/.claude/commands/bmad/bmm/workflows/create-story.md +0 -13
  312. package/.claude/commands/bmad/bmm/workflows/create-ux-design.md +0 -13
  313. package/.claude/commands/bmad/bmm/workflows/create-wireframe.md +0 -13
  314. package/.claude/commands/bmad/bmm/workflows/dev-story.md +0 -13
  315. package/.claude/commands/bmad/bmm/workflows/document-project.md +0 -13
  316. package/.claude/commands/bmad/bmm/workflows/domain-research.md +0 -13
  317. package/.claude/commands/bmad/bmm/workflows/epic-tech-context.md +0 -13
  318. package/.claude/commands/bmad/bmm/workflows/implementation-readiness.md +0 -13
  319. package/.claude/commands/bmad/bmm/workflows/prd.md +0 -13
  320. package/.claude/commands/bmad/bmm/workflows/product-brief.md +0 -13
  321. package/.claude/commands/bmad/bmm/workflows/research.md +0 -13
  322. package/.claude/commands/bmad/bmm/workflows/retrospective.md +0 -13
  323. package/.claude/commands/bmad/bmm/workflows/sprint-planning.md +0 -13
  324. package/.claude/commands/bmad/bmm/workflows/story-context.md +0 -13
  325. package/.claude/commands/bmad/bmm/workflows/story-done.md +0 -13
  326. package/.claude/commands/bmad/bmm/workflows/story-ready.md +0 -13
  327. package/.claude/commands/bmad/bmm/workflows/tech-spec.md +0 -13
  328. package/.claude/commands/bmad/bmm/workflows/workflow-init.md +0 -13
  329. package/.claude/commands/bmad/bmm/workflows/workflow-status.md +0 -13
  330. package/.claude/commands/bmad/core/agents/bmad-master.md +0 -14
  331. package/.claude/commands/bmad/core/tasks/advanced-elicitation.md +0 -9
  332. package/.claude/commands/bmad/core/tasks/index-docs.md +0 -9
  333. package/.claude/commands/bmad/core/tools/shard-doc.md +0 -9
  334. package/.claude/commands/bmad/core/workflows/brainstorming.md +0 -13
  335. package/.claude/commands/bmad/core/workflows/party-mode.md +0 -13
  336. package/.claude/github-star-reminder.txt +0 -1
  337. package/.claude/hooks/bmad-party-manager.sh +0 -225
  338. package/.claude/hooks/stop.sh +0 -221
  339. package/.claude/piper-voices-dir.txt +0 -1
  340. package/.mcp.json +0 -88
  341. package/RELEASE_NOTES_v2.4.0_DRAFT.md +0 -116
  342. package/RELEASE_NOTES_v2.4.1_DRAFT.md +0 -61
  343. package/docs/2025-11-15_15-14-33.snagx +0 -0
  344. package/docs/Screenshot 2025-11-15 151325.png +0 -0
  345. package/docs/Screenshot 2025-11-15 151432.png +0 -0
  346. package/docs/macos-piper-issue.md +0 -172
  347. package/docs/stargazer-cms-prd.md +0 -1918
  348. package/docs/whatsapp-plugin-github-issue.md +0 -393
  349. package/docs/whatsapp-tts-plugin-feasibility.md +0 -418
  350. package/docs/whatsapp-tts-standalone-plugin.md +0 -628
  351. package/github-profile-draft.md +0 -57
  352. package/linkedin/vibe-coding-and-pulseaudio.md +0 -121
  353. package/mcp-server/agentvibes.db +0 -0
  354. package/scripts/audio-tunnel.config +0 -17
  355. package/v4-backup/.bmad-core/agent-teams/team-all.yaml +0 -15
  356. package/v4-backup/.bmad-core/agent-teams/team-fullstack.yaml +0 -19
  357. package/v4-backup/.bmad-core/agent-teams/team-ide-minimal.yaml +0 -11
  358. package/v4-backup/.bmad-core/agent-teams/team-no-ui.yaml +0 -14
  359. package/v4-backup/.bmad-core/agents/analyst.md +0 -84
  360. package/v4-backup/.bmad-core/agents/architect.md +0 -85
  361. package/v4-backup/.bmad-core/agents/bmad-master.md +0 -110
  362. package/v4-backup/.bmad-core/agents/bmad-orchestrator.md +0 -147
  363. package/v4-backup/.bmad-core/agents/dev.md +0 -81
  364. package/v4-backup/.bmad-core/agents/pm.md +0 -84
  365. package/v4-backup/.bmad-core/agents/po.md +0 -79
  366. package/v4-backup/.bmad-core/agents/qa.md +0 -87
  367. package/v4-backup/.bmad-core/agents/sm.md +0 -65
  368. package/v4-backup/.bmad-core/agents/ux-expert.md +0 -69
  369. package/v4-backup/.bmad-core/checklists/architect-checklist.md +0 -440
  370. package/v4-backup/.bmad-core/checklists/change-checklist.md +0 -184
  371. package/v4-backup/.bmad-core/checklists/pm-checklist.md +0 -372
  372. package/v4-backup/.bmad-core/checklists/po-master-checklist.md +0 -434
  373. package/v4-backup/.bmad-core/checklists/story-dod-checklist.md +0 -96
  374. package/v4-backup/.bmad-core/checklists/story-draft-checklist.md +0 -155
  375. package/v4-backup/.bmad-core/core-config.yaml +0 -22
  376. package/v4-backup/.bmad-core/data/bmad-kb.md +0 -809
  377. package/v4-backup/.bmad-core/data/brainstorming-techniques.md +0 -38
  378. package/v4-backup/.bmad-core/data/elicitation-methods.md +0 -156
  379. package/v4-backup/.bmad-core/data/technical-preferences.md +0 -5
  380. package/v4-backup/.bmad-core/data/test-levels-framework.md +0 -148
  381. package/v4-backup/.bmad-core/data/test-priorities-matrix.md +0 -174
  382. package/v4-backup/.bmad-core/enhanced-ide-development-workflow.md +0 -248
  383. package/v4-backup/.bmad-core/install-manifest.yaml +0 -230
  384. package/v4-backup/.bmad-core/tasks/advanced-elicitation.md +0 -119
  385. package/v4-backup/.bmad-core/tasks/apply-qa-fixes.md +0 -150
  386. package/v4-backup/.bmad-core/tasks/brownfield-create-epic.md +0 -162
  387. package/v4-backup/.bmad-core/tasks/brownfield-create-story.md +0 -149
  388. package/v4-backup/.bmad-core/tasks/correct-course.md +0 -72
  389. package/v4-backup/.bmad-core/tasks/create-brownfield-story.md +0 -314
  390. package/v4-backup/.bmad-core/tasks/create-deep-research-prompt.md +0 -280
  391. package/v4-backup/.bmad-core/tasks/create-doc.md +0 -103
  392. package/v4-backup/.bmad-core/tasks/create-next-story.md +0 -114
  393. package/v4-backup/.bmad-core/tasks/document-project.md +0 -345
  394. package/v4-backup/.bmad-core/tasks/execute-checklist.md +0 -88
  395. package/v4-backup/.bmad-core/tasks/facilitate-brainstorming-session.md +0 -138
  396. package/v4-backup/.bmad-core/tasks/generate-ai-frontend-prompt.md +0 -53
  397. package/v4-backup/.bmad-core/tasks/index-docs.md +0 -175
  398. package/v4-backup/.bmad-core/tasks/kb-mode-interaction.md +0 -77
  399. package/v4-backup/.bmad-core/tasks/nfr-assess.md +0 -345
  400. package/v4-backup/.bmad-core/tasks/qa-gate.md +0 -163
  401. package/v4-backup/.bmad-core/tasks/review-story.md +0 -316
  402. package/v4-backup/.bmad-core/tasks/risk-profile.md +0 -355
  403. package/v4-backup/.bmad-core/tasks/shard-doc.md +0 -187
  404. package/v4-backup/.bmad-core/tasks/test-design.md +0 -176
  405. package/v4-backup/.bmad-core/tasks/trace-requirements.md +0 -266
  406. package/v4-backup/.bmad-core/tasks/validate-next-story.md +0 -136
  407. package/v4-backup/.bmad-core/templates/architecture-tmpl.yaml +0 -651
  408. package/v4-backup/.bmad-core/templates/brainstorming-output-tmpl.yaml +0 -156
  409. package/v4-backup/.bmad-core/templates/brownfield-architecture-tmpl.yaml +0 -477
  410. package/v4-backup/.bmad-core/templates/brownfield-prd-tmpl.yaml +0 -281
  411. package/v4-backup/.bmad-core/templates/competitor-analysis-tmpl.yaml +0 -307
  412. package/v4-backup/.bmad-core/templates/front-end-architecture-tmpl.yaml +0 -219
  413. package/v4-backup/.bmad-core/templates/front-end-spec-tmpl.yaml +0 -350
  414. package/v4-backup/.bmad-core/templates/fullstack-architecture-tmpl.yaml +0 -824
  415. package/v4-backup/.bmad-core/templates/market-research-tmpl.yaml +0 -253
  416. package/v4-backup/.bmad-core/templates/prd-tmpl.yaml +0 -203
  417. package/v4-backup/.bmad-core/templates/project-brief-tmpl.yaml +0 -222
  418. package/v4-backup/.bmad-core/templates/qa-gate-tmpl.yaml +0 -103
  419. package/v4-backup/.bmad-core/templates/story-tmpl.yaml +0 -138
  420. package/v4-backup/.bmad-core/user-guide.md +0 -577
  421. package/v4-backup/.bmad-core/utils/bmad-doc-template.md +0 -327
  422. package/v4-backup/.bmad-core/utils/workflow-management.md +0 -71
  423. package/v4-backup/.bmad-core/workflows/brownfield-fullstack.yaml +0 -298
  424. package/v4-backup/.bmad-core/workflows/brownfield-service.yaml +0 -188
  425. package/v4-backup/.bmad-core/workflows/brownfield-ui.yaml +0 -198
  426. package/v4-backup/.bmad-core/workflows/greenfield-fullstack.yaml +0 -241
  427. package/v4-backup/.bmad-core/workflows/greenfield-service.yaml +0 -207
  428. package/v4-backup/.bmad-core/workflows/greenfield-ui.yaml +0 -236
  429. package/v4-backup/.bmad-core/working-in-the-brownfield.md +0 -606
@@ -1,527 +0,0 @@
1
- # Selector Resilience
2
-
3
- ## Principle
4
-
5
- Robust selectors follow a strict hierarchy: **data-testid > ARIA roles > text content > CSS/IDs** (last resort). Selectors must be resilient to UI changes (styling, layout, content updates) and remain human-readable for maintenance.
6
-
7
- ## Rationale
8
-
9
- **The Problem**: Brittle selectors (CSS classes, nth-child, complex XPath) break when UI styling changes, elements are reordered, or design updates occur. This causes test maintenance burden and false negatives.
10
-
11
- **The Solution**: Prioritize semantic selectors that reflect user intent (ARIA roles, accessible names, test IDs). Use dynamic filtering for lists instead of nth() indexes. Validate selectors during code review and refactor proactively.
12
-
13
- **Why This Matters**:
14
-
15
- - Prevents false test failures (UI refactoring doesn't break tests)
16
- - Improves accessibility (ARIA roles benefit both tests and screen readers)
17
- - Enhances readability (semantic selectors document user intent)
18
- - Reduces maintenance burden (robust selectors survive design changes)
19
-
20
- ## Pattern Examples
21
-
22
- ### Example 1: Selector Hierarchy (Priority Order with Examples)
23
-
24
- **Context**: Choose the most resilient selector for each element type
25
-
26
- **Implementation**:
27
-
28
- ```typescript
29
- // tests/selectors/hierarchy-examples.spec.ts
30
- import { test, expect } from '@playwright/test';
31
-
32
- test.describe('Selector Hierarchy Best Practices', () => {
33
- test('Level 1: data-testid (BEST - most resilient)', async ({ page }) => {
34
- await page.goto('/login');
35
-
36
- // ✅ Best: Dedicated test attribute (survives all UI changes)
37
- await page.getByTestId('email-input').fill('user@example.com');
38
- await page.getByTestId('password-input').fill('password123');
39
- await page.getByTestId('login-button').click();
40
-
41
- await expect(page.getByTestId('welcome-message')).toBeVisible();
42
-
43
- // Why it's best:
44
- // - Survives CSS refactoring (class name changes)
45
- // - Survives layout changes (element reordering)
46
- // - Survives content changes (button text updates)
47
- // - Explicit test contract (developer knows it's for testing)
48
- });
49
-
50
- test('Level 2: ARIA roles and accessible names (GOOD - future-proof)', async ({ page }) => {
51
- await page.goto('/login');
52
-
53
- // ✅ Good: Semantic HTML roles (benefits accessibility + tests)
54
- await page.getByRole('textbox', { name: 'Email' }).fill('user@example.com');
55
- await page.getByRole('textbox', { name: 'Password' }).fill('password123');
56
- await page.getByRole('button', { name: 'Sign In' }).click();
57
-
58
- await expect(page.getByRole('heading', { name: 'Welcome' })).toBeVisible();
59
-
60
- // Why it's good:
61
- // - Survives CSS refactoring
62
- // - Survives layout changes
63
- // - Enforces accessibility (screen reader compatible)
64
- // - Self-documenting (role + name = clear intent)
65
- });
66
-
67
- test('Level 3: Text content (ACCEPTABLE - user-centric)', async ({ page }) => {
68
- await page.goto('/dashboard');
69
-
70
- // ✅ Acceptable: Text content (matches user perception)
71
- await page.getByText('Create New Order').click();
72
- await expect(page.getByText('Order Details')).toBeVisible();
73
-
74
- // Why it's acceptable:
75
- // - User-centric (what user sees)
76
- // - Survives CSS/layout changes
77
- // - Breaks when copy changes (forces test update with content)
78
-
79
- // ⚠️ Use with caution for dynamic/localized content:
80
- // - Avoid for content with variables: "User 123" (use regex instead)
81
- // - Avoid for i18n content (use data-testid or ARIA)
82
- });
83
-
84
- test('Level 4: CSS classes/IDs (LAST RESORT - brittle)', async ({ page }) => {
85
- await page.goto('/login');
86
-
87
- // ❌ Last resort: CSS class (breaks with styling updates)
88
- // await page.locator('.btn-primary').click()
89
-
90
- // ❌ Last resort: ID (breaks if ID changes)
91
- // await page.locator('#login-form').fill(...)
92
-
93
- // ✅ Better: Use data-testid or ARIA instead
94
- await page.getByTestId('login-button').click();
95
-
96
- // Why CSS/ID is last resort:
97
- // - Breaks with CSS refactoring (class name changes)
98
- // - Breaks with HTML restructuring (ID changes)
99
- // - Not semantic (unclear what element does)
100
- // - Tight coupling between tests and styling
101
- });
102
- });
103
- ```
104
-
105
- **Key Points**:
106
-
107
- - Hierarchy: data-testid (best) > ARIA (good) > text (acceptable) > CSS/ID (last resort)
108
- - data-testid survives ALL UI changes (explicit test contract)
109
- - ARIA roles enforce accessibility (screen reader compatible)
110
- - Text content is user-centric (but breaks with copy changes)
111
- - CSS/ID are brittle (break with styling refactoring)
112
-
113
- ---
114
-
115
- ### Example 2: Dynamic Selector Patterns (Lists, Filters, Regex)
116
-
117
- **Context**: Handle dynamic content, lists, and variable data with resilient selectors
118
-
119
- **Implementation**:
120
-
121
- ```typescript
122
- // tests/selectors/dynamic-selectors.spec.ts
123
- import { test, expect } from '@playwright/test';
124
-
125
- test.describe('Dynamic Selector Patterns', () => {
126
- test('regex for variable content (user IDs, timestamps)', async ({ page }) => {
127
- await page.goto('/users');
128
-
129
- // ✅ Good: Regex pattern for dynamic user IDs
130
- await expect(page.getByText(/User \d+/)).toBeVisible();
131
-
132
- // ✅ Good: Regex for timestamps
133
- await expect(page.getByText(/Last login: \d{4}-\d{2}-\d{2}/)).toBeVisible();
134
-
135
- // ✅ Good: Regex for dynamic counts
136
- await expect(page.getByText(/\d+ items in cart/)).toBeVisible();
137
- });
138
-
139
- test('partial text matching (case-insensitive, substring)', async ({ page }) => {
140
- await page.goto('/products');
141
-
142
- // ✅ Good: Partial match (survives minor text changes)
143
- await page.getByText('Product', { exact: false }).first().click();
144
-
145
- // ✅ Good: Case-insensitive (survives capitalization changes)
146
- await expect(page.getByText(/sign in/i)).toBeVisible();
147
- });
148
-
149
- test('filter locators for lists (avoid brittle nth)', async ({ page }) => {
150
- await page.goto('/products');
151
-
152
- // ❌ Bad: Index-based (breaks when order changes)
153
- // await page.locator('.product-card').nth(2).click()
154
-
155
- // ✅ Good: Filter by content (resilient to reordering)
156
- await page.locator('[data-testid="product-card"]').filter({ hasText: 'Premium Plan' }).click();
157
-
158
- // ✅ Good: Filter by attribute
159
- await page
160
- .locator('[data-testid="product-card"]')
161
- .filter({ has: page.locator('[data-status="active"]') })
162
- .first()
163
- .click();
164
- });
165
-
166
- test('nth() only when absolutely necessary', async ({ page }) => {
167
- await page.goto('/dashboard');
168
-
169
- // ⚠️ Acceptable: nth(0) for first item (common pattern)
170
- const firstNotification = page.getByTestId('notification').nth(0);
171
- await expect(firstNotification).toContainText('Welcome');
172
-
173
- // ❌ Bad: nth(5) for arbitrary index (fragile)
174
- // await page.getByTestId('notification').nth(5).click()
175
-
176
- // ✅ Better: Use filter() with specific criteria
177
- await page.getByTestId('notification').filter({ hasText: 'Critical Alert' }).click();
178
- });
179
-
180
- test('combine multiple locators for specificity', async ({ page }) => {
181
- await page.goto('/checkout');
182
-
183
- // ✅ Good: Narrow scope with combined locators
184
- const shippingSection = page.getByTestId('shipping-section');
185
- await shippingSection.getByLabel('Address Line 1').fill('123 Main St');
186
- await shippingSection.getByLabel('City').fill('New York');
187
-
188
- // Scoping prevents ambiguity (multiple "City" fields on page)
189
- });
190
- });
191
- ```
192
-
193
- **Key Points**:
194
-
195
- - Regex patterns handle variable content (IDs, timestamps, counts)
196
- - Partial matching survives minor text changes (`exact: false`)
197
- - `filter()` is more resilient than `nth()` (content-based vs index-based)
198
- - `nth(0)` acceptable for "first item", avoid arbitrary indexes
199
- - Combine locators to narrow scope (prevent ambiguity)
200
-
201
- ---
202
-
203
- ### Example 3: Selector Anti-Patterns (What NOT to Do)
204
-
205
- **Context**: Common selector mistakes that cause brittle tests
206
-
207
- **Problem Examples**:
208
-
209
- ```typescript
210
- // tests/selectors/anti-patterns.spec.ts
211
- import { test, expect } from '@playwright/test';
212
-
213
- test.describe('Selector Anti-Patterns to Avoid', () => {
214
- test('❌ Anti-Pattern 1: CSS classes (brittle)', async ({ page }) => {
215
- await page.goto('/login');
216
-
217
- // ❌ Bad: CSS class (breaks with design system updates)
218
- // await page.locator('.btn-primary').click()
219
- // await page.locator('.form-input-lg').fill('test@example.com')
220
-
221
- // ✅ Good: Use data-testid or ARIA role
222
- await page.getByTestId('login-button').click();
223
- await page.getByRole('textbox', { name: 'Email' }).fill('test@example.com');
224
- });
225
-
226
- test('❌ Anti-Pattern 2: Index-based nth() (fragile)', async ({ page }) => {
227
- await page.goto('/products');
228
-
229
- // ❌ Bad: Index-based (breaks when product order changes)
230
- // await page.locator('.product-card').nth(3).click()
231
-
232
- // ✅ Good: Content-based filter
233
- await page.locator('[data-testid="product-card"]').filter({ hasText: 'Laptop' }).click();
234
- });
235
-
236
- test('❌ Anti-Pattern 3: Complex XPath (hard to maintain)', async ({ page }) => {
237
- await page.goto('/dashboard');
238
-
239
- // ❌ Bad: Complex XPath (unreadable, breaks with structure changes)
240
- // await page.locator('xpath=//div[@class="container"]//section[2]//button[contains(@class, "primary")]').click()
241
-
242
- // ✅ Good: Semantic selector
243
- await page.getByRole('button', { name: 'Create Order' }).click();
244
- });
245
-
246
- test('❌ Anti-Pattern 4: ID selectors (coupled to implementation)', async ({ page }) => {
247
- await page.goto('/settings');
248
-
249
- // ❌ Bad: HTML ID (breaks if ID changes for accessibility/SEO)
250
- // await page.locator('#user-settings-form').fill(...)
251
-
252
- // ✅ Good: data-testid or ARIA landmark
253
- await page.getByTestId('user-settings-form').getByLabel('Display Name').fill('John Doe');
254
- });
255
-
256
- test('✅ Refactoring: Bad → Good Selector', async ({ page }) => {
257
- await page.goto('/checkout');
258
-
259
- // Before (brittle):
260
- // await page.locator('.checkout-form > .payment-section > .btn-submit').click()
261
-
262
- // After (resilient):
263
- await page.getByTestId('checkout-form').getByRole('button', { name: 'Complete Payment' }).click();
264
-
265
- await expect(page.getByText('Payment successful')).toBeVisible();
266
- });
267
- });
268
- ```
269
-
270
- **Why These Fail**:
271
-
272
- - **CSS classes**: Change frequently with design updates (Tailwind, CSS modules)
273
- - **nth() indexes**: Fragile to element reordering (new features, A/B tests)
274
- - **Complex XPath**: Unreadable, breaks with HTML structure changes
275
- - **HTML IDs**: Not stable (accessibility improvements change IDs)
276
-
277
- **Better Approach**: Use selector hierarchy (testid > ARIA > text)
278
-
279
- ---
280
-
281
- ### Example 4: Selector Debugging Techniques (Inspector, DevTools, MCP)
282
-
283
- **Context**: Debug selector failures interactively to find better alternatives
284
-
285
- **Implementation**:
286
-
287
- ```typescript
288
- // tests/selectors/debugging-techniques.spec.ts
289
- import { test, expect } from '@playwright/test';
290
-
291
- test.describe('Selector Debugging Techniques', () => {
292
- test('use Playwright Inspector to test selectors', async ({ page }) => {
293
- await page.goto('/dashboard');
294
-
295
- // Pause test to open Inspector
296
- await page.pause();
297
-
298
- // In Inspector console, test selectors:
299
- // page.getByTestId('user-menu') ✅ Works
300
- // page.getByRole('button', { name: 'Profile' }) ✅ Works
301
- // page.locator('.btn-primary') ❌ Brittle
302
-
303
- // Use "Pick Locator" feature to generate selectors
304
- // Use "Record" mode to capture user interactions
305
-
306
- await page.getByTestId('user-menu').click();
307
- await expect(page.getByRole('menu')).toBeVisible();
308
- });
309
-
310
- test('use locator.all() to debug lists', async ({ page }) => {
311
- await page.goto('/products');
312
-
313
- // Debug: How many products are visible?
314
- const products = await page.getByTestId('product-card').all();
315
- console.log(`Found ${products.length} products`);
316
-
317
- // Debug: What text is in each product?
318
- for (const product of products) {
319
- const text = await product.textContent();
320
- console.log(`Product text: ${text}`);
321
- }
322
-
323
- // Use findings to build better selector
324
- await page.getByTestId('product-card').filter({ hasText: 'Laptop' }).click();
325
- });
326
-
327
- test('use DevTools console to test selectors', async ({ page }) => {
328
- await page.goto('/checkout');
329
-
330
- // Open DevTools (manually or via page.pause())
331
- // Test selectors in console:
332
- // document.querySelectorAll('[data-testid="payment-method"]')
333
- // document.querySelector('#credit-card-input')
334
-
335
- // Find robust selector through trial and error
336
- await page.getByTestId('payment-method').selectOption('credit-card');
337
- });
338
-
339
- test('MCP browser_generate_locator (if available)', async ({ page }) => {
340
- await page.goto('/products');
341
-
342
- // If Playwright MCP available, use browser_generate_locator:
343
- // 1. Click element in browser
344
- // 2. MCP generates optimal selector
345
- // 3. Copy into test
346
-
347
- // Example output from MCP:
348
- // page.getByRole('link', { name: 'Product A' })
349
-
350
- // Use generated selector
351
- await page.getByRole('link', { name: 'Product A' }).click();
352
- await expect(page).toHaveURL(/\/products\/\d+/);
353
- });
354
- });
355
- ```
356
-
357
- **Key Points**:
358
-
359
- - Playwright Inspector: Interactive selector testing with "Pick Locator" feature
360
- - `locator.all()`: Debug lists to understand structure and content
361
- - DevTools console: Test CSS selectors before adding to tests
362
- - MCP browser_generate_locator: Auto-generate optimal selectors (if MCP available)
363
- - Always validate selectors work before committing
364
-
365
- ---
366
-
367
- ### Example 2: Selector Refactoring Guide (Before/After Patterns)
368
-
369
- **Context**: Systematically improve brittle selectors to resilient alternatives
370
-
371
- **Implementation**:
372
-
373
- ```typescript
374
- // tests/selectors/refactoring-guide.spec.ts
375
- import { test, expect } from '@playwright/test';
376
-
377
- test.describe('Selector Refactoring Patterns', () => {
378
- test('refactor: CSS class → data-testid', async ({ page }) => {
379
- await page.goto('/products');
380
-
381
- // ❌ Before: CSS class (breaks with Tailwind updates)
382
- // await page.locator('.bg-blue-500.px-4.py-2.rounded').click()
383
-
384
- // ✅ After: data-testid
385
- await page.getByTestId('add-to-cart-button').click();
386
-
387
- // Implementation: Add data-testid to button component
388
- // <button className="bg-blue-500 px-4 py-2 rounded" data-testid="add-to-cart-button">
389
- });
390
-
391
- test('refactor: nth() index → filter()', async ({ page }) => {
392
- await page.goto('/users');
393
-
394
- // ❌ Before: Index-based (breaks when users reorder)
395
- // await page.locator('.user-row').nth(2).click()
396
-
397
- // ✅ After: Content-based filter
398
- await page.locator('[data-testid="user-row"]').filter({ hasText: 'john@example.com' }).click();
399
- });
400
-
401
- test('refactor: Complex XPath → ARIA role', async ({ page }) => {
402
- await page.goto('/checkout');
403
-
404
- // ❌ Before: Complex XPath (unreadable, brittle)
405
- // await page.locator('xpath=//div[@id="payment"]//form//button[contains(@class, "submit")]').click()
406
-
407
- // ✅ After: ARIA role
408
- await page.getByRole('button', { name: 'Complete Payment' }).click();
409
- });
410
-
411
- test('refactor: ID selector → data-testid', async ({ page }) => {
412
- await page.goto('/settings');
413
-
414
- // ❌ Before: HTML ID (changes with accessibility improvements)
415
- // await page.locator('#user-profile-section').getByLabel('Name').fill('John')
416
-
417
- // ✅ After: data-testid + semantic label
418
- await page.getByTestId('user-profile-section').getByLabel('Display Name').fill('John Doe');
419
- });
420
-
421
- test('refactor: Deeply nested CSS → scoped data-testid', async ({ page }) => {
422
- await page.goto('/dashboard');
423
-
424
- // ❌ Before: Deep nesting (breaks with structure changes)
425
- // await page.locator('.container .sidebar .menu .item:nth-child(3) a').click()
426
-
427
- // ✅ After: Scoped data-testid
428
- const sidebar = page.getByTestId('sidebar');
429
- await sidebar.getByRole('link', { name: 'Settings' }).click();
430
- });
431
- });
432
- ```
433
-
434
- **Key Points**:
435
-
436
- - CSS class → data-testid (survives design system updates)
437
- - nth() → filter() (content-based vs index-based)
438
- - Complex XPath → ARIA role (readable, semantic)
439
- - ID → data-testid (decouples from HTML structure)
440
- - Deep nesting → scoped locators (modular, maintainable)
441
-
442
- ---
443
-
444
- ### Example 3: Selector Best Practices Checklist
445
-
446
- ```typescript
447
- // tests/selectors/validation-checklist.spec.ts
448
- import { test, expect } from '@playwright/test';
449
-
450
- /**
451
- * Selector Validation Checklist
452
- *
453
- * Before committing test, verify selectors meet these criteria:
454
- */
455
- test.describe('Selector Best Practices Validation', () => {
456
- test('✅ 1. Prefer data-testid for interactive elements', async ({ page }) => {
457
- await page.goto('/login');
458
-
459
- // Interactive elements (buttons, inputs, links) should use data-testid
460
- await page.getByTestId('email-input').fill('test@example.com');
461
- await page.getByTestId('login-button').click();
462
- });
463
-
464
- test('✅ 2. Use ARIA roles for semantic elements', async ({ page }) => {
465
- await page.goto('/dashboard');
466
-
467
- // Semantic elements (headings, navigation, forms) use ARIA
468
- await expect(page.getByRole('heading', { name: 'Dashboard' })).toBeVisible();
469
- await page.getByRole('navigation').getByRole('link', { name: 'Settings' }).click();
470
- });
471
-
472
- test('✅ 3. Avoid CSS classes (except when testing styles)', async ({ page }) => {
473
- await page.goto('/products');
474
-
475
- // ❌ Never for interaction: page.locator('.btn-primary')
476
- // ✅ Only for visual regression: await expect(page.locator('.error-banner')).toHaveCSS('color', 'rgb(255, 0, 0)')
477
- });
478
-
479
- test('✅ 4. Use filter() instead of nth() for lists', async ({ page }) => {
480
- await page.goto('/orders');
481
-
482
- // List selection should be content-based
483
- await page.getByTestId('order-row').filter({ hasText: 'Order #12345' }).click();
484
- });
485
-
486
- test('✅ 5. Selectors are human-readable', async ({ page }) => {
487
- await page.goto('/checkout');
488
-
489
- // ✅ Good: Clear intent
490
- await page.getByTestId('shipping-address-form').getByLabel('Street Address').fill('123 Main St');
491
-
492
- // ❌ Bad: Cryptic
493
- // await page.locator('div > div:nth-child(2) > input[type="text"]').fill('123 Main St')
494
- });
495
- });
496
- ```
497
-
498
- **Validation Rules**:
499
-
500
- 1. **Interactive elements** (buttons, inputs) → data-testid
501
- 2. **Semantic elements** (headings, nav, forms) → ARIA roles
502
- 3. **CSS classes** → Avoid (except visual regression tests)
503
- 4. **Lists** → filter() over nth() (content-based selection)
504
- 5. **Readability** → Selectors document user intent (clear, semantic)
505
-
506
- ---
507
-
508
- ## Selector Resilience Checklist
509
-
510
- Before deploying selectors:
511
-
512
- - [ ] **Hierarchy followed**: data-testid (1st choice) > ARIA (2nd) > text (3rd) > CSS/ID (last resort)
513
- - [ ] **Interactive elements use data-testid**: Buttons, inputs, links have dedicated test attributes
514
- - [ ] **Semantic elements use ARIA**: Headings, navigation, forms use roles and accessible names
515
- - [ ] **No brittle patterns**: No CSS classes (except visual tests), no arbitrary nth(), no complex XPath
516
- - [ ] **Dynamic content handled**: Regex for IDs/timestamps, filter() for lists, partial matching for text
517
- - [ ] **Selectors are scoped**: Use container locators to narrow scope (prevent ambiguity)
518
- - [ ] **Human-readable**: Selectors document user intent (clear, semantic, maintainable)
519
- - [ ] **Validated in Inspector**: Test selectors interactively before committing (page.pause())
520
-
521
- ## Integration Points
522
-
523
- - **Used in workflows**: `*atdd` (generate tests with robust selectors), `*automate` (healing selector failures), `*test-review` (validate selector quality)
524
- - **Related fragments**: `test-healing-patterns.md` (selector failure diagnosis), `fixture-architecture.md` (page object alternatives), `test-quality.md` (maintainability standards)
525
- - **Tools**: Playwright Inspector (Pick Locator), DevTools console, Playwright MCP browser_generate_locator (optional)
526
-
527
- _Source: Playwright selector best practices, accessibility guidelines (ARIA), production test maintenance patterns_