agentvibes 2.10.0 → 2.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (437) hide show
  1. package/.claude/commands/agent-vibes/agent-vibes.md +1 -1
  2. package/.claude/commands/agent-vibes/bmad.md +3 -3
  3. package/.claude/commands/agent-vibes/set-pretext.md +2 -2
  4. package/.claude/commands/agent-vibes-bmad-voices.md +5 -5
  5. package/.claude/hooks/bmad-speak.sh +1 -1
  6. package/.claude/hooks/migrate-to-agentvibes.sh +161 -0
  7. package/.claude/hooks/play-tts-elevenlabs.sh +1 -1
  8. package/.claude/output-styles/agent-vibes.md +3 -3
  9. package/README.md +9 -6
  10. package/RELEASE_NOTES.md +341 -0
  11. package/docs/architecture/provider-system.md +3 -3
  12. package/docs/bmad-v6-support.md +1 -1
  13. package/docs/technical-deep-dive.md +1 -1
  14. package/docs/voice-mapping-format.md +1 -1
  15. package/package.json +1 -1
  16. package/src/installer.js +88 -16
  17. package/test-migration.sh +539 -0
  18. package/.agentvibes/bmad/bmad-voices-enabled.flag +0 -0
  19. package/.agentvibes/bmad/bmad-voices.md +0 -68
  20. package/.bmad/_cfg/agent-manifest.csv +0 -11
  21. package/.bmad/_cfg/agent-voice-map.csv +0 -11
  22. package/.bmad/_cfg/agents/bmm-analyst.customize.yaml +0 -42
  23. package/.bmad/_cfg/agents/bmm-architect.customize.yaml +0 -42
  24. package/.bmad/_cfg/agents/bmm-dev.customize.yaml +0 -42
  25. package/.bmad/_cfg/agents/bmm-frame-expert.customize.yaml +0 -42
  26. package/.bmad/_cfg/agents/bmm-pm.customize.yaml +0 -42
  27. package/.bmad/_cfg/agents/bmm-sm.customize.yaml +0 -42
  28. package/.bmad/_cfg/agents/bmm-tea.customize.yaml +0 -42
  29. package/.bmad/_cfg/agents/bmm-tech-writer.customize.yaml +0 -42
  30. package/.bmad/_cfg/agents/bmm-ux-designer.customize.yaml +0 -42
  31. package/.bmad/_cfg/agents/core-bmad-master.customize.yaml +0 -42
  32. package/.bmad/_cfg/files-manifest.csv +0 -243
  33. package/.bmad/_cfg/ides/claude-code.yaml +0 -6
  34. package/.bmad/_cfg/manifest.yaml +0 -9
  35. package/.bmad/_cfg/task-manifest.csv +0 -5
  36. package/.bmad/_cfg/tool-manifest.csv +0 -2
  37. package/.bmad/_cfg/workflow-manifest.csv +0 -38
  38. package/.bmad/bmm/README.md +0 -128
  39. package/.bmad/bmm/agents/analyst.md +0 -79
  40. package/.bmad/bmm/agents/analyst.md.backup-pre-tts +0 -75
  41. package/.bmad/bmm/agents/architect.md +0 -80
  42. package/.bmad/bmm/agents/dev.md +0 -70
  43. package/.bmad/bmm/agents/frame-expert.md +0 -72
  44. package/.bmad/bmm/agents/pm.md +0 -84
  45. package/.bmad/bmm/agents/sm.md +0 -93
  46. package/.bmad/bmm/agents/tea.md +0 -80
  47. package/.bmad/bmm/agents/tech-writer.md +0 -84
  48. package/.bmad/bmm/agents/ux-designer.md +0 -79
  49. package/.bmad/bmm/config.yaml +0 -17
  50. package/.bmad/bmm/docs/README.md +0 -236
  51. package/.bmad/bmm/docs/agents-guide.md +0 -1058
  52. package/.bmad/bmm/docs/brownfield-guide.md +0 -762
  53. package/.bmad/bmm/docs/enterprise-agentic-development.md +0 -686
  54. package/.bmad/bmm/docs/faq.md +0 -588
  55. package/.bmad/bmm/docs/glossary.md +0 -320
  56. package/.bmad/bmm/docs/party-mode.md +0 -224
  57. package/.bmad/bmm/docs/quick-spec-flow.md +0 -652
  58. package/.bmad/bmm/docs/quick-start.md +0 -376
  59. package/.bmad/bmm/docs/scale-adaptive-system.md +0 -612
  60. package/.bmad/bmm/docs/test-architecture.md +0 -396
  61. package/.bmad/bmm/docs/workflow-architecture-reference.md +0 -366
  62. package/.bmad/bmm/docs/workflow-document-project-reference.md +0 -489
  63. package/.bmad/bmm/docs/workflows-analysis.md +0 -370
  64. package/.bmad/bmm/docs/workflows-implementation.md +0 -286
  65. package/.bmad/bmm/docs/workflows-planning.md +0 -612
  66. package/.bmad/bmm/docs/workflows-solutioning.md +0 -554
  67. package/.bmad/bmm/teams/default-party.csv +0 -20
  68. package/.bmad/bmm/teams/team-fullstack.yaml +0 -13
  69. package/.bmad/bmm/testarch/knowledge/ci-burn-in.md +0 -675
  70. package/.bmad/bmm/testarch/knowledge/component-tdd.md +0 -486
  71. package/.bmad/bmm/testarch/knowledge/contract-testing.md +0 -957
  72. package/.bmad/bmm/testarch/knowledge/data-factories.md +0 -500
  73. package/.bmad/bmm/testarch/knowledge/email-auth.md +0 -721
  74. package/.bmad/bmm/testarch/knowledge/error-handling.md +0 -725
  75. package/.bmad/bmm/testarch/knowledge/feature-flags.md +0 -750
  76. package/.bmad/bmm/testarch/knowledge/fixture-architecture.md +0 -401
  77. package/.bmad/bmm/testarch/knowledge/network-first.md +0 -486
  78. package/.bmad/bmm/testarch/knowledge/nfr-criteria.md +0 -670
  79. package/.bmad/bmm/testarch/knowledge/playwright-config.md +0 -730
  80. package/.bmad/bmm/testarch/knowledge/probability-impact.md +0 -601
  81. package/.bmad/bmm/testarch/knowledge/risk-governance.md +0 -615
  82. package/.bmad/bmm/testarch/knowledge/selective-testing.md +0 -732
  83. package/.bmad/bmm/testarch/knowledge/selector-resilience.md +0 -527
  84. package/.bmad/bmm/testarch/knowledge/test-healing-patterns.md +0 -644
  85. package/.bmad/bmm/testarch/knowledge/test-levels-framework.md +0 -473
  86. package/.bmad/bmm/testarch/knowledge/test-priorities-matrix.md +0 -373
  87. package/.bmad/bmm/testarch/knowledge/test-quality.md +0 -664
  88. package/.bmad/bmm/testarch/knowledge/timing-debugging.md +0 -372
  89. package/.bmad/bmm/testarch/knowledge/visual-debugging.md +0 -524
  90. package/.bmad/bmm/testarch/tea-index.csv +0 -22
  91. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/instructions.md +0 -112
  92. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/project-context.md +0 -25
  93. package/.bmad/bmm/workflows/1-analysis/brainstorm-project/workflow.yaml +0 -26
  94. package/.bmad/bmm/workflows/1-analysis/domain-research/instructions.md +0 -425
  95. package/.bmad/bmm/workflows/1-analysis/domain-research/template.md +0 -180
  96. package/.bmad/bmm/workflows/1-analysis/domain-research/workflow.yaml +0 -28
  97. package/.bmad/bmm/workflows/1-analysis/product-brief/checklist.md +0 -115
  98. package/.bmad/bmm/workflows/1-analysis/product-brief/instructions.md +0 -524
  99. package/.bmad/bmm/workflows/1-analysis/product-brief/template.md +0 -181
  100. package/.bmad/bmm/workflows/1-analysis/product-brief/workflow.yaml +0 -45
  101. package/.bmad/bmm/workflows/1-analysis/research/checklist-deep-prompt.md +0 -144
  102. package/.bmad/bmm/workflows/1-analysis/research/checklist-technical.md +0 -249
  103. package/.bmad/bmm/workflows/1-analysis/research/checklist.md +0 -299
  104. package/.bmad/bmm/workflows/1-analysis/research/claude-code/injections.yaml +0 -114
  105. package/.bmad/bmm/workflows/1-analysis/research/instructions-deep-prompt.md +0 -438
  106. package/.bmad/bmm/workflows/1-analysis/research/instructions-market.md +0 -675
  107. package/.bmad/bmm/workflows/1-analysis/research/instructions-router.md +0 -134
  108. package/.bmad/bmm/workflows/1-analysis/research/instructions-technical.md +0 -534
  109. package/.bmad/bmm/workflows/1-analysis/research/template-deep-prompt.md +0 -94
  110. package/.bmad/bmm/workflows/1-analysis/research/template-market.md +0 -347
  111. package/.bmad/bmm/workflows/1-analysis/research/template-technical.md +0 -245
  112. package/.bmad/bmm/workflows/1-analysis/research/workflow.yaml +0 -44
  113. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/epics-template.md +0 -80
  114. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/instructions.md +0 -616
  115. package/.bmad/bmm/workflows/2-plan-workflows/create-epics-and-stories/workflow.yaml +0 -53
  116. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/checklist.md +0 -310
  117. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/instructions.md +0 -1308
  118. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +0 -145
  119. package/.bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.yaml +0 -61
  120. package/.bmad/bmm/workflows/2-plan-workflows/prd/checklist.md +0 -346
  121. package/.bmad/bmm/workflows/2-plan-workflows/prd/domain-complexity.csv +0 -13
  122. package/.bmad/bmm/workflows/2-plan-workflows/prd/instructions.md +0 -703
  123. package/.bmad/bmm/workflows/2-plan-workflows/prd/prd-template.md +0 -204
  124. package/.bmad/bmm/workflows/2-plan-workflows/prd/project-types.csv +0 -11
  125. package/.bmad/bmm/workflows/2-plan-workflows/prd/workflow.yaml +0 -52
  126. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/checklist.md +0 -217
  127. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/epics-template.md +0 -74
  128. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions-generate-stories.md +0 -436
  129. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/instructions.md +0 -980
  130. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/tech-spec-template.md +0 -181
  131. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/user-story-template.md +0 -90
  132. package/.bmad/bmm/workflows/2-plan-workflows/tech-spec/workflow.yaml +0 -58
  133. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-patterns.yaml +0 -321
  134. package/.bmad/bmm/workflows/3-solutioning/architecture/architecture-template.md +0 -103
  135. package/.bmad/bmm/workflows/3-solutioning/architecture/checklist.md +0 -240
  136. package/.bmad/bmm/workflows/3-solutioning/architecture/decision-catalog.yaml +0 -222
  137. package/.bmad/bmm/workflows/3-solutioning/architecture/instructions.md +0 -768
  138. package/.bmad/bmm/workflows/3-solutioning/architecture/pattern-categories.csv +0 -13
  139. package/.bmad/bmm/workflows/3-solutioning/architecture/workflow.yaml +0 -55
  140. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/checklist.md +0 -169
  141. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/instructions.md +0 -332
  142. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/template.md +0 -146
  143. package/.bmad/bmm/workflows/3-solutioning/implementation-readiness/workflow.yaml +0 -62
  144. package/.bmad/bmm/workflows/4-implementation/code-review/backlog_template.md +0 -12
  145. package/.bmad/bmm/workflows/4-implementation/code-review/checklist.md +0 -22
  146. package/.bmad/bmm/workflows/4-implementation/code-review/instructions.md +0 -398
  147. package/.bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +0 -60
  148. package/.bmad/bmm/workflows/4-implementation/correct-course/checklist.md +0 -279
  149. package/.bmad/bmm/workflows/4-implementation/correct-course/instructions.md +0 -206
  150. package/.bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +0 -56
  151. package/.bmad/bmm/workflows/4-implementation/create-story/checklist.md +0 -240
  152. package/.bmad/bmm/workflows/4-implementation/create-story/instructions.md +0 -256
  153. package/.bmad/bmm/workflows/4-implementation/create-story/template.md +0 -51
  154. package/.bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +0 -71
  155. package/.bmad/bmm/workflows/4-implementation/dev-story/checklist.md +0 -38
  156. package/.bmad/bmm/workflows/4-implementation/dev-story/instructions.md +0 -267
  157. package/.bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +0 -56
  158. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/checklist.md +0 -17
  159. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/instructions.md +0 -164
  160. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/template.md +0 -76
  161. package/.bmad/bmm/workflows/4-implementation/epic-tech-context/workflow.yaml +0 -57
  162. package/.bmad/bmm/workflows/4-implementation/retrospective/instructions.md +0 -1443
  163. package/.bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +0 -56
  164. package/.bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +0 -33
  165. package/.bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +0 -234
  166. package/.bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +0 -55
  167. package/.bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +0 -49
  168. package/.bmad/bmm/workflows/4-implementation/story-context/checklist.md +0 -16
  169. package/.bmad/bmm/workflows/4-implementation/story-context/context-template.xml +0 -34
  170. package/.bmad/bmm/workflows/4-implementation/story-context/instructions.md +0 -209
  171. package/.bmad/bmm/workflows/4-implementation/story-context/workflow.yaml +0 -61
  172. package/.bmad/bmm/workflows/4-implementation/story-done/instructions.md +0 -111
  173. package/.bmad/bmm/workflows/4-implementation/story-done/workflow.yaml +0 -26
  174. package/.bmad/bmm/workflows/4-implementation/story-ready/instructions.md +0 -117
  175. package/.bmad/bmm/workflows/4-implementation/story-ready/workflow.yaml +0 -23
  176. package/.bmad/bmm/workflows/document-project/checklist.md +0 -245
  177. package/.bmad/bmm/workflows/document-project/documentation-requirements.csv +0 -12
  178. package/.bmad/bmm/workflows/document-project/instructions.md +0 -222
  179. package/.bmad/bmm/workflows/document-project/templates/deep-dive-template.md +0 -345
  180. package/.bmad/bmm/workflows/document-project/templates/index-template.md +0 -169
  181. package/.bmad/bmm/workflows/document-project/templates/project-overview-template.md +0 -103
  182. package/.bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +0 -160
  183. package/.bmad/bmm/workflows/document-project/templates/source-tree-template.md +0 -135
  184. package/.bmad/bmm/workflows/document-project/workflow.yaml +0 -29
  185. package/.bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +0 -298
  186. package/.bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +0 -31
  187. package/.bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +0 -1106
  188. package/.bmad/bmm/workflows/document-project/workflows/full-scan.yaml +0 -31
  189. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-helpers.md +0 -127
  190. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-library.json +0 -90
  191. package/.bmad/bmm/workflows/frame-expert/_shared/excalidraw-templates.yaml +0 -127
  192. package/.bmad/bmm/workflows/frame-expert/_shared/validate-json-instructions.md +0 -79
  193. package/.bmad/bmm/workflows/frame-expert/create-dataflow/checklist.md +0 -39
  194. package/.bmad/bmm/workflows/frame-expert/create-dataflow/instructions.md +0 -131
  195. package/.bmad/bmm/workflows/frame-expert/create-dataflow/workflow.yaml +0 -23
  196. package/.bmad/bmm/workflows/frame-expert/create-diagram/checklist.md +0 -43
  197. package/.bmad/bmm/workflows/frame-expert/create-diagram/instructions.md +0 -142
  198. package/.bmad/bmm/workflows/frame-expert/create-diagram/workflow.yaml +0 -24
  199. package/.bmad/bmm/workflows/frame-expert/create-flowchart/checklist.md +0 -49
  200. package/.bmad/bmm/workflows/frame-expert/create-flowchart/instructions.md +0 -242
  201. package/.bmad/bmm/workflows/frame-expert/create-flowchart/workflow.yaml +0 -27
  202. package/.bmad/bmm/workflows/frame-expert/create-wireframe/checklist.md +0 -38
  203. package/.bmad/bmm/workflows/frame-expert/create-wireframe/instructions.md +0 -133
  204. package/.bmad/bmm/workflows/frame-expert/create-wireframe/workflow.yaml +0 -23
  205. package/.bmad/bmm/workflows/techdoc/documentation-standards.md +0 -262
  206. package/.bmad/bmm/workflows/testarch/atdd/atdd-checklist-template.md +0 -363
  207. package/.bmad/bmm/workflows/testarch/atdd/checklist.md +0 -373
  208. package/.bmad/bmm/workflows/testarch/atdd/instructions.md +0 -785
  209. package/.bmad/bmm/workflows/testarch/atdd/workflow.yaml +0 -45
  210. package/.bmad/bmm/workflows/testarch/automate/checklist.md +0 -580
  211. package/.bmad/bmm/workflows/testarch/automate/instructions.md +0 -1303
  212. package/.bmad/bmm/workflows/testarch/automate/workflow.yaml +0 -52
  213. package/.bmad/bmm/workflows/testarch/ci/checklist.md +0 -246
  214. package/.bmad/bmm/workflows/testarch/ci/github-actions-template.yaml +0 -165
  215. package/.bmad/bmm/workflows/testarch/ci/gitlab-ci-template.yaml +0 -128
  216. package/.bmad/bmm/workflows/testarch/ci/instructions.md +0 -517
  217. package/.bmad/bmm/workflows/testarch/ci/workflow.yaml +0 -45
  218. package/.bmad/bmm/workflows/testarch/framework/checklist.md +0 -321
  219. package/.bmad/bmm/workflows/testarch/framework/instructions.md +0 -455
  220. package/.bmad/bmm/workflows/testarch/framework/workflow.yaml +0 -47
  221. package/.bmad/bmm/workflows/testarch/nfr-assess/checklist.md +0 -405
  222. package/.bmad/bmm/workflows/testarch/nfr-assess/instructions.md +0 -722
  223. package/.bmad/bmm/workflows/testarch/nfr-assess/nfr-report-template.md +0 -443
  224. package/.bmad/bmm/workflows/testarch/nfr-assess/workflow.yaml +0 -47
  225. package/.bmad/bmm/workflows/testarch/test-design/checklist.md +0 -234
  226. package/.bmad/bmm/workflows/testarch/test-design/instructions.md +0 -782
  227. package/.bmad/bmm/workflows/testarch/test-design/test-design-template.md +0 -285
  228. package/.bmad/bmm/workflows/testarch/test-design/workflow.yaml +0 -48
  229. package/.bmad/bmm/workflows/testarch/test-review/checklist.md +0 -470
  230. package/.bmad/bmm/workflows/testarch/test-review/instructions.md +0 -608
  231. package/.bmad/bmm/workflows/testarch/test-review/test-review-template.md +0 -388
  232. package/.bmad/bmm/workflows/testarch/test-review/workflow.yaml +0 -46
  233. package/.bmad/bmm/workflows/testarch/trace/checklist.md +0 -654
  234. package/.bmad/bmm/workflows/testarch/trace/instructions.md +0 -1045
  235. package/.bmad/bmm/workflows/testarch/trace/trace-template.md +0 -673
  236. package/.bmad/bmm/workflows/testarch/trace/workflow.yaml +0 -55
  237. package/.bmad/bmm/workflows/workflow-status/init/instructions.md +0 -334
  238. package/.bmad/bmm/workflows/workflow-status/init/workflow.yaml +0 -28
  239. package/.bmad/bmm/workflows/workflow-status/instructions.md +0 -388
  240. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-brownfield.yaml +0 -138
  241. package/.bmad/bmm/workflows/workflow-status/paths/enterprise-greenfield.yaml +0 -126
  242. package/.bmad/bmm/workflows/workflow-status/paths/game-design.yaml +0 -52
  243. package/.bmad/bmm/workflows/workflow-status/paths/method-brownfield.yaml +0 -122
  244. package/.bmad/bmm/workflows/workflow-status/paths/method-greenfield.yaml +0 -113
  245. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-brownfield.yaml +0 -58
  246. package/.bmad/bmm/workflows/workflow-status/paths/quick-flow-greenfield.yaml +0 -47
  247. package/.bmad/bmm/workflows/workflow-status/project-levels.yaml +0 -59
  248. package/.bmad/bmm/workflows/workflow-status/workflow-status-template.yaml +0 -24
  249. package/.bmad/bmm/workflows/workflow-status/workflow.yaml +0 -28
  250. package/.bmad/core/agents/bmad-master.md +0 -72
  251. package/.bmad/core/agents/bmad-web-orchestrator.agent.xml +0 -113
  252. package/.bmad/core/config.yaml +0 -11
  253. package/.bmad/core/tasks/adv-elicit-methods.csv +0 -39
  254. package/.bmad/core/tasks/advanced-elicitation-methods.csv +0 -21
  255. package/.bmad/core/tasks/advanced-elicitation.xml +0 -106
  256. package/.bmad/core/tasks/index-docs.xml +0 -65
  257. package/.bmad/core/tasks/validate-workflow.xml +0 -89
  258. package/.bmad/core/tasks/workflow.xml +0 -270
  259. package/.bmad/core/tools/shard-doc.xml +0 -109
  260. package/.bmad/core/workflows/brainstorming/README.md +0 -261
  261. package/.bmad/core/workflows/brainstorming/brain-methods.csv +0 -36
  262. package/.bmad/core/workflows/brainstorming/instructions.md +0 -315
  263. package/.bmad/core/workflows/brainstorming/template.md +0 -106
  264. package/.bmad/core/workflows/brainstorming/workflow.yaml +0 -38
  265. package/.bmad/core/workflows/party-mode/instructions.md +0 -203
  266. package/.bmad/core/workflows/party-mode/workflow.yaml +0 -28
  267. package/.bmad/docs/claude-code-instructions.md +0 -25
  268. package/.claude/commands/BMad/analyst.md +0 -88
  269. package/.claude/commands/BMad/architect.md +0 -89
  270. package/.claude/commands/BMad/bmad-master.md +0 -114
  271. package/.claude/commands/BMad/bmad-orchestrator.md +0 -151
  272. package/.claude/commands/BMad/dev.md +0 -85
  273. package/.claude/commands/BMad/pm.md +0 -88
  274. package/.claude/commands/BMad/po.md +0 -83
  275. package/.claude/commands/BMad/qa.md +0 -91
  276. package/.claude/commands/BMad/sm.md +0 -69
  277. package/.claude/commands/BMad/tasks/advanced-elicitation.md +0 -123
  278. package/.claude/commands/BMad/tasks/apply-qa-fixes.md +0 -154
  279. package/.claude/commands/BMad/tasks/brownfield-create-epic.md +0 -166
  280. package/.claude/commands/BMad/tasks/brownfield-create-story.md +0 -153
  281. package/.claude/commands/BMad/tasks/correct-course.md +0 -76
  282. package/.claude/commands/BMad/tasks/create-brownfield-story.md +0 -318
  283. package/.claude/commands/BMad/tasks/create-deep-research-prompt.md +0 -284
  284. package/.claude/commands/BMad/tasks/create-doc.md +0 -107
  285. package/.claude/commands/BMad/tasks/create-next-story.md +0 -118
  286. package/.claude/commands/BMad/tasks/document-project.md +0 -349
  287. package/.claude/commands/BMad/tasks/execute-checklist.md +0 -92
  288. package/.claude/commands/BMad/tasks/facilitate-brainstorming-session.md +0 -142
  289. package/.claude/commands/BMad/tasks/generate-ai-frontend-prompt.md +0 -57
  290. package/.claude/commands/BMad/tasks/index-docs.md +0 -179
  291. package/.claude/commands/BMad/tasks/kb-mode-interaction.md +0 -81
  292. package/.claude/commands/BMad/tasks/nfr-assess.md +0 -349
  293. package/.claude/commands/BMad/tasks/qa-gate.md +0 -167
  294. package/.claude/commands/BMad/tasks/review-story.md +0 -320
  295. package/.claude/commands/BMad/tasks/risk-profile.md +0 -359
  296. package/.claude/commands/BMad/tasks/shard-doc.md +0 -191
  297. package/.claude/commands/BMad/tasks/test-design.md +0 -180
  298. package/.claude/commands/BMad/tasks/trace-requirements.md +0 -270
  299. package/.claude/commands/BMad/tasks/validate-next-story.md +0 -140
  300. package/.claude/commands/BMad/ux-expert.md +0 -73
  301. package/.claude/commands/bmad/bmm/agents/analyst.md +0 -14
  302. package/.claude/commands/bmad/bmm/agents/architect.md +0 -14
  303. package/.claude/commands/bmad/bmm/agents/dev.md +0 -14
  304. package/.claude/commands/bmad/bmm/agents/frame-expert.md +0 -14
  305. package/.claude/commands/bmad/bmm/agents/pm.md +0 -14
  306. package/.claude/commands/bmad/bmm/agents/sm.md +0 -14
  307. package/.claude/commands/bmad/bmm/agents/tea.md +0 -14
  308. package/.claude/commands/bmad/bmm/agents/tech-writer.md +0 -14
  309. package/.claude/commands/bmad/bmm/agents/ux-designer.md +0 -14
  310. package/.claude/commands/bmad/bmm/workflows/architecture.md +0 -13
  311. package/.claude/commands/bmad/bmm/workflows/brainstorm-project.md +0 -13
  312. package/.claude/commands/bmad/bmm/workflows/code-review.md +0 -13
  313. package/.claude/commands/bmad/bmm/workflows/correct-course.md +0 -13
  314. package/.claude/commands/bmad/bmm/workflows/create-dataflow.md +0 -13
  315. package/.claude/commands/bmad/bmm/workflows/create-diagram.md +0 -13
  316. package/.claude/commands/bmad/bmm/workflows/create-epics-and-stories.md +0 -13
  317. package/.claude/commands/bmad/bmm/workflows/create-flowchart.md +0 -13
  318. package/.claude/commands/bmad/bmm/workflows/create-story.md +0 -13
  319. package/.claude/commands/bmad/bmm/workflows/create-ux-design.md +0 -13
  320. package/.claude/commands/bmad/bmm/workflows/create-wireframe.md +0 -13
  321. package/.claude/commands/bmad/bmm/workflows/dev-story.md +0 -13
  322. package/.claude/commands/bmad/bmm/workflows/document-project.md +0 -13
  323. package/.claude/commands/bmad/bmm/workflows/domain-research.md +0 -13
  324. package/.claude/commands/bmad/bmm/workflows/epic-tech-context.md +0 -13
  325. package/.claude/commands/bmad/bmm/workflows/implementation-readiness.md +0 -13
  326. package/.claude/commands/bmad/bmm/workflows/prd.md +0 -13
  327. package/.claude/commands/bmad/bmm/workflows/product-brief.md +0 -13
  328. package/.claude/commands/bmad/bmm/workflows/research.md +0 -13
  329. package/.claude/commands/bmad/bmm/workflows/retrospective.md +0 -13
  330. package/.claude/commands/bmad/bmm/workflows/sprint-planning.md +0 -13
  331. package/.claude/commands/bmad/bmm/workflows/story-context.md +0 -13
  332. package/.claude/commands/bmad/bmm/workflows/story-done.md +0 -13
  333. package/.claude/commands/bmad/bmm/workflows/story-ready.md +0 -13
  334. package/.claude/commands/bmad/bmm/workflows/tech-spec.md +0 -13
  335. package/.claude/commands/bmad/bmm/workflows/workflow-init.md +0 -13
  336. package/.claude/commands/bmad/bmm/workflows/workflow-status.md +0 -13
  337. package/.claude/commands/bmad/core/agents/bmad-master.md +0 -14
  338. package/.claude/commands/bmad/core/tasks/advanced-elicitation.md +0 -9
  339. package/.claude/commands/bmad/core/tasks/index-docs.md +0 -9
  340. package/.claude/commands/bmad/core/tools/shard-doc.md +0 -9
  341. package/.claude/commands/bmad/core/workflows/brainstorming.md +0 -13
  342. package/.claude/commands/bmad/core/workflows/party-mode.md +0 -13
  343. package/.claude/github-star-reminder.txt +0 -1
  344. package/.claude/hooks/bmad-party-manager.sh +0 -225
  345. package/.claude/hooks/stop.sh +0 -221
  346. package/.claude/piper-voices-dir.txt +0 -1
  347. package/.claude/plugins/bmad-voices-enabled.flag +0 -0
  348. package/.mcp.json +0 -88
  349. package/RELEASE_NOTES_v2.4.0_DRAFT.md +0 -116
  350. package/RELEASE_NOTES_v2.4.1_DRAFT.md +0 -61
  351. package/docs/2025-11-15_15-14-33.snagx +0 -0
  352. package/docs/Screenshot 2025-11-15 151325.png +0 -0
  353. package/docs/Screenshot 2025-11-15 151432.png +0 -0
  354. package/docs/macos-piper-issue.md +0 -172
  355. package/docs/stargazer-cms-prd.md +0 -1918
  356. package/docs/whatsapp-plugin-github-issue.md +0 -393
  357. package/docs/whatsapp-tts-plugin-feasibility.md +0 -418
  358. package/docs/whatsapp-tts-standalone-plugin.md +0 -628
  359. package/github-profile-draft.md +0 -57
  360. package/linkedin/vibe-coding-and-pulseaudio.md +0 -121
  361. package/mcp-server/agentvibes.db +0 -0
  362. package/scripts/audio-tunnel.config +0 -17
  363. package/v4-backup/.bmad-core/agent-teams/team-all.yaml +0 -15
  364. package/v4-backup/.bmad-core/agent-teams/team-fullstack.yaml +0 -19
  365. package/v4-backup/.bmad-core/agent-teams/team-ide-minimal.yaml +0 -11
  366. package/v4-backup/.bmad-core/agent-teams/team-no-ui.yaml +0 -14
  367. package/v4-backup/.bmad-core/agents/analyst.md +0 -84
  368. package/v4-backup/.bmad-core/agents/architect.md +0 -85
  369. package/v4-backup/.bmad-core/agents/bmad-master.md +0 -110
  370. package/v4-backup/.bmad-core/agents/bmad-orchestrator.md +0 -147
  371. package/v4-backup/.bmad-core/agents/dev.md +0 -81
  372. package/v4-backup/.bmad-core/agents/pm.md +0 -84
  373. package/v4-backup/.bmad-core/agents/po.md +0 -79
  374. package/v4-backup/.bmad-core/agents/qa.md +0 -87
  375. package/v4-backup/.bmad-core/agents/sm.md +0 -65
  376. package/v4-backup/.bmad-core/agents/ux-expert.md +0 -69
  377. package/v4-backup/.bmad-core/checklists/architect-checklist.md +0 -440
  378. package/v4-backup/.bmad-core/checklists/change-checklist.md +0 -184
  379. package/v4-backup/.bmad-core/checklists/pm-checklist.md +0 -372
  380. package/v4-backup/.bmad-core/checklists/po-master-checklist.md +0 -434
  381. package/v4-backup/.bmad-core/checklists/story-dod-checklist.md +0 -96
  382. package/v4-backup/.bmad-core/checklists/story-draft-checklist.md +0 -155
  383. package/v4-backup/.bmad-core/core-config.yaml +0 -22
  384. package/v4-backup/.bmad-core/data/bmad-kb.md +0 -809
  385. package/v4-backup/.bmad-core/data/brainstorming-techniques.md +0 -38
  386. package/v4-backup/.bmad-core/data/elicitation-methods.md +0 -156
  387. package/v4-backup/.bmad-core/data/technical-preferences.md +0 -5
  388. package/v4-backup/.bmad-core/data/test-levels-framework.md +0 -148
  389. package/v4-backup/.bmad-core/data/test-priorities-matrix.md +0 -174
  390. package/v4-backup/.bmad-core/enhanced-ide-development-workflow.md +0 -248
  391. package/v4-backup/.bmad-core/install-manifest.yaml +0 -230
  392. package/v4-backup/.bmad-core/tasks/advanced-elicitation.md +0 -119
  393. package/v4-backup/.bmad-core/tasks/apply-qa-fixes.md +0 -150
  394. package/v4-backup/.bmad-core/tasks/brownfield-create-epic.md +0 -162
  395. package/v4-backup/.bmad-core/tasks/brownfield-create-story.md +0 -149
  396. package/v4-backup/.bmad-core/tasks/correct-course.md +0 -72
  397. package/v4-backup/.bmad-core/tasks/create-brownfield-story.md +0 -314
  398. package/v4-backup/.bmad-core/tasks/create-deep-research-prompt.md +0 -280
  399. package/v4-backup/.bmad-core/tasks/create-doc.md +0 -103
  400. package/v4-backup/.bmad-core/tasks/create-next-story.md +0 -114
  401. package/v4-backup/.bmad-core/tasks/document-project.md +0 -345
  402. package/v4-backup/.bmad-core/tasks/execute-checklist.md +0 -88
  403. package/v4-backup/.bmad-core/tasks/facilitate-brainstorming-session.md +0 -138
  404. package/v4-backup/.bmad-core/tasks/generate-ai-frontend-prompt.md +0 -53
  405. package/v4-backup/.bmad-core/tasks/index-docs.md +0 -175
  406. package/v4-backup/.bmad-core/tasks/kb-mode-interaction.md +0 -77
  407. package/v4-backup/.bmad-core/tasks/nfr-assess.md +0 -345
  408. package/v4-backup/.bmad-core/tasks/qa-gate.md +0 -163
  409. package/v4-backup/.bmad-core/tasks/review-story.md +0 -316
  410. package/v4-backup/.bmad-core/tasks/risk-profile.md +0 -355
  411. package/v4-backup/.bmad-core/tasks/shard-doc.md +0 -187
  412. package/v4-backup/.bmad-core/tasks/test-design.md +0 -176
  413. package/v4-backup/.bmad-core/tasks/trace-requirements.md +0 -266
  414. package/v4-backup/.bmad-core/tasks/validate-next-story.md +0 -136
  415. package/v4-backup/.bmad-core/templates/architecture-tmpl.yaml +0 -651
  416. package/v4-backup/.bmad-core/templates/brainstorming-output-tmpl.yaml +0 -156
  417. package/v4-backup/.bmad-core/templates/brownfield-architecture-tmpl.yaml +0 -477
  418. package/v4-backup/.bmad-core/templates/brownfield-prd-tmpl.yaml +0 -281
  419. package/v4-backup/.bmad-core/templates/competitor-analysis-tmpl.yaml +0 -307
  420. package/v4-backup/.bmad-core/templates/front-end-architecture-tmpl.yaml +0 -219
  421. package/v4-backup/.bmad-core/templates/front-end-spec-tmpl.yaml +0 -350
  422. package/v4-backup/.bmad-core/templates/fullstack-architecture-tmpl.yaml +0 -824
  423. package/v4-backup/.bmad-core/templates/market-research-tmpl.yaml +0 -253
  424. package/v4-backup/.bmad-core/templates/prd-tmpl.yaml +0 -203
  425. package/v4-backup/.bmad-core/templates/project-brief-tmpl.yaml +0 -222
  426. package/v4-backup/.bmad-core/templates/qa-gate-tmpl.yaml +0 -103
  427. package/v4-backup/.bmad-core/templates/story-tmpl.yaml +0 -138
  428. package/v4-backup/.bmad-core/user-guide.md +0 -577
  429. package/v4-backup/.bmad-core/utils/bmad-doc-template.md +0 -327
  430. package/v4-backup/.bmad-core/utils/workflow-management.md +0 -71
  431. package/v4-backup/.bmad-core/workflows/brownfield-fullstack.yaml +0 -298
  432. package/v4-backup/.bmad-core/workflows/brownfield-service.yaml +0 -188
  433. package/v4-backup/.bmad-core/workflows/brownfield-ui.yaml +0 -198
  434. package/v4-backup/.bmad-core/workflows/greenfield-fullstack.yaml +0 -241
  435. package/v4-backup/.bmad-core/workflows/greenfield-service.yaml +0 -207
  436. package/v4-backup/.bmad-core/workflows/greenfield-ui.yaml +0 -236
  437. package/v4-backup/.bmad-core/working-in-the-brownfield.md +0 -606
