agentvibes 2.12.7 → 2.12.8

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