agentvibes 2.13.7 → 2.13.9

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