@@ -1,601 +0,0 @@
1
- # Probability and Impact Scale
2
-
3
- ## Principle
4
-
5
- Risk scoring uses a **probability × impact** matrix (1-9 scale) to prioritize testing efforts. Higher scores (6-9) demand immediate action; lower scores (1-3) require documentation only. This systematic approach ensures testing resources focus on the highest-value risks.
6
-
7
- ## Rationale
8
-
9
- **The Problem**: Without quantifiable risk assessment, teams over-test low-value scenarios while missing critical risks. Gut feeling leads to inconsistent prioritization and missed edge cases.
10
-
11
- **The Solution**: Standardize risk evaluation with a 3×3 matrix (probability: 1-3, impact: 1-3). Multiply to derive risk score (1-9). Automate classification (DOCUMENT, MONITOR, MITIGATE, BLOCK) based on thresholds. This approach surfaces hidden risks early and justifies testing decisions to stakeholders.
12
-
13
- **Why This Matters**:
14
-
15
- - Consistent risk language across product, engineering, and QA
16
- - Objective prioritization of test scenarios (not politics)
17
- - Automatic gate decisions (score=9 → FAIL until resolved)
18
- - Audit trail for compliance and retrospectives
19
-
20
- ## Pattern Examples
21
-
22
- ### Example 1: Probability-Impact Matrix Implementation (Automated Classification)
23
-
24
- **Context**: Implement a reusable risk scoring system with automatic threshold classification
25
-
26
- **Implementation**:
27
-
28
- ```typescript
29
- // src/testing/risk-matrix.ts
30
-
31
- /**
32
- * Probability levels:
33
- * 1 = Unlikely (standard implementation, low uncertainty)
34
- * 2 = Possible (edge cases or partial unknowns)
35
- * 3 = Likely (known issues, new integrations, high ambiguity)
36
- */
37
- export type Probability = 1 | 2 | 3;
38
-
39
- /**
40
- * Impact levels:
41
- * 1 = Minor (cosmetic issues or easy workarounds)
42
- * 2 = Degraded (partial feature loss or manual workaround)
43
- * 3 = Critical (blockers, data/security/regulatory exposure)
44
- */
45
- export type Impact = 1 | 2 | 3;
46
-
47
- /**
48
- * Risk score (probability × impact): 1-9
49
- */
50
- export type RiskScore = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9;
51
-
52
- /**
53
- * Action categories based on risk score thresholds
54
- */
55
- export type RiskAction = 'DOCUMENT' | 'MONITOR' | 'MITIGATE' | 'BLOCK';
56
-
57
- export type RiskAssessment = {
58
- probability: Probability;
59
- impact: Impact;
60
- score: RiskScore;
61
- action: RiskAction;
62
- reasoning: string;
63
- };
64
-
65
- /**
66
- * Calculate risk score: probability × impact
67
- */
68
- export function calculateRiskScore(probability: Probability, impact: Impact): RiskScore {
69
- return (probability * impact) as RiskScore;
70
- }
71
-
72
- /**
73
- * Classify risk action based on score thresholds:
74
- * - 1-3: DOCUMENT (awareness only)
75
- * - 4-5: MONITOR (watch closely, plan mitigations)
76
- * - 6-8: MITIGATE (CONCERNS at gate until mitigated)
77
- * - 9: BLOCK (automatic FAIL until resolved or waived)
78
- */
79
- export function classifyRiskAction(score: RiskScore): RiskAction {
80
- if (score >= 9) return 'BLOCK';
81
- if (score >= 6) return 'MITIGATE';
82
- if (score >= 4) return 'MONITOR';
83
- return 'DOCUMENT';
84
- }
85
-
86
- /**
87
- * Full risk assessment with automatic classification
88
- */
89
- export function assessRisk(params: { probability: Probability; impact: Impact; reasoning: string }): RiskAssessment {
90
- const { probability, impact, reasoning } = params;
91
-
92
- const score = calculateRiskScore(probability, impact);
93
- const action = classifyRiskAction(score);
94
-
95
- return { probability, impact, score, action, reasoning };
96
- }
97
-
98
- /**
99
- * Generate risk matrix visualization (3x3 grid)
100
- * Returns markdown table with color-coded scores
101
- */
102
- export function generateRiskMatrix(): string {
103
- const matrix: string[][] = [];
104
- const header = ['Impact \\ Probability', 'Unlikely (1)', 'Possible (2)', 'Likely (3)'];
105
- matrix.push(header);
106
-
107
- const impactLabels = ['Critical (3)', 'Degraded (2)', 'Minor (1)'];
108
- for (let impact = 3; impact >= 1; impact--) {
109
- const row = [impactLabels[3 - impact]];
110
- for (let probability = 1; probability <= 3; probability++) {
111
- const score = calculateRiskScore(probability as Probability, impact as Impact);
112
- const action = classifyRiskAction(score);
113
- const emoji = action === 'BLOCK' ? '🔴' : action === 'MITIGATE' ? '🟠' : action === 'MONITOR' ? '🟡' : '🟢';
114
- row.push(`${emoji} ${score}`);
115
- }
116
- matrix.push(row);
117
- }
118
-
119
- return matrix.map((row) => `| ${row.join(' | ')} |`).join('\n');
120
- }
121
- ```
122
-
123
- **Key Points**:
124
-
125
- - Type-safe probability/impact (1-3 enforced at compile time)
126
- - Automatic action classification (DOCUMENT, MONITOR, MITIGATE, BLOCK)
127
- - Visual matrix generation for documentation
128
- - Risk score formula: `probability * impact` (max = 9)
129
- - Threshold-based decision rules (6-8 = MITIGATE, 9 = BLOCK)
130
-
131
- ---
132
-
133
- ### Example 2: Risk Assessment Workflow (Test Planning Integration)
134
-
135
- **Context**: Apply risk matrix during test design to prioritize scenarios
136
-
137
- **Implementation**:
138
-
139
- ```typescript
140
- // tests/e2e/test-planning/risk-assessment.ts
141
- import { assessRisk, generateRiskMatrix, type RiskAssessment } from '../../../src/testing/risk-matrix';
142
-
143
- export type TestScenario = {
144
- id: string;
145
- title: string;
146
- feature: string;
147
- risk: RiskAssessment;
148
- testLevel: 'E2E' | 'API' | 'Unit';
149
- priority: 'P0' | 'P1' | 'P2' | 'P3';
150
- owner: string;
151
- };
152
-
153
- /**
154
- * Assess test scenarios and auto-assign priority based on risk score
155
- */
156
- export function assessTestScenarios(scenarios: Omit<TestScenario, 'risk' | 'priority'>[]): TestScenario[] {
157
- return scenarios.map((scenario) => {
158
- // Auto-assign priority based on risk score
159
- const priority = mapRiskToPriority(scenario.risk.score);
160
- return { ...scenario, priority };
161
- });
162
- }
163
-
164
- /**
165
- * Map risk score to test priority (P0-P3)
166
- * P0: Critical (score 9) - blocks release
167
- * P1: High (score 6-8) - must fix before release
168
- * P2: Medium (score 4-5) - fix if time permits
169
- * P3: Low (score 1-3) - document and defer
170
- */
171
- function mapRiskToPriority(score: number): 'P0' | 'P1' | 'P2' | 'P3' {
172
- if (score === 9) return 'P0';
173
- if (score >= 6) return 'P1';
174
- if (score >= 4) return 'P2';
175
- return 'P3';
176
- }
177
-
178
- /**
179
- * Example: Payment flow risk assessment
180
- */
181
- export const paymentScenarios: Array<Omit<TestScenario, 'priority'>> = [
182
- {
183
- id: 'PAY-001',
184
- title: 'Valid credit card payment completes successfully',
185
- feature: 'Checkout',
186
- risk: assessRisk({
187
- probability: 2, // Possible (standard Stripe integration)
188
- impact: 3, // Critical (revenue loss if broken)
189
- reasoning: 'Core revenue flow, but Stripe is well-tested',
190
- }),
191
- testLevel: 'E2E',
192
- owner: 'qa-team',
193
- },
194
- {
195
- id: 'PAY-002',
196
- title: 'Expired credit card shows user-friendly error',
197
- feature: 'Checkout',
198
- risk: assessRisk({
199
- probability: 3, // Likely (edge case handling often buggy)
200
- impact: 2, // Degraded (users see error, but can retry)
201
- reasoning: 'Error handling logic is custom and complex',
202
- }),
203
- testLevel: 'E2E',
204
- owner: 'qa-team',
205
- },
206
- {
207
- id: 'PAY-003',
208
- title: 'Payment confirmation email formatting is correct',
209
- feature: 'Email',
210
- risk: assessRisk({
211
- probability: 2, // Possible (template changes occasionally break)
212
- impact: 1, // Minor (cosmetic issue, email still sent)
213
- reasoning: 'Non-blocking, users get email regardless',
214
- }),
215
- testLevel: 'Unit',
216
- owner: 'dev-team',
217
- },
218
- {
219
- id: 'PAY-004',
220
- title: 'Payment fails gracefully when Stripe is down',
221
- feature: 'Checkout',
222
- risk: assessRisk({
223
- probability: 1, // Unlikely (Stripe has 99.99% uptime)
224
- impact: 3, // Critical (complete checkout failure)
225
- reasoning: 'Rare but catastrophic, requires retry mechanism',
226
- }),
227
- testLevel: 'API',
228
- owner: 'qa-team',
229
- },
230
- ];
231
-
232
- /**
233
- * Generate risk assessment report with priority distribution
234
- */
235
- export function generateRiskReport(scenarios: TestScenario[]): string {
236
- const priorityCounts = scenarios.reduce(
237
- (acc, s) => {
238
- acc[s.priority] = (acc[s.priority] || 0) + 1;
239
- return acc;
240
- },
241
- {} as Record<string, number>,
242
- );
243
-
244
- const actionCounts = scenarios.reduce(
245
- (acc, s) => {
246
- acc[s.risk.action] = (acc[s.risk.action] || 0) + 1;
247
- return acc;
248
- },
249
- {} as Record<string, number>,
250
- );
251
-
252
- return `
253
- # Risk Assessment Report
254
-
255
- ## Risk Matrix
256
- ${generateRiskMatrix()}
257
-
258
- ## Priority Distribution
259
- - **P0 (Blocker)**: ${priorityCounts.P0 || 0} scenarios
260
- - **P1 (High)**: ${priorityCounts.P1 || 0} scenarios
261
- - **P2 (Medium)**: ${priorityCounts.P2 || 0} scenarios
262
- - **P3 (Low)**: ${priorityCounts.P3 || 0} scenarios
263
-
264
- ## Action Required
265
- - **BLOCK**: ${actionCounts.BLOCK || 0} scenarios (auto-fail gate)
266
- - **MITIGATE**: ${actionCounts.MITIGATE || 0} scenarios (concerns at gate)
267
- - **MONITOR**: ${actionCounts.MONITOR || 0} scenarios (watch closely)
268
- - **DOCUMENT**: ${actionCounts.DOCUMENT || 0} scenarios (awareness only)
269
-
270
- ## Scenarios by Risk Score (Highest First)
271
- ${scenarios
272
- .sort((a, b) => b.risk.score - a.risk.score)
273
- .map((s) => `- **[${s.priority}]** ${s.id}: ${s.title} (Score: ${s.risk.score} - ${s.risk.action})`)
274
- .join('\n')}
275
- `.trim();
276
- }
277
- ```
278
-
279
- **Key Points**:
280
-
281
- - Risk score → Priority mapping (P0-P3 automated)
282
- - Report generation with priority/action distribution
283
- - Scenarios sorted by risk score (highest first)
284
- - Visual matrix included in reports
285
- - Reusable across projects (extract to shared library)
286
-
287
- ---
288
-
289
- ### Example 3: Dynamic Risk Re-Assessment (Continuous Evaluation)
290
-
291
- **Context**: Recalculate risk scores as project evolves (requirements change, mitigations implemented)
292
-
293
- **Implementation**:
294
-
295
- ```typescript
296
- // src/testing/risk-tracking.ts
297
- import { type RiskAssessment, assessRisk, type Probability, type Impact } from './risk-matrix';
298
-
299
- export type RiskHistory = {
300
- timestamp: Date;
301
- assessment: RiskAssessment;
302
- changedBy: string;
303
- reason: string;
304
- };
305
-
306
- export type TrackedRisk = {
307
- id: string;
308
- title: string;
309
- feature: string;
310
- currentRisk: RiskAssessment;
311
- history: RiskHistory[];
312
- mitigations: string[];
313
- status: 'OPEN' | 'MITIGATED' | 'WAIVED' | 'RESOLVED';
314
- };
315
-
316
- export class RiskTracker {
317
- private risks: Map<string, TrackedRisk> = new Map();
318
-
319
- /**
320
- * Add new risk to tracker
321
- */
322
- addRisk(params: {
323
- id: string;
324
- title: string;
325
- feature: string;
326
- probability: Probability;
327
- impact: Impact;
328
- reasoning: string;
329
- changedBy: string;
330
- }): TrackedRisk {
331
- const { id, title, feature, probability, impact, reasoning, changedBy } = params;
332
-
333
- const assessment = assessRisk({ probability, impact, reasoning });
334
-
335
- const risk: TrackedRisk = {
336
- id,
337
- title,
338
- feature,
339
- currentRisk: assessment,
340
- history: [
341
- {
342
- timestamp: new Date(),
343
- assessment,
344
- changedBy,
345
- reason: 'Initial assessment',
346
- },
347
- ],
348
- mitigations: [],
349
- status: 'OPEN',
350
- };
351
-
352
- this.risks.set(id, risk);
353
- return risk;
354
- }
355
-
356
- /**
357
- * Reassess risk (probability or impact changed)
358
- */
359
- reassessRisk(params: {
360
- id: string;
361
- probability?: Probability;
362
- impact?: Impact;
363
- reasoning: string;
364
- changedBy: string;
365
- }): TrackedRisk | null {
366
- const { id, probability, impact, reasoning, changedBy } = params;
367
- const risk = this.risks.get(id);
368
- if (!risk) return null;
369
-
370
- // Use existing values if not provided
371
- const newProbability = probability ?? risk.currentRisk.probability;
372
- const newImpact = impact ?? risk.currentRisk.impact;
373
-
374
- const newAssessment = assessRisk({
375
- probability: newProbability,
376
- impact: newImpact,
377
- reasoning,
378
- });
379
-
380
- risk.currentRisk = newAssessment;
381
- risk.history.push({
382
- timestamp: new Date(),
383
- assessment: newAssessment,
384
- changedBy,
385
- reason: reasoning,
386
- });
387
-
388
- this.risks.set(id, risk);
389
- return risk;
390
- }
391
-
392
- /**
393
- * Mark risk as mitigated (probability reduced)
394
- */
395
- mitigateRisk(params: { id: string; newProbability: Probability; mitigation: string; changedBy: string }): TrackedRisk | null {
396
- const { id, newProbability, mitigation, changedBy } = params;
397
- const risk = this.reassessRisk({
398
- id,
399
- probability: newProbability,
400
- reasoning: `Mitigation implemented: ${mitigation}`,
401
- changedBy,
402
- });
403
-
404
- if (risk) {
405
- risk.mitigations.push(mitigation);
406
- if (risk.currentRisk.action === 'DOCUMENT' || risk.currentRisk.action === 'MONITOR') {
407
- risk.status = 'MITIGATED';
408
- }
409
- }
410
-
411
- return risk;
412
- }
413
-
414
- /**
415
- * Get risks requiring action (MITIGATE or BLOCK)
416
- */
417
- getRisksRequiringAction(): TrackedRisk[] {
418
- return Array.from(this.risks.values()).filter(
419
- (r) => r.status === 'OPEN' && (r.currentRisk.action === 'MITIGATE' || r.currentRisk.action === 'BLOCK'),
420
- );
421
- }
422
-
423
- /**
424
- * Generate risk trend report (show changes over time)
425
- */
426
- generateTrendReport(riskId: string): string | null {
427
- const risk = this.risks.get(riskId);
428
- if (!risk) return null;
429
-
430
- return `
431
- # Risk Trend Report: ${risk.id}
432
-
433
- **Title**: ${risk.title}
434
- **Feature**: ${risk.feature}
435
- **Status**: ${risk.status}
436
-
437
- ## Current Assessment
438
- - **Probability**: ${risk.currentRisk.probability}
439
- - **Impact**: ${risk.currentRisk.impact}
440
- - **Score**: ${risk.currentRisk.score}
441
- - **Action**: ${risk.currentRisk.action}
442
- - **Reasoning**: ${risk.currentRisk.reasoning}
443
-
444
- ## Mitigations Applied
445
- ${risk.mitigations.length > 0 ? risk.mitigations.map((m) => `- ${m}`).join('\n') : '- None'}
446
-
447
- ## History (${risk.history.length} changes)
448
- ${risk.history
449
- .reverse()
450
- .map((h) => `- **${h.timestamp.toISOString()}** by ${h.changedBy}: Score ${h.assessment.score} (${h.assessment.action}) - ${h.reason}`)
451
- .join('\n')}
452
- `.trim();
453
- }
454
- }
455
- ```
456
-
457
- **Key Points**:
458
-
459
- - Historical tracking (audit trail for risk changes)
460
- - Mitigation impact tracking (probability reduction)
461
- - Status lifecycle (OPEN → MITIGATED → RESOLVED)
462
- - Trend reports (show risk evolution over time)
463
- - Re-assessment triggers (requirements change, new info)
464
-
465
- ---
466
-
467
- ### Example 4: Risk Matrix in Gate Decision (Integration with Trace Workflow)
468
-
469
- **Context**: Use probability-impact scores to drive gate decisions (PASS/CONCERNS/FAIL/WAIVED)
470
-
471
- **Implementation**:
472
-
473
- ```typescript
474
- // src/testing/gate-decision.ts
475
- import { type RiskScore, classifyRiskAction, type RiskAction } from './risk-matrix';
476
- import { type TrackedRisk } from './risk-tracking';
477
-
478
- export type GateDecision = 'PASS' | 'CONCERNS' | 'FAIL' | 'WAIVED';
479
-
480
- export type GateResult = {
481
- decision: GateDecision;
482
- blockers: TrackedRisk[]; // Score=9, action=BLOCK
483
- concerns: TrackedRisk[]; // Score 6-8, action=MITIGATE
484
- monitored: TrackedRisk[]; // Score 4-5, action=MONITOR
485
- documented: TrackedRisk[]; // Score 1-3, action=DOCUMENT
486
- summary: string;
487
- };
488
-
489
- /**
490
- * Evaluate gate based on risk assessments
491
- */
492
- export function evaluateGateFromRisks(risks: TrackedRisk[]): GateResult {
493
- const blockers = risks.filter((r) => r.currentRisk.action === 'BLOCK' && r.status === 'OPEN');
494
- const concerns = risks.filter((r) => r.currentRisk.action === 'MITIGATE' && r.status === 'OPEN');
495
- const monitored = risks.filter((r) => r.currentRisk.action === 'MONITOR');
496
- const documented = risks.filter((r) => r.currentRisk.action === 'DOCUMENT');
497
-
498
- let decision: GateDecision;
499
-
500
- if (blockers.length > 0) {
501
- decision = 'FAIL';
502
- } else if (concerns.length > 0) {
503
- decision = 'CONCERNS';
504
- } else {
505
- decision = 'PASS';
506
- }
507
-
508
- const summary = generateGateSummary({ decision, blockers, concerns, monitored, documented });
509
-
510
- return { decision, blockers, concerns, monitored, documented, summary };
511
- }
512
-
513
- /**
514
- * Generate gate decision summary
515
- */
516
- function generateGateSummary(result: Omit<GateResult, 'summary'>): string {
517
- const { decision, blockers, concerns, monitored, documented } = result;
518
-
519
- const lines: string[] = [`## Gate Decision: ${decision}`];
520
-
521
- if (decision === 'FAIL') {
522
- lines.push(`\n**Blockers** (${blockers.length}): Automatic FAIL until resolved or waived`);
523
- blockers.forEach((r) => {
524
- lines.push(`- **${r.id}**: ${r.title} (Score: ${r.currentRisk.score})`);
525
- lines.push(` - Probability: ${r.currentRisk.probability}, Impact: ${r.currentRisk.impact}`);
526
- lines.push(` - Reasoning: ${r.currentRisk.reasoning}`);
527
- });
528
- }
529
-
530
- if (concerns.length > 0) {
531
- lines.push(`\n**Concerns** (${concerns.length}): Address before release`);
532
- concerns.forEach((r) => {
533
- lines.push(`- **${r.id}**: ${r.title} (Score: ${r.currentRisk.score})`);
534
- lines.push(` - Mitigations: ${r.mitigations.join(', ') || 'None'}`);
535
- });
536
- }
537
-
538
- if (monitored.length > 0) {
539
- lines.push(`\n**Monitored** (${monitored.length}): Watch closely`);
540
- monitored.forEach((r) => lines.push(`- **${r.id}**: ${r.title} (Score: ${r.currentRisk.score})`));
541
- }
542
-
543
- if (documented.length > 0) {
544
- lines.push(`\n**Documented** (${documented.length}): Awareness only`);
545
- }
546
-
547
- lines.push(`\n---\n`);
548
- lines.push(`**Next Steps**:`);
549
- if (decision === 'FAIL') {
550
- lines.push(`- Resolve blockers or request formal waiver`);
551
- } else if (decision === 'CONCERNS') {
552
- lines.push(`- Implement mitigations for high-risk scenarios (score 6-8)`);
553
- lines.push(`- Re-run gate after mitigations`);
554
- } else {
555
- lines.push(`- Proceed with release`);
556
- }
557
-
558
- return lines.join('\n');
559
- }
560
- ```
561
-
562
- **Key Points**:
563
-
564
- - Gate decision driven by risk scores (not gut feeling)
565
- - Automatic FAIL for score=9 (blockers)
566
- - CONCERNS for score 6-8 (requires mitigation)
567
- - PASS only when no blockers/concerns
568
- - Actionable summary with next steps
569
- - Integration with trace workflow (Phase 2)
570
-
571
- ---
572
-
573
- ## Probability-Impact Threshold Summary
574
-
575
- | Score | Action | Gate Impact | Typical Use Case |
576
- | ----- | -------- | -------------------- | -------------------------------------- |
577
- | 1-3 | DOCUMENT | None | Cosmetic issues, low-priority bugs |
578
- | 4-5 | MONITOR | None (watch closely) | Edge cases, partial unknowns |
579
- | 6-8 | MITIGATE | CONCERNS at gate | High-impact scenarios needing coverage |
580
- | 9 | BLOCK | Automatic FAIL | Critical blockers, must resolve |
581
-
582
- ## Risk Assessment Checklist
583
-
584
- Before deploying risk matrix:
585
-
586
- - [ ] **Probability scale defined**: 1 (unlikely), 2 (possible), 3 (likely) with clear examples
587
- - [ ] **Impact scale defined**: 1 (minor), 2 (degraded), 3 (critical) with concrete criteria
588
- - [ ] **Threshold rules documented**: Score → Action mapping (1-3 = DOCUMENT, 4-5 = MONITOR, 6-8 = MITIGATE, 9 = BLOCK)
589
- - [ ] **Gate integration**: Risk scores drive gate decisions (PASS/CONCERNS/FAIL/WAIVED)
590
- - [ ] **Re-assessment process**: Risks re-evaluated as project evolves (requirements change, mitigations applied)
591
- - [ ] **Audit trail**: Historical tracking for risk changes (who, when, why)
592
- - [ ] **Mitigation tracking**: Link mitigations to probability reduction (quantify impact)
593
- - [ ] **Reporting**: Risk matrix visualization, trend reports, gate summaries
594
-
595
- ## Integration Points
596
-
597
- - **Used in workflows**: `*test-design` (initial risk assessment), `*trace` (gate decision Phase 2), `*nfr-assess` (security/performance risks)
598
- - **Related fragments**: `risk-governance.md` (risk scoring matrix, gate decision engine), `test-priorities-matrix.md` (P0-P3 mapping), `nfr-criteria.md` (impact assessment for NFRs)
599
- - **Tools**: TypeScript for type safety, markdown for reports, version control for audit trail
600
-
601
- _Source: Murat risk model summary, gate decision patterns from production systems, probability-impact matrix from risk governance practices_