agentvibes 2.13.6 → 2.13.8

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