create-byan-agent 2.0.1 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (974) hide show
  1. package/.github/agents/bmad-agent-bmad-master.md +40 -0
  2. package/.github/agents/bmad-agent-byan-v2.md +44 -0
  3. package/.github/agents/bmad-agent-byan.md +251 -0
  4. package/.github/agents/bmad-agent-drawio.md +44 -0
  5. package/.github/agents/bmad-agent-marc.md +98 -0
  6. package/README.MD +225 -0
  7. package/__tests__/byan-v2/context/copilot-context.test.js +327 -0
  8. package/__tests__/byan-v2/context/session-state.test.js +322 -0
  9. package/__tests__/byan-v2/dispatcher/complexity-scorer.test.js +358 -0
  10. package/__tests__/byan-v2/dispatcher/five-whys-analyzer.test.js +473 -0
  11. package/__tests__/byan-v2/dispatcher/local-executor.test.js +496 -0
  12. package/__tests__/byan-v2/dispatcher/task-router.test.js +265 -0
  13. package/__tests__/byan-v2/dispatcher/task-tool-interface.test.js +328 -0
  14. package/__tests__/byan-v2/generation/agent-profile-validator.test.js +386 -0
  15. package/__tests__/byan-v2/generation/mantra-validator.test.js +640 -0
  16. package/__tests__/byan-v2/generation/profile-template.test.js +338 -0
  17. package/__tests__/byan-v2/integration/active-listening-flow.test.js +577 -0
  18. package/__tests__/byan-v2/integration/five-whys-flow.test.js +559 -0
  19. package/__tests__/byan-v2/integration/full-bmad-workflow.test.js +903 -0
  20. package/__tests__/byan-v2/integration/full-bmad-workflow.test.js.backup +889 -0
  21. package/__tests__/byan-v2/integration/glossary-flow.test.js +479 -0
  22. package/__tests__/byan-v2/integration/system-integration.test.js +306 -0
  23. package/__tests__/byan-v2/integration/voice-integration.test.js +157 -0
  24. package/__tests__/byan-v2/observability/error-tracker.test.js +461 -0
  25. package/__tests__/byan-v2/observability/logger.test.js +419 -0
  26. package/__tests__/byan-v2/observability/metrics-collector.test.js +346 -0
  27. package/__tests__/byan-v2/orchestrator/active-listener.test.js +694 -0
  28. package/__tests__/byan-v2/orchestrator/analysis-state.test.js +493 -0
  29. package/__tests__/byan-v2/orchestrator/generation-state.test.js +518 -0
  30. package/__tests__/byan-v2/orchestrator/glossary-builder.test.js +464 -0
  31. package/__tests__/byan-v2/orchestrator/interview-state.test.js +470 -0
  32. package/__tests__/byan-v2/orchestrator/state-machine.test.js +495 -0
  33. package/__tests__/cache.test.js +241 -0
  34. package/__tests__/context.test.js +135 -0
  35. package/__tests__/dashboard.test.js +444 -0
  36. package/__tests__/dispatcher.test.js +245 -0
  37. package/__tests__/integration.test.js +163 -0
  38. package/__tests__/metrics-collector.test.js +433 -0
  39. package/__tests__/structured-logger.test.js +358 -0
  40. package/__tests__/worker-pool.test.js +343 -0
  41. package/__tests__/workflow-executor.test.js +356 -0
  42. package/_bmad/_config/agent-manifest.csv +25 -0
  43. package/_bmad/_config/agents/bmb-agent-builder.customize.yaml +41 -0
  44. package/_bmad/_config/agents/bmb-module-builder.customize.yaml +41 -0
  45. package/_bmad/_config/agents/bmb-workflow-builder.customize.yaml +41 -0
  46. package/_bmad/_config/agents/bmm-analyst.customize.yaml +41 -0
  47. package/_bmad/_config/agents/bmm-architect.customize.yaml +41 -0
  48. package/_bmad/_config/agents/bmm-dev.customize.yaml +41 -0
  49. package/_bmad/_config/agents/bmm-pm.customize.yaml +41 -0
  50. package/_bmad/_config/agents/bmm-quick-flow-solo-dev.customize.yaml +41 -0
  51. package/_bmad/_config/agents/bmm-quinn.customize.yaml +41 -0
  52. package/_bmad/_config/agents/bmm-sm.customize.yaml +41 -0
  53. package/_bmad/_config/agents/bmm-tech-writer.customize.yaml +41 -0
  54. package/_bmad/_config/agents/bmm-ux-designer.customize.yaml +41 -0
  55. package/_bmad/_config/agents/byan.customize.yaml +29 -0
  56. package/_bmad/_config/agents/cis-brainstorming-coach.customize.yaml +41 -0
  57. package/_bmad/_config/agents/cis-creative-problem-solver.customize.yaml +41 -0
  58. package/_bmad/_config/agents/cis-design-thinking-coach.customize.yaml +41 -0
  59. package/_bmad/_config/agents/cis-innovation-strategist.customize.yaml +41 -0
  60. package/_bmad/_config/agents/cis-presentation-master.customize.yaml +41 -0
  61. package/_bmad/_config/agents/cis-storyteller.customize.yaml +41 -0
  62. package/_bmad/_config/agents/core-bmad-master.customize.yaml +41 -0
  63. package/_bmad/_config/agents/tea-tea.customize.yaml +41 -0
  64. package/_bmad/_config/bmad-help.csv +72 -0
  65. package/_bmad/_config/files-manifest.csv +607 -0
  66. package/_bmad/_config/ides/codex.yaml +5 -0
  67. package/_bmad/_config/manifest.yaml +43 -0
  68. package/_bmad/_config/task-manifest.csv +9 -0
  69. package/_bmad/_config/tool-manifest.csv +1 -0
  70. package/_bmad/_config/workflow-manifest.csv +46 -0
  71. package/_bmad/_memory/config.yaml +11 -0
  72. package/_bmad/_memory/storyteller-sidecar/stories-told.md +7 -0
  73. package/_bmad/_memory/storyteller-sidecar/story-preferences.md +7 -0
  74. package/_bmad/_memory/tech-writer-sidecar/documentation-standards.md +224 -0
  75. package/_bmad/bmb/agents/byan.md +215 -0
  76. package/_bmad/bmb/agents/byan.optimized-v2.md +116 -0
  77. package/_bmad/bmb/agents/byan.optimized.md +189 -0
  78. package/_bmad/bmb/agents/drawio.md +359 -0
  79. package/_bmad/bmb/agents/marc.md +351 -0
  80. package/_bmad/bmb/agents/turbo-whisper-integration.md +312 -0
  81. package/_bmad/bmb/config.yaml +12 -0
  82. package/_bmad/bmb/module-help.csv +13 -0
  83. package/_bmad/bmb/workflows/agent/data/agent-compilation.md +273 -0
  84. package/_bmad/bmb/workflows/agent/data/agent-menu-patterns.md +233 -0
  85. package/_bmad/bmb/workflows/agent/data/agent-metadata.md +208 -0
  86. package/_bmad/bmb/workflows/agent/data/brainstorm-context.md +146 -0
  87. package/_bmad/bmb/workflows/agent/data/communication-presets.csv +61 -0
  88. package/_bmad/bmb/workflows/agent/data/critical-actions.md +120 -0
  89. package/_bmad/bmb/workflows/agent/data/expert-agent-architecture.md +236 -0
  90. package/_bmad/bmb/workflows/agent/data/expert-agent-validation.md +174 -0
  91. package/_bmad/bmb/workflows/agent/data/module-agent-validation.md +126 -0
  92. package/_bmad/bmb/workflows/agent/data/persona-properties.md +266 -0
  93. package/_bmad/bmb/workflows/agent/data/principles-crafting.md +292 -0
  94. package/_bmad/bmb/workflows/agent/data/reference/module-examples/architect.md +68 -0
  95. package/_bmad/bmb/workflows/agent/data/simple-agent-architecture.md +204 -0
  96. package/_bmad/bmb/workflows/agent/data/simple-agent-validation.md +133 -0
  97. package/_bmad/bmb/workflows/agent/data/understanding-agent-types.md +222 -0
  98. package/_bmad/bmb/workflows/agent/steps-c/step-01-brainstorm.md +128 -0
  99. package/_bmad/bmb/workflows/agent/steps-c/step-02-discovery.md +170 -0
  100. package/_bmad/bmb/workflows/agent/steps-c/step-03-type-metadata.md +296 -0
  101. package/_bmad/bmb/workflows/agent/steps-c/step-04-persona.md +212 -0
  102. package/_bmad/bmb/workflows/agent/steps-c/step-05-commands-menu.md +178 -0
  103. package/_bmad/bmb/workflows/agent/steps-c/step-06-activation.md +279 -0
  104. package/_bmad/bmb/workflows/agent/steps-c/step-07a-build-simple.md +187 -0
  105. package/_bmad/bmb/workflows/agent/steps-c/step-07b-build-expert.md +201 -0
  106. package/_bmad/bmb/workflows/agent/steps-c/step-07c-build-module.md +258 -0
  107. package/_bmad/bmb/workflows/agent/steps-c/step-08-celebrate.md +249 -0
  108. package/_bmad/bmb/workflows/agent/steps-e/e-01-load-existing.md +221 -0
  109. package/_bmad/bmb/workflows/agent/steps-e/e-02-discover-edits.md +193 -0
  110. package/_bmad/bmb/workflows/agent/steps-e/e-03-placeholder.md +1 -0
  111. package/_bmad/bmb/workflows/agent/steps-e/e-04-type-metadata.md +124 -0
  112. package/_bmad/bmb/workflows/agent/steps-e/e-05-persona.md +134 -0
  113. package/_bmad/bmb/workflows/agent/steps-e/e-06-commands-menu.md +122 -0
  114. package/_bmad/bmb/workflows/agent/steps-e/e-07-activation.md +125 -0
  115. package/_bmad/bmb/workflows/agent/steps-e/e-08a-edit-simple.md +137 -0
  116. package/_bmad/bmb/workflows/agent/steps-e/e-08b-edit-expert.md +119 -0
  117. package/_bmad/bmb/workflows/agent/steps-e/e-08c-edit-module.md +123 -0
  118. package/_bmad/bmb/workflows/agent/steps-e/e-09-celebrate.md +155 -0
  119. package/_bmad/bmb/workflows/agent/steps-v/v-01-load-review.md +136 -0
  120. package/_bmad/bmb/workflows/agent/steps-v/v-02a-validate-metadata.md +116 -0
  121. package/_bmad/bmb/workflows/agent/steps-v/v-02b-validate-persona.md +124 -0
  122. package/_bmad/bmb/workflows/agent/steps-v/v-02c-validate-menu.md +145 -0
  123. package/_bmad/bmb/workflows/agent/steps-v/v-02d-validate-structure.md +136 -0
  124. package/_bmad/bmb/workflows/agent/steps-v/v-02e-validate-sidecar.md +136 -0
  125. package/_bmad/bmb/workflows/agent/steps-v/v-03-summary.md +104 -0
  126. package/_bmad/bmb/workflows/agent/templates/agent-plan.template.md +5 -0
  127. package/_bmad/bmb/workflows/agent/templates/expert-agent-template/expert-agent.template.md +77 -0
  128. package/_bmad/bmb/workflows/agent/templates/simple-agent.template.md +72 -0
  129. package/_bmad/bmb/workflows/agent/workflow.md +123 -0
  130. package/_bmad/bmb/workflows/module/data/agent-architecture.md +179 -0
  131. package/_bmad/bmb/workflows/module/data/agent-spec-template.md +79 -0
  132. package/_bmad/bmb/workflows/module/data/module-installer-standards.md +348 -0
  133. package/_bmad/bmb/workflows/module/data/module-standards.md +280 -0
  134. package/_bmad/bmb/workflows/module/data/module-yaml-conventions.md +392 -0
  135. package/_bmad/bmb/workflows/module/steps-b/step-01-welcome.md +147 -0
  136. package/_bmad/bmb/workflows/module/steps-b/step-02-spark.md +140 -0
  137. package/_bmad/bmb/workflows/module/steps-b/step-03-module-type.md +148 -0
  138. package/_bmad/bmb/workflows/module/steps-b/step-04-vision.md +82 -0
  139. package/_bmad/bmb/workflows/module/steps-b/step-05-identity.md +96 -0
  140. package/_bmad/bmb/workflows/module/steps-b/step-06-users.md +85 -0
  141. package/_bmad/bmb/workflows/module/steps-b/step-07-value.md +75 -0
  142. package/_bmad/bmb/workflows/module/steps-b/step-08-agents.md +96 -0
  143. package/_bmad/bmb/workflows/module/steps-b/step-09-workflows.md +82 -0
  144. package/_bmad/bmb/workflows/module/steps-b/step-10-tools.md +90 -0
  145. package/_bmad/bmb/workflows/module/steps-b/step-11-scenarios.md +83 -0
  146. package/_bmad/bmb/workflows/module/steps-b/step-12-creative.md +94 -0
  147. package/_bmad/bmb/workflows/module/steps-b/step-13-review.md +104 -0
  148. package/_bmad/bmb/workflows/module/steps-b/step-14-finalize.md +117 -0
  149. package/_bmad/bmb/workflows/module/steps-c/step-01-load-brief.md +178 -0
  150. package/_bmad/bmb/workflows/module/steps-c/step-01b-continue.md +83 -0
  151. package/_bmad/bmb/workflows/module/steps-c/step-02-structure.md +109 -0
  152. package/_bmad/bmb/workflows/module/steps-c/step-03-config.md +118 -0
  153. package/_bmad/bmb/workflows/module/steps-c/step-04-installer.md +160 -0
  154. package/_bmad/bmb/workflows/module/steps-c/step-05-agents.md +167 -0
  155. package/_bmad/bmb/workflows/module/steps-c/step-06-workflows.md +183 -0
  156. package/_bmad/bmb/workflows/module/steps-c/step-07-docs.md +402 -0
  157. package/_bmad/bmb/workflows/module/steps-c/step-08-complete.md +123 -0
  158. package/_bmad/bmb/workflows/module/steps-e/step-01-load-target.md +81 -0
  159. package/_bmad/bmb/workflows/module/steps-e/step-02-select-edit.md +77 -0
  160. package/_bmad/bmb/workflows/module/steps-e/step-03-apply-edit.md +77 -0
  161. package/_bmad/bmb/workflows/module/steps-e/step-04-review.md +80 -0
  162. package/_bmad/bmb/workflows/module/steps-e/step-05-confirm.md +75 -0
  163. package/_bmad/bmb/workflows/module/steps-v/step-01-load-target.md +96 -0
  164. package/_bmad/bmb/workflows/module/steps-v/step-02-file-structure.md +94 -0
  165. package/_bmad/bmb/workflows/module/steps-v/step-03-module-yaml.md +99 -0
  166. package/_bmad/bmb/workflows/module/steps-v/step-04-agent-specs.md +152 -0
  167. package/_bmad/bmb/workflows/module/steps-v/step-05-workflow-specs.md +152 -0
  168. package/_bmad/bmb/workflows/module/steps-v/step-06-documentation.md +143 -0
  169. package/_bmad/bmb/workflows/module/steps-v/step-07-installation.md +113 -0
  170. package/_bmad/bmb/workflows/module/steps-v/step-08-report.md +197 -0
  171. package/_bmad/bmb/workflows/module/templates/brief-template.md +154 -0
  172. package/_bmad/bmb/workflows/module/templates/workflow-spec-template.md +96 -0
  173. package/_bmad/bmb/workflows/module/workflow.md +100 -0
  174. package/_bmad/bmb/workflows/turbo-whisper/configure-workflow.md +488 -0
  175. package/_bmad/bmb/workflows/turbo-whisper/docker-setup-workflow.md +478 -0
  176. package/_bmad/bmb/workflows/turbo-whisper/install-workflow.md +426 -0
  177. package/_bmad/bmb/workflows/turbo-whisper/integrate-workflow.md +510 -0
  178. package/_bmad/bmb/workflows/workflow/data/architecture.md +152 -0
  179. package/_bmad/bmb/workflows/workflow/data/common-workflow-tools.csv +19 -0
  180. package/_bmad/bmb/workflows/workflow/data/csv-data-file-standards.md +81 -0
  181. package/_bmad/bmb/workflows/workflow/data/frontmatter-standards.md +225 -0
  182. package/_bmad/bmb/workflows/workflow/data/input-discovery-standards.md +269 -0
  183. package/_bmad/bmb/workflows/workflow/data/intent-vs-prescriptive-spectrum.md +50 -0
  184. package/_bmad/bmb/workflows/workflow/data/menu-handling-standards.md +167 -0
  185. package/_bmad/bmb/workflows/workflow/data/output-format-standards.md +188 -0
  186. package/_bmad/bmb/workflows/workflow/data/step-file-rules.md +235 -0
  187. package/_bmad/bmb/workflows/workflow/data/step-type-patterns.md +311 -0
  188. package/_bmad/bmb/workflows/workflow/data/subprocess-optimization-patterns.md +386 -0
  189. package/_bmad/bmb/workflows/workflow/data/trimodal-workflow-structure.md +209 -0
  190. package/_bmad/bmb/workflows/workflow/data/workflow-chaining-standards.md +271 -0
  191. package/_bmad/bmb/workflows/workflow/data/workflow-examples.md +276 -0
  192. package/_bmad/bmb/workflows/workflow/data/workflow-type-criteria.md +172 -0
  193. package/_bmad/bmb/workflows/workflow/steps-c/step-00-conversion.md +262 -0
  194. package/_bmad/bmb/workflows/workflow/steps-c/step-01-discovery.md +194 -0
  195. package/_bmad/bmb/workflows/workflow/steps-c/step-01b-continuation.md +3 -0
  196. package/_bmad/bmb/workflows/workflow/steps-c/step-02-classification.md +269 -0
  197. package/_bmad/bmb/workflows/workflow/steps-c/step-03-requirements.md +282 -0
  198. package/_bmad/bmb/workflows/workflow/steps-c/step-04-tools.md +281 -0
  199. package/_bmad/bmb/workflows/workflow/steps-c/step-05-plan-review.md +242 -0
  200. package/_bmad/bmb/workflows/workflow/steps-c/step-06-design.md +329 -0
  201. package/_bmad/bmb/workflows/workflow/steps-c/step-07-foundation.md +238 -0
  202. package/_bmad/bmb/workflows/workflow/steps-c/step-08-build-step-01.md +377 -0
  203. package/_bmad/bmb/workflows/workflow/steps-c/step-09-build-next-step.md +350 -0
  204. package/_bmad/bmb/workflows/workflow/steps-c/step-10-confirmation.md +320 -0
  205. package/_bmad/bmb/workflows/workflow/steps-c/step-11-completion.md +191 -0
  206. package/_bmad/bmb/workflows/workflow/steps-e/step-e-01-assess-workflow.md +237 -0
  207. package/_bmad/bmb/workflows/workflow/steps-e/step-e-02-discover-edits.md +248 -0
  208. package/_bmad/bmb/workflows/workflow/steps-e/step-e-03-fix-validation.md +252 -0
  209. package/_bmad/bmb/workflows/workflow/steps-e/step-e-04-direct-edit.md +275 -0
  210. package/_bmad/bmb/workflows/workflow/steps-e/step-e-05-apply-edit.md +154 -0
  211. package/_bmad/bmb/workflows/workflow/steps-e/step-e-06-validate-after.md +190 -0
  212. package/_bmad/bmb/workflows/workflow/steps-e/step-e-07-complete.md +206 -0
  213. package/_bmad/bmb/workflows/workflow/steps-v/step-01-validate-max-mode.md +109 -0
  214. package/_bmad/bmb/workflows/workflow/steps-v/step-01-validate.md +221 -0
  215. package/_bmad/bmb/workflows/workflow/steps-v/step-01b-structure.md +152 -0
  216. package/_bmad/bmb/workflows/workflow/steps-v/step-02-frontmatter-validation.md +199 -0
  217. package/_bmad/bmb/workflows/workflow/steps-v/step-02b-path-violations.md +265 -0
  218. package/_bmad/bmb/workflows/workflow/steps-v/step-03-menu-validation.md +164 -0
  219. package/_bmad/bmb/workflows/workflow/steps-v/step-04-step-type-validation.md +211 -0
  220. package/_bmad/bmb/workflows/workflow/steps-v/step-05-output-format-validation.md +200 -0
  221. package/_bmad/bmb/workflows/workflow/steps-v/step-06-validation-design-check.md +195 -0
  222. package/_bmad/bmb/workflows/workflow/steps-v/step-07-instruction-style-check.md +209 -0
  223. package/_bmad/bmb/workflows/workflow/steps-v/step-08-collaborative-experience-check.md +199 -0
  224. package/_bmad/bmb/workflows/workflow/steps-v/step-08b-subprocess-optimization.md +179 -0
  225. package/_bmad/bmb/workflows/workflow/steps-v/step-09-cohesive-review.md +186 -0
  226. package/_bmad/bmb/workflows/workflow/steps-v/step-10-report-complete.md +154 -0
  227. package/_bmad/bmb/workflows/workflow/steps-v/step-11-plan-validation.md +237 -0
  228. package/_bmad/bmb/workflows/workflow/templates/minimal-output-template.md +11 -0
  229. package/_bmad/bmb/workflows/workflow/templates/step-01-init-continuable-template.md +241 -0
  230. package/_bmad/bmb/workflows/workflow/templates/step-1b-template.md +223 -0
  231. package/_bmad/bmb/workflows/workflow/templates/step-template.md +290 -0
  232. package/_bmad/bmb/workflows/workflow/templates/workflow-template.md +102 -0
  233. package/_bmad/bmb/workflows/workflow/workflow.md +109 -0
  234. package/_bmad/bmm/agents/analyst.md +76 -0
  235. package/_bmad/bmm/agents/architect.md +58 -0
  236. package/_bmad/bmm/agents/dev.md +69 -0
  237. package/_bmad/bmm/agents/expert-merise-agile.md +177 -0
  238. package/_bmad/bmm/agents/pm.md +72 -0
  239. package/_bmad/bmm/agents/quick-flow-solo-dev.md +69 -0
  240. package/_bmad/bmm/agents/quinn.md +92 -0
  241. package/_bmad/bmm/agents/sm.md +70 -0
  242. package/_bmad/bmm/agents/tech-writer/tech-writer.md +70 -0
  243. package/_bmad/bmm/agents/ux-designer.md +57 -0
  244. package/_bmad/bmm/config.yaml +16 -0
  245. package/_bmad/bmm/data/project-context-template.md +26 -0
  246. package/_bmad/bmm/module-help.csv +38 -0
  247. package/_bmad/bmm/teams/default-party.csv +20 -0
  248. package/_bmad/bmm/teams/team-fullstack.yaml +12 -0
  249. package/_bmad/bmm/workflows/1-analysis/create-product-brief/product-brief.template.md +10 -0
  250. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-01-init.md +177 -0
  251. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +161 -0
  252. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +199 -0
  253. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-03-users.md +202 -0
  254. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +205 -0
  255. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +219 -0
  256. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +162 -0
  257. package/_bmad/bmm/workflows/1-analysis/create-product-brief/workflow.md +58 -0
  258. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-01-init.md +137 -0
  259. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +229 -0
  260. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +238 -0
  261. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +206 -0
  262. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +234 -0
  263. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +443 -0
  264. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
  265. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
  266. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
  267. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
  268. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
  269. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +475 -0
  270. package/_bmad/bmm/workflows/1-analysis/research/research.template.md +29 -0
  271. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-01-init.md +137 -0
  272. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +239 -0
  273. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +248 -0
  274. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +202 -0
  275. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +239 -0
  276. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +486 -0
  277. package/_bmad/bmm/workflows/1-analysis/research/workflow.md +173 -0
  278. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +13 -0
  279. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +197 -0
  280. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/project-types.csv +11 -0
  281. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01-init.md +191 -0
  282. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01b-continue.md +153 -0
  283. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02-discovery.md +224 -0
  284. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-03-success.md +226 -0
  285. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-04-journeys.md +213 -0
  286. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-05-domain.md +207 -0
  287. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-06-innovation.md +226 -0
  288. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-07-project-type.md +237 -0
  289. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-08-scoping.md +228 -0
  290. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-09-functional.md +231 -0
  291. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-10-nonfunctional.md +242 -0
  292. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-11-polish.md +217 -0
  293. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-12-complete.md +124 -0
  294. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01-discovery.md +247 -0
  295. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01b-legacy-conversion.md +208 -0
  296. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-02-review.md +249 -0
  297. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-03-edit.md +253 -0
  298. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-04-complete.md +168 -0
  299. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +218 -0
  300. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +191 -0
  301. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +209 -0
  302. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +174 -0
  303. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
  304. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +228 -0
  305. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +217 -0
  306. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
  307. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
  308. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +263 -0
  309. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +209 -0
  310. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
  311. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +242 -0
  312. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +231 -0
  313. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/templates/prd-template.md +10 -0
  314. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/validation-report-prd-workflow.md +433 -0
  315. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/workflow.md +150 -0
  316. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +135 -0
  317. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +127 -0
  318. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +190 -0
  319. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +216 -0
  320. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +219 -0
  321. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +234 -0
  322. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +252 -0
  323. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +254 -0
  324. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +224 -0
  325. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +224 -0
  326. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +241 -0
  327. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +248 -0
  328. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +237 -0
  329. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +264 -0
  330. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +171 -0
  331. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +13 -0
  332. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +43 -0
  333. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +190 -0
  334. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +178 -0
  335. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +179 -0
  336. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +139 -0
  337. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +252 -0
  338. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +135 -0
  339. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +4 -0
  340. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +55 -0
  341. package/_bmad/bmm/workflows/3-solutioning/create-architecture/architecture-decision-template.md +12 -0
  342. package/_bmad/bmm/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +11 -0
  343. package/_bmad/bmm/workflows/3-solutioning/create-architecture/data/project-types.csv +7 -0
  344. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-01-init.md +153 -0
  345. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +164 -0
  346. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-02-context.md +224 -0
  347. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +331 -0
  348. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +318 -0
  349. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +359 -0
  350. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +379 -0
  351. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +359 -0
  352. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +76 -0
  353. package/_bmad/bmm/workflows/3-solutioning/create-architecture/workflow.md +50 -0
  354. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +259 -0
  355. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +233 -0
  356. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +272 -0
  357. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +149 -0
  358. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +57 -0
  359. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +59 -0
  360. package/_bmad/bmm/workflows/4-implementation/code-review/checklist.md +23 -0
  361. package/_bmad/bmm/workflows/4-implementation/code-review/instructions.xml +227 -0
  362. package/_bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +50 -0
  363. package/_bmad/bmm/workflows/4-implementation/correct-course/checklist.md +288 -0
  364. package/_bmad/bmm/workflows/4-implementation/correct-course/instructions.md +206 -0
  365. package/_bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +58 -0
  366. package/_bmad/bmm/workflows/4-implementation/create-story/checklist.md +358 -0
  367. package/_bmad/bmm/workflows/4-implementation/create-story/instructions.xml +345 -0
  368. package/_bmad/bmm/workflows/4-implementation/create-story/template.md +49 -0
  369. package/_bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +59 -0
  370. package/_bmad/bmm/workflows/4-implementation/dev-story/checklist.md +80 -0
  371. package/_bmad/bmm/workflows/4-implementation/dev-story/instructions.xml +410 -0
  372. package/_bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +25 -0
  373. package/_bmad/bmm/workflows/4-implementation/retrospective/instructions.md +1443 -0
  374. package/_bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +57 -0
  375. package/_bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +33 -0
  376. package/_bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +225 -0
  377. package/_bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +55 -0
  378. package/_bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +53 -0
  379. package/_bmad/bmm/workflows/4-implementation/sprint-status/instructions.md +229 -0
  380. package/_bmad/bmm/workflows/4-implementation/sprint-status/workflow.yaml +35 -0
  381. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +176 -0
  382. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +120 -0
  383. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +113 -0
  384. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +113 -0
  385. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +106 -0
  386. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +149 -0
  387. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +50 -0
  388. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-01-understand.md +192 -0
  389. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-02-investigate.md +145 -0
  390. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +128 -0
  391. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +201 -0
  392. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/tech-spec-template.md +74 -0
  393. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +79 -0
  394. package/_bmad/bmm/workflows/document-project/checklist.md +245 -0
  395. package/_bmad/bmm/workflows/document-project/documentation-requirements.csv +12 -0
  396. package/_bmad/bmm/workflows/document-project/instructions.md +221 -0
  397. package/_bmad/bmm/workflows/document-project/templates/deep-dive-template.md +345 -0
  398. package/_bmad/bmm/workflows/document-project/templates/index-template.md +169 -0
  399. package/_bmad/bmm/workflows/document-project/templates/project-overview-template.md +103 -0
  400. package/_bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +160 -0
  401. package/_bmad/bmm/workflows/document-project/templates/source-tree-template.md +135 -0
  402. package/_bmad/bmm/workflows/document-project/workflow.yaml +28 -0
  403. package/_bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +298 -0
  404. package/_bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +31 -0
  405. package/_bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +1106 -0
  406. package/_bmad/bmm/workflows/document-project/workflows/full-scan.yaml +31 -0
  407. package/_bmad/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-library.json +90 -0
  408. package/_bmad/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-templates.yaml +127 -0
  409. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/checklist.md +39 -0
  410. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/instructions.md +130 -0
  411. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/workflow.yaml +26 -0
  412. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/checklist.md +43 -0
  413. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/instructions.md +141 -0
  414. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/workflow.yaml +26 -0
  415. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/checklist.md +49 -0
  416. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/instructions.md +241 -0
  417. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/workflow.yaml +26 -0
  418. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/checklist.md +38 -0
  419. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/instructions.md +133 -0
  420. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/workflow.yaml +26 -0
  421. package/_bmad/bmm/workflows/generate-project-context/project-context-template.md +21 -0
  422. package/_bmad/bmm/workflows/generate-project-context/steps/step-01-discover.md +184 -0
  423. package/_bmad/bmm/workflows/generate-project-context/steps/step-02-generate.md +318 -0
  424. package/_bmad/bmm/workflows/generate-project-context/steps/step-03-complete.md +278 -0
  425. package/_bmad/bmm/workflows/generate-project-context/workflow.md +49 -0
  426. package/_bmad/bmm/workflows/qa/automate/checklist.md +33 -0
  427. package/_bmad/bmm/workflows/qa/automate/instructions.md +110 -0
  428. package/_bmad/bmm/workflows/qa/automate/workflow.yaml +47 -0
  429. package/_bmad/cis/agents/brainstorming-coach.md +61 -0
  430. package/_bmad/cis/agents/creative-problem-solver.md +61 -0
  431. package/_bmad/cis/agents/design-thinking-coach.md +61 -0
  432. package/_bmad/cis/agents/innovation-strategist.md +61 -0
  433. package/_bmad/cis/agents/presentation-master.md +67 -0
  434. package/_bmad/cis/agents/storyteller/storyteller.md +58 -0
  435. package/_bmad/cis/config.yaml +12 -0
  436. package/_bmad/cis/module-help.csv +6 -0
  437. package/_bmad/cis/teams/creative-squad.yaml +7 -0
  438. package/_bmad/cis/teams/default-party.csv +12 -0
  439. package/_bmad/cis/workflows/README.md +139 -0
  440. package/_bmad/cis/workflows/design-thinking/README.md +56 -0
  441. package/_bmad/cis/workflows/design-thinking/design-methods.csv +31 -0
  442. package/_bmad/cis/workflows/design-thinking/instructions.md +202 -0
  443. package/_bmad/cis/workflows/design-thinking/template.md +111 -0
  444. package/_bmad/cis/workflows/design-thinking/workflow.yaml +27 -0
  445. package/_bmad/cis/workflows/innovation-strategy/README.md +56 -0
  446. package/_bmad/cis/workflows/innovation-strategy/innovation-frameworks.csv +31 -0
  447. package/_bmad/cis/workflows/innovation-strategy/instructions.md +276 -0
  448. package/_bmad/cis/workflows/innovation-strategy/template.md +189 -0
  449. package/_bmad/cis/workflows/innovation-strategy/workflow.yaml +27 -0
  450. package/_bmad/cis/workflows/problem-solving/README.md +56 -0
  451. package/_bmad/cis/workflows/problem-solving/instructions.md +252 -0
  452. package/_bmad/cis/workflows/problem-solving/solving-methods.csv +31 -0
  453. package/_bmad/cis/workflows/problem-solving/template.md +165 -0
  454. package/_bmad/cis/workflows/problem-solving/workflow.yaml +27 -0
  455. package/_bmad/cis/workflows/storytelling/README.md +58 -0
  456. package/_bmad/cis/workflows/storytelling/instructions.md +293 -0
  457. package/_bmad/cis/workflows/storytelling/story-types.csv +26 -0
  458. package/_bmad/cis/workflows/storytelling/template.md +113 -0
  459. package/_bmad/cis/workflows/storytelling/workflow.yaml +27 -0
  460. package/_bmad/core/agents/bmad-master.md +56 -0
  461. package/_bmad/core/agents/test-dynamic.md +40 -0
  462. package/_bmad/core/base/bmad-base-agent.md +42 -0
  463. package/_bmad/core/config.yaml +9 -0
  464. package/_bmad/core/module-help.csv +9 -0
  465. package/_bmad/core/resources/excalidraw/README.md +160 -0
  466. package/_bmad/core/resources/excalidraw/excalidraw-helpers.md +127 -0
  467. package/_bmad/core/resources/excalidraw/library-loader.md +50 -0
  468. package/_bmad/core/resources/excalidraw/validate-json-instructions.md +79 -0
  469. package/_bmad/core/tasks/editorial-review-prose.xml +100 -0
  470. package/_bmad/core/tasks/editorial-review-structure.xml +209 -0
  471. package/_bmad/core/tasks/help.md +62 -0
  472. package/_bmad/core/tasks/index-docs.xml +65 -0
  473. package/_bmad/core/tasks/review-adversarial-general.xml +48 -0
  474. package/_bmad/core/tasks/shard-doc.xml +109 -0
  475. package/_bmad/core/tasks/workflow.xml +235 -0
  476. package/_bmad/core/workflows/advanced-elicitation/methods.csv +51 -0
  477. package/_bmad/core/workflows/advanced-elicitation/workflow.xml +117 -0
  478. package/_bmad/core/workflows/brainstorming/brain-methods.csv +62 -0
  479. package/_bmad/core/workflows/brainstorming/steps/step-01-session-setup.md +197 -0
  480. package/_bmad/core/workflows/brainstorming/steps/step-01b-continue.md +122 -0
  481. package/_bmad/core/workflows/brainstorming/steps/step-02a-user-selected.md +225 -0
  482. package/_bmad/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +237 -0
  483. package/_bmad/core/workflows/brainstorming/steps/step-02c-random-selection.md +209 -0
  484. package/_bmad/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +264 -0
  485. package/_bmad/core/workflows/brainstorming/steps/step-03-technique-execution.md +399 -0
  486. package/_bmad/core/workflows/brainstorming/steps/step-04-idea-organization.md +303 -0
  487. package/_bmad/core/workflows/brainstorming/template.md +15 -0
  488. package/_bmad/core/workflows/brainstorming/workflow.md +58 -0
  489. package/_bmad/core/workflows/party-mode/steps/step-01-agent-loading.md +138 -0
  490. package/_bmad/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +187 -0
  491. package/_bmad/core/workflows/party-mode/steps/step-03-graceful-exit.md +157 -0
  492. package/_bmad/core/workflows/party-mode/workflow.md +194 -0
  493. package/_bmad/tea/agents/tea.md +71 -0
  494. package/_bmad/tea/config.yaml +19 -0
  495. package/_bmad/tea/module-help.csv +10 -0
  496. package/_bmad/tea/teams/default-party.csv +2 -0
  497. package/_bmad/tea/testarch/knowledge/adr-quality-readiness-checklist.md +377 -0
  498. package/_bmad/tea/testarch/knowledge/api-request.md +442 -0
  499. package/_bmad/tea/testarch/knowledge/api-testing-patterns.md +851 -0
  500. package/_bmad/tea/testarch/knowledge/auth-session.md +548 -0
  501. package/_bmad/tea/testarch/knowledge/burn-in.md +273 -0
  502. package/_bmad/tea/testarch/knowledge/ci-burn-in.md +675 -0
  503. package/_bmad/tea/testarch/knowledge/component-tdd.md +486 -0
  504. package/_bmad/tea/testarch/knowledge/contract-testing.md +957 -0
  505. package/_bmad/tea/testarch/knowledge/data-factories.md +500 -0
  506. package/_bmad/tea/testarch/knowledge/email-auth.md +721 -0
  507. package/_bmad/tea/testarch/knowledge/error-handling.md +725 -0
  508. package/_bmad/tea/testarch/knowledge/feature-flags.md +750 -0
  509. package/_bmad/tea/testarch/knowledge/file-utils.md +456 -0
  510. package/_bmad/tea/testarch/knowledge/fixture-architecture.md +401 -0
  511. package/_bmad/tea/testarch/knowledge/fixtures-composition.md +382 -0
  512. package/_bmad/tea/testarch/knowledge/intercept-network-call.md +426 -0
  513. package/_bmad/tea/testarch/knowledge/log.md +426 -0
  514. package/_bmad/tea/testarch/knowledge/network-error-monitor.md +401 -0
  515. package/_bmad/tea/testarch/knowledge/network-first.md +486 -0
  516. package/_bmad/tea/testarch/knowledge/network-recorder.md +527 -0
  517. package/_bmad/tea/testarch/knowledge/nfr-criteria.md +670 -0
  518. package/_bmad/tea/testarch/knowledge/overview.md +286 -0
  519. package/_bmad/tea/testarch/knowledge/playwright-config.md +730 -0
  520. package/_bmad/tea/testarch/knowledge/probability-impact.md +601 -0
  521. package/_bmad/tea/testarch/knowledge/recurse.md +421 -0
  522. package/_bmad/tea/testarch/knowledge/risk-governance.md +615 -0
  523. package/_bmad/tea/testarch/knowledge/selective-testing.md +732 -0
  524. package/_bmad/tea/testarch/knowledge/selector-resilience.md +527 -0
  525. package/_bmad/tea/testarch/knowledge/test-healing-patterns.md +644 -0
  526. package/_bmad/tea/testarch/knowledge/test-levels-framework.md +473 -0
  527. package/_bmad/tea/testarch/knowledge/test-priorities-matrix.md +373 -0
  528. package/_bmad/tea/testarch/knowledge/test-quality.md +664 -0
  529. package/_bmad/tea/testarch/knowledge/timing-debugging.md +372 -0
  530. package/_bmad/tea/testarch/knowledge/visual-debugging.md +524 -0
  531. package/_bmad/tea/testarch/tea-index.csv +35 -0
  532. package/_bmad/tea/workflows/testarch/README.md +74 -0
  533. package/_bmad/tea/workflows/testarch/atdd/atdd-checklist-template.md +363 -0
  534. package/_bmad/tea/workflows/testarch/atdd/checklist.md +374 -0
  535. package/_bmad/tea/workflows/testarch/atdd/instructions.md +38 -0
  536. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-01-preflight-and-context.md +110 -0
  537. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-02-generation-mode.md +79 -0
  538. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-03-test-strategy.md +76 -0
  539. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04-generate-tests.md +228 -0
  540. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04a-subprocess-api-failing.md +215 -0
  541. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04b-subprocess-e2e-failing.md +212 -0
  542. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04c-aggregate.md +329 -0
  543. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-05-validate-and-complete.md +68 -0
  544. package/_bmad/tea/workflows/testarch/atdd/steps-e/step-01-assess.md +65 -0
  545. package/_bmad/tea/workflows/testarch/atdd/steps-e/step-02-apply-edit.md +60 -0
  546. package/_bmad/tea/workflows/testarch/atdd/steps-v/step-01-validate.md +67 -0
  547. package/_bmad/tea/workflows/testarch/atdd/validation-report-20260127-095021.md +73 -0
  548. package/_bmad/tea/workflows/testarch/atdd/validation-report-20260127-102401.md +116 -0
  549. package/_bmad/tea/workflows/testarch/atdd/workflow-plan.md +21 -0
  550. package/_bmad/tea/workflows/testarch/atdd/workflow.md +39 -0
  551. package/_bmad/tea/workflows/testarch/atdd/workflow.yaml +45 -0
  552. package/_bmad/tea/workflows/testarch/automate/checklist.md +582 -0
  553. package/_bmad/tea/workflows/testarch/automate/instructions.md +43 -0
  554. package/_bmad/tea/workflows/testarch/automate/steps-c/step-01-preflight-and-context.md +127 -0
  555. package/_bmad/tea/workflows/testarch/automate/steps-c/step-02-identify-targets.md +95 -0
  556. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03-generate-tests.md +199 -0
  557. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03a-subprocess-api.md +183 -0
  558. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03b-subprocess-e2e.md +181 -0
  559. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03c-aggregate.md +300 -0
  560. package/_bmad/tea/workflows/testarch/automate/steps-c/step-04-validate-and-summarize.md +69 -0
  561. package/_bmad/tea/workflows/testarch/automate/steps-e/step-01-assess.md +65 -0
  562. package/_bmad/tea/workflows/testarch/automate/steps-e/step-02-apply-edit.md +60 -0
  563. package/_bmad/tea/workflows/testarch/automate/steps-v/step-01-validate.md +67 -0
  564. package/_bmad/tea/workflows/testarch/automate/validation-report-20260127-095021.md +72 -0
  565. package/_bmad/tea/workflows/testarch/automate/validation-report-20260127-102401.md +114 -0
  566. package/_bmad/tea/workflows/testarch/automate/workflow-plan.md +20 -0
  567. package/_bmad/tea/workflows/testarch/automate/workflow.md +39 -0
  568. package/_bmad/tea/workflows/testarch/automate/workflow.yaml +52 -0
  569. package/_bmad/tea/workflows/testarch/ci/checklist.md +247 -0
  570. package/_bmad/tea/workflows/testarch/ci/github-actions-template.yaml +198 -0
  571. package/_bmad/tea/workflows/testarch/ci/gitlab-ci-template.yaml +149 -0
  572. package/_bmad/tea/workflows/testarch/ci/instructions.md +38 -0
  573. package/_bmad/tea/workflows/testarch/ci/steps-c/step-01-preflight.md +92 -0
  574. package/_bmad/tea/workflows/testarch/ci/steps-c/step-02-generate-pipeline.md +82 -0
  575. package/_bmad/tea/workflows/testarch/ci/steps-c/step-03-configure-quality-gates.md +75 -0
  576. package/_bmad/tea/workflows/testarch/ci/steps-c/step-04-validate-and-summary.md +67 -0
  577. package/_bmad/tea/workflows/testarch/ci/steps-e/step-01-assess.md +65 -0
  578. package/_bmad/tea/workflows/testarch/ci/steps-e/step-02-apply-edit.md +60 -0
  579. package/_bmad/tea/workflows/testarch/ci/steps-v/step-01-validate.md +67 -0
  580. package/_bmad/tea/workflows/testarch/ci/validation-report-20260127-095021.md +72 -0
  581. package/_bmad/tea/workflows/testarch/ci/validation-report-20260127-102401.md +114 -0
  582. package/_bmad/tea/workflows/testarch/ci/workflow-plan.md +20 -0
  583. package/_bmad/tea/workflows/testarch/ci/workflow.md +39 -0
  584. package/_bmad/tea/workflows/testarch/ci/workflow.yaml +45 -0
  585. package/_bmad/tea/workflows/testarch/framework/checklist.md +320 -0
  586. package/_bmad/tea/workflows/testarch/framework/instructions.md +38 -0
  587. package/_bmad/tea/workflows/testarch/framework/steps-c/step-01-preflight.md +75 -0
  588. package/_bmad/tea/workflows/testarch/framework/steps-c/step-02-select-framework.md +73 -0
  589. package/_bmad/tea/workflows/testarch/framework/steps-c/step-03-scaffold-framework.md +120 -0
  590. package/_bmad/tea/workflows/testarch/framework/steps-c/step-04-docs-and-scripts.md +70 -0
  591. package/_bmad/tea/workflows/testarch/framework/steps-c/step-05-validate-and-summary.md +68 -0
  592. package/_bmad/tea/workflows/testarch/framework/steps-e/step-01-assess.md +65 -0
  593. package/_bmad/tea/workflows/testarch/framework/steps-e/step-02-apply-edit.md +60 -0
  594. package/_bmad/tea/workflows/testarch/framework/steps-v/step-01-validate.md +67 -0
  595. package/_bmad/tea/workflows/testarch/framework/validation-report-20260127-095021.md +73 -0
  596. package/_bmad/tea/workflows/testarch/framework/validation-report-20260127-102401.md +116 -0
  597. package/_bmad/tea/workflows/testarch/framework/workflow-plan.md +22 -0
  598. package/_bmad/tea/workflows/testarch/framework/workflow.md +39 -0
  599. package/_bmad/tea/workflows/testarch/framework/workflow.yaml +47 -0
  600. package/_bmad/tea/workflows/testarch/nfr-assess/checklist.md +407 -0
  601. package/_bmad/tea/workflows/testarch/nfr-assess/instructions.md +36 -0
  602. package/_bmad/tea/workflows/testarch/nfr-assess/nfr-report-template.md +462 -0
  603. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-01-load-context.md +85 -0
  604. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-02-define-thresholds.md +82 -0
  605. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-03-gather-evidence.md +64 -0
  606. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04-evaluate-and-score.md +140 -0
  607. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04a-subprocess-security.md +138 -0
  608. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04b-subprocess-performance.md +84 -0
  609. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04c-subprocess-reliability.md +85 -0
  610. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04d-subprocess-scalability.md +88 -0
  611. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04e-aggregate-nfr.md +219 -0
  612. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-05-generate-report.md +71 -0
  613. package/_bmad/tea/workflows/testarch/nfr-assess/steps-e/step-01-assess.md +65 -0
  614. package/_bmad/tea/workflows/testarch/nfr-assess/steps-e/step-02-apply-edit.md +60 -0
  615. package/_bmad/tea/workflows/testarch/nfr-assess/steps-v/step-01-validate.md +67 -0
  616. package/_bmad/tea/workflows/testarch/nfr-assess/validation-report-20260127-095021.md +73 -0
  617. package/_bmad/tea/workflows/testarch/nfr-assess/validation-report-20260127-102401.md +116 -0
  618. package/_bmad/tea/workflows/testarch/nfr-assess/workflow-plan.md +19 -0
  619. package/_bmad/tea/workflows/testarch/nfr-assess/workflow.md +39 -0
  620. package/_bmad/tea/workflows/testarch/nfr-assess/workflow.yaml +47 -0
  621. package/_bmad/tea/workflows/testarch/teach-me-testing/checklist.md +197 -0
  622. package/_bmad/tea/workflows/testarch/teach-me-testing/data/curriculum.yaml +129 -0
  623. package/_bmad/tea/workflows/testarch/teach-me-testing/data/quiz-questions.yaml +206 -0
  624. package/_bmad/tea/workflows/testarch/teach-me-testing/data/role-paths.yaml +136 -0
  625. package/_bmad/tea/workflows/testarch/teach-me-testing/data/session-content-map.yaml +204 -0
  626. package/_bmad/tea/workflows/testarch/teach-me-testing/data/tea-resources-index.yaml +359 -0
  627. package/_bmad/tea/workflows/testarch/teach-me-testing/instructions.md +130 -0
  628. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-01-init.md +235 -0
  629. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-01b-continue.md +147 -0
  630. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-02-assess.md +258 -0
  631. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-03-session-menu.md +219 -0
  632. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-01.md +460 -0
  633. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-02.md +465 -0
  634. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-03.md +301 -0
  635. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-04.md +234 -0
  636. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-05.md +234 -0
  637. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-06.md +209 -0
  638. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-07.md +212 -0
  639. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-05-completion.md +339 -0
  640. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-e/step-e-01-assess-workflow.md +141 -0
  641. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-e/step-e-02-apply-edits.md +122 -0
  642. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-v/step-v-01-validate.md +263 -0
  643. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/certificate-template.md +86 -0
  644. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/progress-template.yaml +95 -0
  645. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/session-notes-template.md +83 -0
  646. package/_bmad/tea/workflows/testarch/teach-me-testing/workflow-plan-teach-me-testing.md +950 -0
  647. package/_bmad/tea/workflows/testarch/teach-me-testing/workflow.md +90 -0
  648. package/_bmad/tea/workflows/testarch/test-design/checklist.md +410 -0
  649. package/_bmad/tea/workflows/testarch/test-design/instructions.md +52 -0
  650. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-01-detect-mode.md +109 -0
  651. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-02-load-context.md +127 -0
  652. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-03-risk-and-testability.md +85 -0
  653. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-04-coverage-plan.md +98 -0
  654. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-05-generate-output.md +97 -0
  655. package/_bmad/tea/workflows/testarch/test-design/steps-e/step-01-assess.md +65 -0
  656. package/_bmad/tea/workflows/testarch/test-design/steps-e/step-02-apply-edit.md +60 -0
  657. package/_bmad/tea/workflows/testarch/test-design/steps-v/step-01-validate.md +67 -0
  658. package/_bmad/tea/workflows/testarch/test-design/test-design-architecture-template.md +222 -0
  659. package/_bmad/tea/workflows/testarch/test-design/test-design-qa-template.md +296 -0
  660. package/_bmad/tea/workflows/testarch/test-design/test-design-template.md +294 -0
  661. package/_bmad/tea/workflows/testarch/test-design/validation-report-20260127-095021.md +73 -0
  662. package/_bmad/tea/workflows/testarch/test-design/validation-report-20260127-102401.md +116 -0
  663. package/_bmad/tea/workflows/testarch/test-design/workflow-plan.md +22 -0
  664. package/_bmad/tea/workflows/testarch/test-design/workflow.md +39 -0
  665. package/_bmad/tea/workflows/testarch/test-design/workflow.yaml +69 -0
  666. package/_bmad/tea/workflows/testarch/test-review/checklist.md +472 -0
  667. package/_bmad/tea/workflows/testarch/test-review/instructions.md +36 -0
  668. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-01-load-context.md +101 -0
  669. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-02-discover-tests.md +69 -0
  670. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03-quality-evaluation.md +184 -0
  671. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03a-subprocess-determinism.md +214 -0
  672. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03b-subprocess-isolation.md +125 -0
  673. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03c-subprocess-maintainability.md +102 -0
  674. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03d-subprocess-coverage.md +111 -0
  675. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03e-subprocess-performance.md +117 -0
  676. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03f-aggregate-scores.md +246 -0
  677. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-04-generate-report.md +72 -0
  678. package/_bmad/tea/workflows/testarch/test-review/steps-e/step-01-assess.md +65 -0
  679. package/_bmad/tea/workflows/testarch/test-review/steps-e/step-02-apply-edit.md +60 -0
  680. package/_bmad/tea/workflows/testarch/test-review/steps-v/step-01-validate.md +67 -0
  681. package/_bmad/tea/workflows/testarch/test-review/test-review-template.md +390 -0
  682. package/_bmad/tea/workflows/testarch/test-review/validation-report-20260127-095021.md +72 -0
  683. package/_bmad/tea/workflows/testarch/test-review/validation-report-20260127-102401.md +114 -0
  684. package/_bmad/tea/workflows/testarch/test-review/workflow-plan.md +18 -0
  685. package/_bmad/tea/workflows/testarch/test-review/workflow.md +39 -0
  686. package/_bmad/tea/workflows/testarch/test-review/workflow.yaml +46 -0
  687. package/_bmad/tea/workflows/testarch/trace/checklist.md +642 -0
  688. package/_bmad/tea/workflows/testarch/trace/instructions.md +36 -0
  689. package/_bmad/tea/workflows/testarch/trace/steps-c/step-01-load-context.md +80 -0
  690. package/_bmad/tea/workflows/testarch/trace/steps-c/step-02-discover-tests.md +69 -0
  691. package/_bmad/tea/workflows/testarch/trace/steps-c/step-03-map-criteria.md +65 -0
  692. package/_bmad/tea/workflows/testarch/trace/steps-c/step-04-analyze-gaps.md +244 -0
  693. package/_bmad/tea/workflows/testarch/trace/steps-c/step-05-gate-decision.md +232 -0
  694. package/_bmad/tea/workflows/testarch/trace/steps-e/step-01-assess.md +65 -0
  695. package/_bmad/tea/workflows/testarch/trace/steps-e/step-02-apply-edit.md +60 -0
  696. package/_bmad/tea/workflows/testarch/trace/steps-v/step-01-validate.md +67 -0
  697. package/_bmad/tea/workflows/testarch/trace/trace-template.md +675 -0
  698. package/_bmad/tea/workflows/testarch/trace/validation-report-20260127-095021.md +73 -0
  699. package/_bmad/tea/workflows/testarch/trace/validation-report-20260127-102401.md +116 -0
  700. package/_bmad/tea/workflows/testarch/trace/workflow-plan.md +21 -0
  701. package/_bmad/tea/workflows/testarch/trace/workflow.md +39 -0
  702. package/_bmad/tea/workflows/testarch/trace/workflow.yaml +55 -0
  703. package/install/.eslintrc.js +20 -0
  704. package/install/.prettierrc +7 -0
  705. package/install/BUGFIX-CHALK.md +173 -0
  706. package/install/BUGFIX-DOCUMENTATION-INDEX.md +299 -0
  707. package/install/BUGFIX-PATH-RESOLUTION.md +293 -0
  708. package/install/BUGFIX-QUICKSTART.md +184 -0
  709. package/install/BUGFIX-SUMMARY.txt +91 -0
  710. package/install/BUGFIX-VISUAL-SUMMARY.md +253 -0
  711. package/install/DEPLOYMENT-GUIDE-V2.md +431 -0
  712. package/install/DOCS-INDEX.md +261 -0
  713. package/install/GUIDE-INSTALLATION-BYAN-SIMPLE.md +1083 -0
  714. package/install/INSTALLER-V2-CHANGES.md +472 -0
  715. package/install/PUBLICATION-CHECKLIST.md +265 -0
  716. package/install/PUBLISH-GUIDE.md +190 -0
  717. package/install/QUICKSTART.md +311 -0
  718. package/install/README-NPM-SHORT.md +298 -0
  719. package/install/README-NPM.md +433 -0
  720. package/install/README-RACHID.md +302 -0
  721. package/install/README-V2-INDEX.md +306 -0
  722. package/install/README.md +298 -0
  723. package/install/RESUME-EXECUTIF-YAN.md +408 -0
  724. package/install/UPDATE-SUMMARY.md +205 -0
  725. package/install/__tests__/integration/detection-flow.test.js +154 -0
  726. package/install/__tests__/platforms/claude-code.test.js +175 -0
  727. package/install/__tests__/platforms/codex.test.js +80 -0
  728. package/install/__tests__/platforms/copilot-cli.test.js +118 -0
  729. package/install/__tests__/platforms/vscode.test.js +67 -0
  730. package/install/__tests__/utils/file-utils.test.js +87 -0
  731. package/install/__tests__/utils/git-detector.test.js +80 -0
  732. package/install/__tests__/utils/logger.test.js +83 -0
  733. package/install/__tests__/utils/node-detector.test.js +71 -0
  734. package/install/__tests__/utils/os-detector.test.js +63 -0
  735. package/install/__tests__/utils/yaml-utils.test.js +85 -0
  736. package/install/__tests__/yanstaller/detector.test.js +210 -0
  737. package/install/coverage/clover.xml +219 -0
  738. package/install/coverage/coverage-final.json +13 -0
  739. package/install/coverage/lcov-report/base.css +224 -0
  740. package/install/coverage/lcov-report/block-navigation.js +87 -0
  741. package/install/coverage/lcov-report/favicon.png +0 -0
  742. package/install/coverage/lcov-report/index.html +146 -0
  743. package/install/coverage/lcov-report/lib/errors.js.html +268 -0
  744. package/install/coverage/lcov-report/lib/exit-codes.js.html +247 -0
  745. package/install/coverage/lcov-report/lib/index.html +131 -0
  746. package/install/coverage/lcov-report/lib/platforms/claude-code.js.html +343 -0
  747. package/install/coverage/lcov-report/lib/platforms/codex.js.html +361 -0
  748. package/install/coverage/lcov-report/lib/platforms/copilot-cli.js.html +454 -0
  749. package/install/coverage/lcov-report/lib/platforms/index.html +176 -0
  750. package/install/coverage/lcov-report/lib/platforms/index.js.html +127 -0
  751. package/install/coverage/lcov-report/lib/platforms/vscode.js.html +238 -0
  752. package/install/coverage/lcov-report/lib/utils/config-loader.js.html +322 -0
  753. package/install/coverage/lcov-report/lib/utils/file-utils.js.html +397 -0
  754. package/install/coverage/lcov-report/lib/utils/git-detector.js.html +190 -0
  755. package/install/coverage/lcov-report/lib/utils/index.html +206 -0
  756. package/install/coverage/lcov-report/lib/utils/logger.js.html +277 -0
  757. package/install/coverage/lcov-report/lib/utils/node-detector.js.html +259 -0
  758. package/install/coverage/lcov-report/lib/utils/os-detector.js.html +307 -0
  759. package/install/coverage/lcov-report/lib/utils/yaml-utils.js.html +346 -0
  760. package/install/coverage/lcov-report/lib/yanstaller/backuper.js.html +409 -0
  761. package/install/coverage/lcov-report/lib/yanstaller/detector.js.html +508 -0
  762. package/install/coverage/lcov-report/lib/yanstaller/index.html +236 -0
  763. package/install/coverage/lcov-report/lib/yanstaller/index.js.html +364 -0
  764. package/install/coverage/lcov-report/lib/yanstaller/installer.js.html +505 -0
  765. package/install/coverage/lcov-report/lib/yanstaller/interviewer.js.html +349 -0
  766. package/install/coverage/lcov-report/lib/yanstaller/recommender.js.html +379 -0
  767. package/install/coverage/lcov-report/lib/yanstaller/troubleshooter.js.html +352 -0
  768. package/install/coverage/lcov-report/lib/yanstaller/validator.js.html +679 -0
  769. package/install/coverage/lcov-report/lib/yanstaller/wizard.js.html +412 -0
  770. package/install/coverage/lcov-report/platforms/claude-code.js.html +343 -0
  771. package/install/coverage/lcov-report/platforms/codex.js.html +361 -0
  772. package/install/coverage/lcov-report/platforms/copilot-cli.js.html +454 -0
  773. package/install/coverage/lcov-report/platforms/index.html +176 -0
  774. package/install/coverage/lcov-report/platforms/index.js.html +127 -0
  775. package/install/coverage/lcov-report/platforms/vscode.js.html +238 -0
  776. package/install/coverage/lcov-report/prettify.css +1 -0
  777. package/install/coverage/lcov-report/prettify.js +2 -0
  778. package/install/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  779. package/install/coverage/lcov-report/sorter.js +210 -0
  780. package/install/coverage/lcov-report/utils/file-utils.js.html +397 -0
  781. package/install/coverage/lcov-report/utils/git-detector.js.html +190 -0
  782. package/install/coverage/lcov-report/utils/index.html +191 -0
  783. package/install/coverage/lcov-report/utils/logger.js.html +277 -0
  784. package/install/coverage/lcov-report/utils/node-detector.js.html +259 -0
  785. package/install/coverage/lcov-report/utils/os-detector.js.html +307 -0
  786. package/install/coverage/lcov-report/utils/yaml-utils.js.html +346 -0
  787. package/install/coverage/lcov-report/yanstaller/detector.js.html +508 -0
  788. package/install/coverage/lcov-report/yanstaller/index.html +116 -0
  789. package/install/coverage/lcov.info +414 -0
  790. package/install/install.sh +239 -0
  791. package/install/jest.config.js +33 -0
  792. package/install/lib/errors.js +61 -0
  793. package/install/lib/exit-codes.js +54 -0
  794. package/install/lib/platforms/claude-code.js +86 -0
  795. package/install/lib/platforms/codex.js +92 -0
  796. package/install/lib/platforms/copilot-cli.js +123 -0
  797. package/install/lib/platforms/index.js +14 -0
  798. package/install/lib/platforms/vscode.js +51 -0
  799. package/install/lib/utils/config-loader.js +79 -0
  800. package/install/lib/utils/file-utils.js +104 -0
  801. package/install/lib/utils/git-detector.js +35 -0
  802. package/install/lib/utils/logger.js +64 -0
  803. package/install/lib/utils/node-detector.js +58 -0
  804. package/install/lib/utils/os-detector.js +74 -0
  805. package/install/lib/utils/yaml-utils.js +87 -0
  806. package/install/lib/yanstaller/backuper.js +108 -0
  807. package/install/lib/yanstaller/detector.js +141 -0
  808. package/install/lib/yanstaller/index.js +93 -0
  809. package/install/lib/yanstaller/installer.js +140 -0
  810. package/install/lib/yanstaller/interviewer.js +88 -0
  811. package/install/lib/yanstaller/recommender.js +98 -0
  812. package/install/lib/yanstaller/troubleshooter.js +89 -0
  813. package/install/lib/yanstaller/validator.js +198 -0
  814. package/install/lib/yanstaller/wizard.js +109 -0
  815. package/install/package-npm.json +55 -0
  816. package/install/package.json +63 -0
  817. package/install/src/byan-v2/context/copilot-context.js +79 -0
  818. package/install/src/byan-v2/context/session-state.js +98 -0
  819. package/install/src/byan-v2/dispatcher/complexity-scorer.js +232 -0
  820. package/install/src/byan-v2/dispatcher/local-executor.js +221 -0
  821. package/install/src/byan-v2/dispatcher/task-router.js +122 -0
  822. package/install/src/byan-v2/dispatcher/task-tool-interface-mock.js +134 -0
  823. package/install/src/byan-v2/dispatcher/task-tool-interface.js +123 -0
  824. package/install/src/byan-v2/generation/agent-profile-validator.js +113 -0
  825. package/install/src/byan-v2/generation/profile-template.js +113 -0
  826. package/install/src/byan-v2/generation/templates/default-agent.md +49 -0
  827. package/install/src/byan-v2/generation/templates/test-template.md +1 -0
  828. package/install/src/byan-v2/index.js +199 -0
  829. package/install/src/byan-v2/observability/error-tracker.js +105 -0
  830. package/install/src/byan-v2/observability/logger.js +154 -0
  831. package/install/src/byan-v2/observability/metrics-collector.js +194 -0
  832. package/install/src/byan-v2/orchestrator/analysis-state.js +268 -0
  833. package/install/src/byan-v2/orchestrator/generation-state.js +340 -0
  834. package/install/src/byan-v2/orchestrator/interview-state.js +271 -0
  835. package/install/src/byan-v2/orchestrator/state-machine.js +204 -0
  836. package/install/src/core/cache/cache.js +126 -0
  837. package/install/src/core/context/context.js +86 -0
  838. package/install/src/core/dispatcher/dispatcher.js +135 -0
  839. package/install/src/core/worker-pool/worker-pool.js +194 -0
  840. package/install/src/core/workflow/workflow-executor.js +220 -0
  841. package/install/src/index.js +139 -0
  842. package/install/src/observability/dashboard/dashboard.js +191 -0
  843. package/install/src/observability/logger/structured-logger.js +254 -0
  844. package/install/src/observability/metrics/metrics-collector.js +325 -0
  845. package/install/switch-to-v2.sh +126 -0
  846. package/install/templates/.github/agents/bmad-agent-bmb-agent-builder.md +15 -0
  847. package/install/templates/.github/agents/bmad-agent-bmb-module-builder.md +15 -0
  848. package/install/templates/.github/agents/bmad-agent-bmb-workflow-builder.md +15 -0
  849. package/install/templates/.github/agents/bmad-agent-bmm-analyst.md +15 -0
  850. package/install/templates/.github/agents/bmad-agent-bmm-architect.md +15 -0
  851. package/install/templates/.github/agents/bmad-agent-bmm-dev.md +15 -0
  852. package/install/templates/.github/agents/bmad-agent-bmm-pm.md +15 -0
  853. package/install/templates/.github/agents/bmad-agent-bmm-quick-flow-solo-dev.md +15 -0
  854. package/install/templates/.github/agents/bmad-agent-bmm-quinn.md +15 -0
  855. package/install/templates/.github/agents/bmad-agent-bmm-sm.md +15 -0
  856. package/install/templates/.github/agents/bmad-agent-bmm-tech-writer.md +15 -0
  857. package/install/templates/.github/agents/bmad-agent-bmm-ux-designer.md +15 -0
  858. package/install/templates/.github/agents/bmad-agent-byan-test.md +32 -0
  859. package/install/templates/.github/agents/bmad-agent-carmack.md +18 -0
  860. package/install/templates/.github/agents/bmad-agent-cis-brainstorming-coach.md +15 -0
  861. package/install/templates/.github/agents/bmad-agent-cis-creative-problem-solver.md +15 -0
  862. package/install/templates/.github/agents/bmad-agent-cis-design-thinking-coach.md +15 -0
  863. package/install/templates/.github/agents/bmad-agent-cis-innovation-strategist.md +15 -0
  864. package/install/templates/.github/agents/bmad-agent-cis-presentation-master.md +15 -0
  865. package/install/templates/.github/agents/bmad-agent-cis-storyteller.md +15 -0
  866. package/install/templates/.github/agents/bmad-agent-patnote.md +48 -0
  867. package/install/templates/.github/agents/bmad-agent-rachid.md +47 -0
  868. package/install/templates/.github/agents/bmad-agent-tea-tea.md +15 -0
  869. package/install/templates/_bmad/bmb/agents/agent-builder.md +59 -0
  870. package/install/templates/_bmad/bmb/agents/byan-test.md +116 -0
  871. package/install/templates/_bmad/bmb/agents/byan.md +215 -0
  872. package/install/templates/_bmad/bmb/agents/module-builder.md +60 -0
  873. package/install/templates/_bmad/bmb/agents/patnote.md +495 -0
  874. package/install/templates/_bmad/bmb/agents/rachid.md +184 -0
  875. package/install/templates/_bmad/bmb/agents/workflow-builder.md +61 -0
  876. package/install/templates/_bmad/bmb/workflows/byan/data/mantras.yaml +272 -0
  877. package/install/templates/_bmad/bmb/workflows/byan/data/templates.yaml +59 -0
  878. package/install/templates/_bmad/bmb/workflows/byan/delete-agent-workflow.md +657 -0
  879. package/install/templates/_bmad/bmb/workflows/byan/edit-agent-workflow.md +688 -0
  880. package/install/templates/_bmad/bmb/workflows/byan/interview-workflow.md +753 -0
  881. package/install/templates/_bmad/bmb/workflows/byan/quick-create-workflow.md +450 -0
  882. package/install/templates/_bmad/bmb/workflows/byan/templates/base-agent-template.md +79 -0
  883. package/install/templates/_bmad/bmb/workflows/byan/validate-agent-workflow.md +676 -0
  884. package/install/templates/_bmad/core/agents/carmack.md +238 -0
  885. package/install/test-chalk-fix.sh +210 -0
  886. package/install/test-installer-v2.sh +204 -0
  887. package/install/test-path-resolution.sh +200 -0
  888. package/package.json +51 -33
  889. package/src/byan-v2/context/copilot-context.js +79 -0
  890. package/src/byan-v2/context/session-state.js +98 -0
  891. package/src/byan-v2/data/mantras.json +852 -0
  892. package/src/byan-v2/dispatcher/complexity-scorer.js +232 -0
  893. package/src/byan-v2/dispatcher/five-whys-analyzer.js +310 -0
  894. package/src/byan-v2/dispatcher/local-executor.js +221 -0
  895. package/src/byan-v2/dispatcher/task-router.js +122 -0
  896. package/src/byan-v2/dispatcher/task-tool-interface-mock.js +134 -0
  897. package/src/byan-v2/dispatcher/task-tool-interface.js +123 -0
  898. package/src/byan-v2/generation/agent-profile-validator.js +113 -0
  899. package/src/byan-v2/generation/mantra-validator.js +416 -0
  900. package/src/byan-v2/generation/profile-template.js +113 -0
  901. package/src/byan-v2/generation/templates/default-agent.md +49 -0
  902. package/src/byan-v2/generation/templates/test-template.md +1 -0
  903. package/src/byan-v2/index.js +652 -0
  904. package/src/byan-v2/integration/voice-integration.js +295 -0
  905. package/src/byan-v2/observability/error-tracker.js +105 -0
  906. package/src/byan-v2/observability/logger.js +154 -0
  907. package/src/byan-v2/observability/metrics-collector.js +194 -0
  908. package/src/byan-v2/orchestrator/active-listener.js +541 -0
  909. package/src/byan-v2/orchestrator/analysis-state.js +268 -0
  910. package/src/byan-v2/orchestrator/generation-state.js +340 -0
  911. package/src/byan-v2/orchestrator/glossary-builder.js +431 -0
  912. package/src/byan-v2/orchestrator/interview-state.js +353 -0
  913. package/src/byan-v2/orchestrator/state-machine.js +253 -0
  914. package/src/core/cache/cache.js +126 -0
  915. package/src/core/context/context.js +86 -0
  916. package/src/core/dispatcher/dispatcher.js +135 -0
  917. package/src/core/worker-pool/worker-pool.js +194 -0
  918. package/src/core/workflow/workflow-executor.js +220 -0
  919. package/src/index.js +139 -0
  920. package/src/observability/dashboard/dashboard.js +191 -0
  921. package/src/observability/logger/structured-logger.js +254 -0
  922. package/src/observability/metrics/metrics-collector.js +325 -0
  923. /package/{templates/.github → .github}/agents/bmad-agent-bmb-agent-builder.md +0 -0
  924. /package/{templates/.github → .github}/agents/bmad-agent-bmb-module-builder.md +0 -0
  925. /package/{templates/.github → .github}/agents/bmad-agent-bmb-workflow-builder.md +0 -0
  926. /package/{templates/.github → .github}/agents/bmad-agent-bmm-analyst.md +0 -0
  927. /package/{templates/.github → .github}/agents/bmad-agent-bmm-architect.md +0 -0
  928. /package/{templates/.github → .github}/agents/bmad-agent-bmm-dev.md +0 -0
  929. /package/{templates/.github → .github}/agents/bmad-agent-bmm-pm.md +0 -0
  930. /package/{templates/.github → .github}/agents/bmad-agent-bmm-quick-flow-solo-dev.md +0 -0
  931. /package/{templates/.github → .github}/agents/bmad-agent-bmm-quinn.md +0 -0
  932. /package/{templates/.github → .github}/agents/bmad-agent-bmm-sm.md +0 -0
  933. /package/{templates/.github → .github}/agents/bmad-agent-bmm-tech-writer.md +0 -0
  934. /package/{templates/.github → .github}/agents/bmad-agent-bmm-ux-designer.md +0 -0
  935. /package/{templates/.github → .github}/agents/bmad-agent-byan-test.md +0 -0
  936. /package/{templates/.github → .github}/agents/bmad-agent-carmack.md +0 -0
  937. /package/{templates/.github → .github}/agents/bmad-agent-cis-brainstorming-coach.md +0 -0
  938. /package/{templates/.github → .github}/agents/bmad-agent-cis-creative-problem-solver.md +0 -0
  939. /package/{templates/.github → .github}/agents/bmad-agent-cis-design-thinking-coach.md +0 -0
  940. /package/{templates/.github → .github}/agents/bmad-agent-cis-innovation-strategist.md +0 -0
  941. /package/{templates/.github → .github}/agents/bmad-agent-cis-presentation-master.md +0 -0
  942. /package/{templates/.github → .github}/agents/bmad-agent-cis-storyteller.md +0 -0
  943. /package/{templates/.github → .github}/agents/bmad-agent-patnote.md +0 -0
  944. /package/{templates/.github → .github}/agents/bmad-agent-rachid.md +0 -0
  945. /package/{templates/.github → .github}/agents/bmad-agent-tea-tea.md +0 -0
  946. /package/{templates/.github → .github}/agents/bmad-agent-test-dynamic.md +0 -0
  947. /package/{templates/.github → .github}/agents/franck.md +0 -0
  948. /package/{templates/_bmad → _bmad}/bmb/agents/agent-builder.md +0 -0
  949. /package/{templates/_bmad → _bmad}/bmb/agents/byan-test.md +0 -0
  950. /package/{templates/_bmad/bmb/agents/byan.md → _bmad/bmb/agents/byan.backup.20260202_212559.md} +0 -0
  951. /package/{templates/_bmad → _bmad}/bmb/agents/module-builder.md +0 -0
  952. /package/{templates/_bmad → _bmad}/bmb/agents/patnote.md +0 -0
  953. /package/{templates/_bmad → _bmad}/bmb/agents/rachid.md +0 -0
  954. /package/{templates/_bmad → _bmad}/bmb/agents/workflow-builder.md +0 -0
  955. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/data/mantras.yaml +0 -0
  956. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/data/templates.yaml +0 -0
  957. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/delete-agent-workflow.md +0 -0
  958. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/edit-agent-workflow.md +0 -0
  959. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/interview-workflow.md +0 -0
  960. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/quick-create-workflow.md +0 -0
  961. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/templates/base-agent-template.md +0 -0
  962. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/validate-agent-workflow.md +0 -0
  963. /package/{templates/_bmad → _bmad}/core/agents/carmack.md +0 -0
  964. /package/{CHANGELOG.md → install/CHANGELOG.md} +0 -0
  965. /package/{LICENSE → install/LICENSE} +0 -0
  966. /package/{README.md → install/README-NPM-PUBLISH.md} +0 -0
  967. /package/{bin → install/bin}/create-byan-agent-backup.js +0 -0
  968. /package/{bin → install/bin}/create-byan-agent-fixed.js +0 -0
  969. /package/{bin → install/bin}/create-byan-agent-v2.js +0 -0
  970. /package/{bin → install/bin}/create-byan-agent.js +0 -0
  971. /package/{templates → install/templates}/.github/agents/bmad-agent-bmad-master.md +0 -0
  972. /package/{templates → install/templates}/.github/agents/bmad-agent-byan.md +0 -0
  973. /package/{templates → install/templates}/.github/agents/bmad-agent-marc.md +0 -0
  974. /package/{templates → install/templates}/_bmad/bmb/agents/marc.md +0 -0
@@ -0,0 +1,957 @@
1
+ # Contract Testing Essentials (Pact)
2
+
3
+ ## Principle
4
+
5
+ Contract testing validates API contracts between consumer and provider services without requiring integrated end-to-end tests. Store consumer contracts alongside integration specs, version contracts semantically, and publish on every CI run. Provider verification before merge surfaces breaking changes immediately, while explicit fallback behavior (timeouts, retries, error payloads) captures resilience guarantees in contracts.
6
+
7
+ ## Rationale
8
+
9
+ Traditional integration testing requires running both consumer and provider simultaneously, creating slow, flaky tests with complex setup. Contract testing decouples services: consumers define expectations (pact files), providers verify against those expectations independently. This enables parallel development, catches breaking changes early, and documents API behavior as executable specifications. Pair contract tests with API smoke tests to validate data mapping and UI rendering in tandem.
10
+
11
+ ## Pattern Examples
12
+
13
+ ### Example 1: Pact Consumer Test (Frontend → Backend API)
14
+
15
+ **Context**: React application consuming a user management API, defining expected interactions.
16
+
17
+ **Implementation**:
18
+
19
+ ```typescript
20
+ // tests/contract/user-api.pact.spec.ts
21
+ import { PactV3, MatchersV3 } from '@pact-foundation/pact';
22
+ import { getUserById, createUser, User } from '@/api/user-service';
23
+
24
+ const { like, eachLike, string, integer } = MatchersV3;
25
+
26
+ /**
27
+ * Consumer-Driven Contract Test
28
+ * - Consumer (React app) defines expected API behavior
29
+ * - Generates pact file for provider to verify
30
+ * - Runs in isolation (no real backend required)
31
+ */
32
+
33
+ const provider = new PactV3({
34
+ consumer: 'user-management-web',
35
+ provider: 'user-api-service',
36
+ dir: './pacts', // Output directory for pact files
37
+ logLevel: 'warn',
38
+ });
39
+
40
+ describe('User API Contract', () => {
41
+ describe('GET /users/:id', () => {
42
+ it('should return user when user exists', async () => {
43
+ // Arrange: Define expected interaction
44
+ await provider
45
+ .given('user with id 1 exists') // Provider state
46
+ .uponReceiving('a request for user 1')
47
+ .withRequest({
48
+ method: 'GET',
49
+ path: '/users/1',
50
+ headers: {
51
+ Accept: 'application/json',
52
+ Authorization: like('Bearer token123'), // Matcher: any string
53
+ },
54
+ })
55
+ .willRespondWith({
56
+ status: 200,
57
+ headers: {
58
+ 'Content-Type': 'application/json',
59
+ },
60
+ body: like({
61
+ id: integer(1),
62
+ name: string('John Doe'),
63
+ email: string('john@example.com'),
64
+ role: string('user'),
65
+ createdAt: string('2025-01-15T10:00:00Z'),
66
+ }),
67
+ })
68
+ .executeTest(async (mockServer) => {
69
+ // Act: Call consumer code against mock server
70
+ const user = await getUserById(1, {
71
+ baseURL: mockServer.url,
72
+ headers: { Authorization: 'Bearer token123' },
73
+ });
74
+
75
+ // Assert: Validate consumer behavior
76
+ expect(user).toEqual(
77
+ expect.objectContaining({
78
+ id: 1,
79
+ name: 'John Doe',
80
+ email: 'john@example.com',
81
+ role: 'user',
82
+ }),
83
+ );
84
+ });
85
+ });
86
+
87
+ it('should handle 404 when user does not exist', async () => {
88
+ await provider
89
+ .given('user with id 999 does not exist')
90
+ .uponReceiving('a request for non-existent user')
91
+ .withRequest({
92
+ method: 'GET',
93
+ path: '/users/999',
94
+ headers: { Accept: 'application/json' },
95
+ })
96
+ .willRespondWith({
97
+ status: 404,
98
+ headers: { 'Content-Type': 'application/json' },
99
+ body: {
100
+ error: 'User not found',
101
+ code: 'USER_NOT_FOUND',
102
+ },
103
+ })
104
+ .executeTest(async (mockServer) => {
105
+ // Act & Assert: Consumer handles 404 gracefully
106
+ await expect(getUserById(999, { baseURL: mockServer.url })).rejects.toThrow('User not found');
107
+ });
108
+ });
109
+ });
110
+
111
+ describe('POST /users', () => {
112
+ it('should create user and return 201', async () => {
113
+ const newUser: Omit<User, 'id' | 'createdAt'> = {
114
+ name: 'Jane Smith',
115
+ email: 'jane@example.com',
116
+ role: 'admin',
117
+ };
118
+
119
+ await provider
120
+ .given('no users exist')
121
+ .uponReceiving('a request to create a user')
122
+ .withRequest({
123
+ method: 'POST',
124
+ path: '/users',
125
+ headers: {
126
+ 'Content-Type': 'application/json',
127
+ Accept: 'application/json',
128
+ },
129
+ body: like(newUser),
130
+ })
131
+ .willRespondWith({
132
+ status: 201,
133
+ headers: { 'Content-Type': 'application/json' },
134
+ body: like({
135
+ id: integer(2),
136
+ name: string('Jane Smith'),
137
+ email: string('jane@example.com'),
138
+ role: string('admin'),
139
+ createdAt: string('2025-01-15T11:00:00Z'),
140
+ }),
141
+ })
142
+ .executeTest(async (mockServer) => {
143
+ const createdUser = await createUser(newUser, {
144
+ baseURL: mockServer.url,
145
+ });
146
+
147
+ expect(createdUser).toEqual(
148
+ expect.objectContaining({
149
+ id: expect.any(Number),
150
+ name: 'Jane Smith',
151
+ email: 'jane@example.com',
152
+ role: 'admin',
153
+ }),
154
+ );
155
+ });
156
+ });
157
+ });
158
+ });
159
+ ```
160
+
161
+ **package.json scripts**:
162
+
163
+ ```json
164
+ {
165
+ "scripts": {
166
+ "test:contract": "jest tests/contract --testTimeout=30000",
167
+ "pact:publish": "pact-broker publish ./pacts --consumer-app-version=$GIT_SHA --broker-base-url=$PACT_BROKER_URL --broker-token=$PACT_BROKER_TOKEN"
168
+ }
169
+ }
170
+ ```
171
+
172
+ **Key Points**:
173
+
174
+ - **Consumer-driven**: Frontend defines expectations, not backend
175
+ - **Matchers**: `like`, `string`, `integer` for flexible matching
176
+ - **Provider states**: given() sets up test preconditions
177
+ - **Isolation**: No real backend needed, runs fast
178
+ - **Pact generation**: Automatically creates JSON pact files
179
+
180
+ ---
181
+
182
+ ### Example 2: Pact Provider Verification (Backend validates contracts)
183
+
184
+ **Context**: Node.js/Express API verifying pacts published by consumers.
185
+
186
+ **Implementation**:
187
+
188
+ ```typescript
189
+ // tests/contract/user-api.provider.spec.ts
190
+ import { Verifier, VerifierOptions } from '@pact-foundation/pact';
191
+ import { server } from '../../src/server'; // Your Express/Fastify app
192
+ import { seedDatabase, resetDatabase } from '../support/db-helpers';
193
+
194
+ /**
195
+ * Provider Verification Test
196
+ * - Provider (backend API) verifies against published pacts
197
+ * - State handlers setup test data for each interaction
198
+ * - Runs before merge to catch breaking changes
199
+ */
200
+
201
+ describe('Pact Provider Verification', () => {
202
+ let serverInstance;
203
+ const PORT = 3001;
204
+
205
+ beforeAll(async () => {
206
+ // Start provider server
207
+ serverInstance = server.listen(PORT);
208
+ console.log(`Provider server running on port ${PORT}`);
209
+ });
210
+
211
+ afterAll(async () => {
212
+ // Cleanup
213
+ await serverInstance.close();
214
+ });
215
+
216
+ it('should verify pacts from all consumers', async () => {
217
+ const opts: VerifierOptions = {
218
+ // Provider details
219
+ provider: 'user-api-service',
220
+ providerBaseUrl: `http://localhost:${PORT}`,
221
+
222
+ // Pact Broker configuration
223
+ pactBrokerUrl: process.env.PACT_BROKER_URL,
224
+ pactBrokerToken: process.env.PACT_BROKER_TOKEN,
225
+ publishVerificationResult: process.env.CI === 'true',
226
+ providerVersion: process.env.GIT_SHA || 'dev',
227
+
228
+ // State handlers: Setup provider state for each interaction
229
+ stateHandlers: {
230
+ 'user with id 1 exists': async () => {
231
+ await seedDatabase({
232
+ users: [
233
+ {
234
+ id: 1,
235
+ name: 'John Doe',
236
+ email: 'john@example.com',
237
+ role: 'user',
238
+ createdAt: '2025-01-15T10:00:00Z',
239
+ },
240
+ ],
241
+ });
242
+ return 'User seeded successfully';
243
+ },
244
+
245
+ 'user with id 999 does not exist': async () => {
246
+ // Ensure user doesn't exist
247
+ await resetDatabase();
248
+ return 'Database reset';
249
+ },
250
+
251
+ 'no users exist': async () => {
252
+ await resetDatabase();
253
+ return 'Database empty';
254
+ },
255
+ },
256
+
257
+ // Request filters: Add auth headers to all requests
258
+ requestFilter: (req, res, next) => {
259
+ // Mock authentication for verification
260
+ req.headers['x-user-id'] = 'test-user';
261
+ req.headers['authorization'] = 'Bearer valid-test-token';
262
+ next();
263
+ },
264
+
265
+ // Timeout for verification
266
+ timeout: 30000,
267
+ };
268
+
269
+ // Run verification
270
+ await new Verifier(opts).verifyProvider();
271
+ });
272
+ });
273
+ ```
274
+
275
+ **CI integration**:
276
+
277
+ ```yaml
278
+ # .github/workflows/pact-provider.yml
279
+ name: Pact Provider Verification
280
+ on:
281
+ pull_request:
282
+ push:
283
+ branches: [main]
284
+
285
+ jobs:
286
+ verify-contracts:
287
+ runs-on: ubuntu-latest
288
+ steps:
289
+ - uses: actions/checkout@v4
290
+
291
+ - name: Setup Node.js
292
+ uses: actions/setup-node@v4
293
+ with:
294
+ node-version-file: '.nvmrc'
295
+
296
+ - name: Install dependencies
297
+ run: npm ci
298
+
299
+ - name: Start database
300
+ run: docker-compose up -d postgres
301
+
302
+ - name: Run migrations
303
+ run: npm run db:migrate
304
+
305
+ - name: Verify pacts
306
+ run: npm run test:contract:provider
307
+ env:
308
+ PACT_BROKER_URL: ${{ secrets.PACT_BROKER_URL }}
309
+ PACT_BROKER_TOKEN: ${{ secrets.PACT_BROKER_TOKEN }}
310
+ GIT_SHA: ${{ github.sha }}
311
+ CI: true
312
+
313
+ - name: Can I Deploy?
314
+ run: |
315
+ npx pact-broker can-i-deploy \
316
+ --pacticipant user-api-service \
317
+ --version ${{ github.sha }} \
318
+ --to-environment production
319
+ env:
320
+ PACT_BROKER_BASE_URL: ${{ secrets.PACT_BROKER_URL }}
321
+ PACT_BROKER_TOKEN: ${{ secrets.PACT_BROKER_TOKEN }}
322
+ ```
323
+
324
+ **Key Points**:
325
+
326
+ - **State handlers**: Setup provider data for each given() state
327
+ - **Request filters**: Add auth/headers for verification requests
328
+ - **CI publishing**: Verification results sent to broker
329
+ - **can-i-deploy**: Safety check before production deployment
330
+ - **Database isolation**: Reset between state handlers
331
+
332
+ ---
333
+
334
+ ### Example 3: Contract CI Integration (Consumer & Provider Workflow)
335
+
336
+ **Context**: Complete CI/CD workflow coordinating consumer pact publishing and provider verification.
337
+
338
+ **Implementation**:
339
+
340
+ ```yaml
341
+ # .github/workflows/pact-consumer.yml (Consumer side)
342
+ name: Pact Consumer Tests
343
+ on:
344
+ pull_request:
345
+ push:
346
+ branches: [main]
347
+
348
+ jobs:
349
+ consumer-tests:
350
+ runs-on: ubuntu-latest
351
+ steps:
352
+ - uses: actions/checkout@v4
353
+
354
+ - name: Setup Node.js
355
+ uses: actions/setup-node@v4
356
+ with:
357
+ node-version-file: '.nvmrc'
358
+
359
+ - name: Install dependencies
360
+ run: npm ci
361
+
362
+ - name: Run consumer contract tests
363
+ run: npm run test:contract
364
+
365
+ - name: Publish pacts to broker
366
+ if: github.ref == 'refs/heads/main' || github.event_name == 'pull_request'
367
+ run: |
368
+ npx pact-broker publish ./pacts \
369
+ --consumer-app-version ${{ github.sha }} \
370
+ --branch ${{ github.head_ref || github.ref_name }} \
371
+ --broker-base-url ${{ secrets.PACT_BROKER_URL }} \
372
+ --broker-token ${{ secrets.PACT_BROKER_TOKEN }}
373
+
374
+ - name: Tag pact with environment (main branch only)
375
+ if: github.ref == 'refs/heads/main'
376
+ run: |
377
+ npx pact-broker create-version-tag \
378
+ --pacticipant user-management-web \
379
+ --version ${{ github.sha }} \
380
+ --tag production \
381
+ --broker-base-url ${{ secrets.PACT_BROKER_URL }} \
382
+ --broker-token ${{ secrets.PACT_BROKER_TOKEN }}
383
+ ```
384
+
385
+ ```yaml
386
+ # .github/workflows/pact-provider.yml (Provider side)
387
+ name: Pact Provider Verification
388
+ on:
389
+ pull_request:
390
+ push:
391
+ branches: [main]
392
+ repository_dispatch:
393
+ types: [pact_changed] # Webhook from Pact Broker
394
+
395
+ jobs:
396
+ verify-contracts:
397
+ runs-on: ubuntu-latest
398
+ steps:
399
+ - uses: actions/checkout@v4
400
+
401
+ - name: Setup Node.js
402
+ uses: actions/setup-node@v4
403
+ with:
404
+ node-version-file: '.nvmrc'
405
+
406
+ - name: Install dependencies
407
+ run: npm ci
408
+
409
+ - name: Start dependencies
410
+ run: docker-compose up -d
411
+
412
+ - name: Run provider verification
413
+ run: npm run test:contract:provider
414
+ env:
415
+ PACT_BROKER_URL: ${{ secrets.PACT_BROKER_URL }}
416
+ PACT_BROKER_TOKEN: ${{ secrets.PACT_BROKER_TOKEN }}
417
+ GIT_SHA: ${{ github.sha }}
418
+ CI: true
419
+
420
+ - name: Publish verification results
421
+ if: always()
422
+ run: echo "Verification results published to broker"
423
+
424
+ - name: Can I Deploy to Production?
425
+ if: github.ref == 'refs/heads/main'
426
+ run: |
427
+ npx pact-broker can-i-deploy \
428
+ --pacticipant user-api-service \
429
+ --version ${{ github.sha }} \
430
+ --to-environment production \
431
+ --broker-base-url ${{ secrets.PACT_BROKER_URL }} \
432
+ --broker-token ${{ secrets.PACT_BROKER_TOKEN }} \
433
+ --retry-while-unknown 6 \
434
+ --retry-interval 10
435
+
436
+ - name: Record deployment (if can-i-deploy passed)
437
+ if: success() && github.ref == 'refs/heads/main'
438
+ run: |
439
+ npx pact-broker record-deployment \
440
+ --pacticipant user-api-service \
441
+ --version ${{ github.sha }} \
442
+ --environment production \
443
+ --broker-base-url ${{ secrets.PACT_BROKER_URL }} \
444
+ --broker-token ${{ secrets.PACT_BROKER_TOKEN }}
445
+ ```
446
+
447
+ **Pact Broker Webhook Configuration**:
448
+
449
+ ```json
450
+ {
451
+ "events": [
452
+ {
453
+ "name": "contract_content_changed"
454
+ }
455
+ ],
456
+ "request": {
457
+ "method": "POST",
458
+ "url": "https://api.github.com/repos/your-org/user-api/dispatches",
459
+ "headers": {
460
+ "Authorization": "Bearer ${user.githubToken}",
461
+ "Content-Type": "application/json",
462
+ "Accept": "application/vnd.github.v3+json"
463
+ },
464
+ "body": {
465
+ "event_type": "pact_changed",
466
+ "client_payload": {
467
+ "pact_url": "${pactbroker.pactUrl}",
468
+ "consumer": "${pactbroker.consumerName}",
469
+ "provider": "${pactbroker.providerName}"
470
+ }
471
+ }
472
+ }
473
+ }
474
+ ```
475
+
476
+ **Key Points**:
477
+
478
+ - **Automatic trigger**: Consumer pact changes trigger provider verification via webhook
479
+ - **Branch tracking**: Pacts published per branch for feature testing
480
+ - **can-i-deploy**: Safety gate before production deployment
481
+ - **Record deployment**: Track which version is in each environment
482
+ - **Parallel dev**: Consumer and provider teams work independently
483
+
484
+ ---
485
+
486
+ ### Example 4: Resilience Coverage (Testing Fallback Behavior)
487
+
488
+ **Context**: Capture timeout, retry, and error handling behavior explicitly in contracts.
489
+
490
+ **Implementation**:
491
+
492
+ ```typescript
493
+ // tests/contract/user-api-resilience.pact.spec.ts
494
+ import { PactV3, MatchersV3 } from '@pact-foundation/pact';
495
+ import { getUserById, ApiError } from '@/api/user-service';
496
+
497
+ const { like, string } = MatchersV3;
498
+
499
+ const provider = new PactV3({
500
+ consumer: 'user-management-web',
501
+ provider: 'user-api-service',
502
+ dir: './pacts',
503
+ });
504
+
505
+ describe('User API Resilience Contract', () => {
506
+ /**
507
+ * Test 500 error handling
508
+ * Verifies consumer handles server errors gracefully
509
+ */
510
+ it('should handle 500 errors with retry logic', async () => {
511
+ await provider
512
+ .given('server is experiencing errors')
513
+ .uponReceiving('a request that returns 500')
514
+ .withRequest({
515
+ method: 'GET',
516
+ path: '/users/1',
517
+ headers: { Accept: 'application/json' },
518
+ })
519
+ .willRespondWith({
520
+ status: 500,
521
+ headers: { 'Content-Type': 'application/json' },
522
+ body: {
523
+ error: 'Internal server error',
524
+ code: 'INTERNAL_ERROR',
525
+ retryable: true,
526
+ },
527
+ })
528
+ .executeTest(async (mockServer) => {
529
+ // Consumer should retry on 500
530
+ try {
531
+ await getUserById(1, {
532
+ baseURL: mockServer.url,
533
+ retries: 3,
534
+ retryDelay: 100,
535
+ });
536
+ fail('Should have thrown error after retries');
537
+ } catch (error) {
538
+ expect(error).toBeInstanceOf(ApiError);
539
+ expect((error as ApiError).code).toBe('INTERNAL_ERROR');
540
+ expect((error as ApiError).retryable).toBe(true);
541
+ }
542
+ });
543
+ });
544
+
545
+ /**
546
+ * Test 429 rate limiting
547
+ * Verifies consumer respects rate limits
548
+ */
549
+ it('should handle 429 rate limit with backoff', async () => {
550
+ await provider
551
+ .given('rate limit exceeded for user')
552
+ .uponReceiving('a request that is rate limited')
553
+ .withRequest({
554
+ method: 'GET',
555
+ path: '/users/1',
556
+ })
557
+ .willRespondWith({
558
+ status: 429,
559
+ headers: {
560
+ 'Content-Type': 'application/json',
561
+ 'Retry-After': '60', // Retry after 60 seconds
562
+ },
563
+ body: {
564
+ error: 'Too many requests',
565
+ code: 'RATE_LIMIT_EXCEEDED',
566
+ },
567
+ })
568
+ .executeTest(async (mockServer) => {
569
+ try {
570
+ await getUserById(1, {
571
+ baseURL: mockServer.url,
572
+ respectRateLimit: true,
573
+ });
574
+ fail('Should have thrown rate limit error');
575
+ } catch (error) {
576
+ expect(error).toBeInstanceOf(ApiError);
577
+ expect((error as ApiError).code).toBe('RATE_LIMIT_EXCEEDED');
578
+ expect((error as ApiError).retryAfter).toBe(60);
579
+ }
580
+ });
581
+ });
582
+
583
+ /**
584
+ * Test timeout handling
585
+ * Verifies consumer has appropriate timeout configuration
586
+ */
587
+ it('should timeout after 10 seconds', async () => {
588
+ await provider
589
+ .given('server is slow to respond')
590
+ .uponReceiving('a request that times out')
591
+ .withRequest({
592
+ method: 'GET',
593
+ path: '/users/1',
594
+ })
595
+ .willRespondWith({
596
+ status: 200,
597
+ headers: { 'Content-Type': 'application/json' },
598
+ body: like({ id: 1, name: 'John' }),
599
+ })
600
+ .withDelay(15000) // Simulate 15 second delay
601
+ .executeTest(async (mockServer) => {
602
+ try {
603
+ await getUserById(1, {
604
+ baseURL: mockServer.url,
605
+ timeout: 10000, // 10 second timeout
606
+ });
607
+ fail('Should have timed out');
608
+ } catch (error) {
609
+ expect(error).toBeInstanceOf(ApiError);
610
+ expect((error as ApiError).code).toBe('TIMEOUT');
611
+ }
612
+ });
613
+ });
614
+
615
+ /**
616
+ * Test partial response (optional fields)
617
+ * Verifies consumer handles missing optional data
618
+ */
619
+ it('should handle response with missing optional fields', async () => {
620
+ await provider
621
+ .given('user exists with minimal data')
622
+ .uponReceiving('a request for user with partial data')
623
+ .withRequest({
624
+ method: 'GET',
625
+ path: '/users/1',
626
+ })
627
+ .willRespondWith({
628
+ status: 200,
629
+ headers: { 'Content-Type': 'application/json' },
630
+ body: {
631
+ id: integer(1),
632
+ name: string('John Doe'),
633
+ email: string('john@example.com'),
634
+ // role, createdAt, etc. omitted (optional fields)
635
+ },
636
+ })
637
+ .executeTest(async (mockServer) => {
638
+ const user = await getUserById(1, { baseURL: mockServer.url });
639
+
640
+ // Consumer handles missing optional fields gracefully
641
+ expect(user.id).toBe(1);
642
+ expect(user.name).toBe('John Doe');
643
+ expect(user.role).toBeUndefined(); // Optional field
644
+ expect(user.createdAt).toBeUndefined(); // Optional field
645
+ });
646
+ });
647
+ });
648
+ ```
649
+
650
+ **API client with retry logic**:
651
+
652
+ ```typescript
653
+ // src/api/user-service.ts
654
+ import axios, { AxiosInstance, AxiosRequestConfig } from 'axios';
655
+
656
+ export class ApiError extends Error {
657
+ constructor(
658
+ message: string,
659
+ public code: string,
660
+ public retryable: boolean = false,
661
+ public retryAfter?: number,
662
+ ) {
663
+ super(message);
664
+ }
665
+ }
666
+
667
+ /**
668
+ * User API client with retry and error handling
669
+ */
670
+ export async function getUserById(
671
+ id: number,
672
+ config?: AxiosRequestConfig & { retries?: number; retryDelay?: number; respectRateLimit?: boolean },
673
+ ): Promise<User> {
674
+ const { retries = 3, retryDelay = 1000, respectRateLimit = true, ...axiosConfig } = config || {};
675
+
676
+ let lastError: Error;
677
+
678
+ for (let attempt = 1; attempt <= retries; attempt++) {
679
+ try {
680
+ const response = await axios.get(`/users/${id}`, axiosConfig);
681
+ return response.data;
682
+ } catch (error: any) {
683
+ lastError = error;
684
+
685
+ // Handle rate limiting
686
+ if (error.response?.status === 429) {
687
+ const retryAfter = parseInt(error.response.headers['retry-after'] || '60');
688
+ throw new ApiError('Too many requests', 'RATE_LIMIT_EXCEEDED', false, retryAfter);
689
+ }
690
+
691
+ // Retry on 500 errors
692
+ if (error.response?.status === 500 && attempt < retries) {
693
+ await new Promise((resolve) => setTimeout(resolve, retryDelay * attempt));
694
+ continue;
695
+ }
696
+
697
+ // Handle 404
698
+ if (error.response?.status === 404) {
699
+ throw new ApiError('User not found', 'USER_NOT_FOUND', false);
700
+ }
701
+
702
+ // Handle timeout
703
+ if (error.code === 'ECONNABORTED') {
704
+ throw new ApiError('Request timeout', 'TIMEOUT', true);
705
+ }
706
+
707
+ break;
708
+ }
709
+ }
710
+
711
+ throw new ApiError('Request failed after retries', 'INTERNAL_ERROR', true);
712
+ }
713
+ ```
714
+
715
+ **Key Points**:
716
+
717
+ - **Resilience contracts**: Timeouts, retries, errors explicitly tested
718
+ - **State handlers**: Provider sets up each test scenario
719
+ - **Error handling**: Consumer validates graceful degradation
720
+ - **Retry logic**: Exponential backoff tested
721
+ - **Optional fields**: Consumer handles partial responses
722
+
723
+ ---
724
+
725
+ ### Example 4: Pact Broker Housekeeping & Lifecycle Management
726
+
727
+ **Context**: Automated broker maintenance to prevent contract sprawl and noise.
728
+
729
+ **Implementation**:
730
+
731
+ ```typescript
732
+ // scripts/pact-broker-housekeeping.ts
733
+ /**
734
+ * Pact Broker Housekeeping Script
735
+ * - Archive superseded contracts
736
+ * - Expire unused pacts
737
+ * - Tag releases for environment tracking
738
+ */
739
+
740
+ import { execSync } from 'child_process';
741
+
742
+ const PACT_BROKER_URL = process.env.PACT_BROKER_URL!;
743
+ const PACT_BROKER_TOKEN = process.env.PACT_BROKER_TOKEN!;
744
+ const PACTICIPANT = 'user-api-service';
745
+
746
+ /**
747
+ * Tag release with environment
748
+ */
749
+ function tagRelease(version: string, environment: 'staging' | 'production') {
750
+ console.log(`🏷️ Tagging ${PACTICIPANT} v${version} as ${environment}`);
751
+
752
+ execSync(
753
+ `npx pact-broker create-version-tag \
754
+ --pacticipant ${PACTICIPANT} \
755
+ --version ${version} \
756
+ --tag ${environment} \
757
+ --broker-base-url ${PACT_BROKER_URL} \
758
+ --broker-token ${PACT_BROKER_TOKEN}`,
759
+ { stdio: 'inherit' },
760
+ );
761
+ }
762
+
763
+ /**
764
+ * Record deployment to environment
765
+ */
766
+ function recordDeployment(version: string, environment: 'staging' | 'production') {
767
+ console.log(`📝 Recording deployment of ${PACTICIPANT} v${version} to ${environment}`);
768
+
769
+ execSync(
770
+ `npx pact-broker record-deployment \
771
+ --pacticipant ${PACTICIPANT} \
772
+ --version ${version} \
773
+ --environment ${environment} \
774
+ --broker-base-url ${PACT_BROKER_URL} \
775
+ --broker-token ${PACT_BROKER_TOKEN}`,
776
+ { stdio: 'inherit' },
777
+ );
778
+ }
779
+
780
+ /**
781
+ * Clean up old pact versions (retention policy)
782
+ * Keep: last 30 days, all production tags, latest from each branch
783
+ */
784
+ function cleanupOldPacts() {
785
+ console.log(`🧹 Cleaning up old pacts for ${PACTICIPANT}`);
786
+
787
+ execSync(
788
+ `npx pact-broker clean \
789
+ --pacticipant ${PACTICIPANT} \
790
+ --broker-base-url ${PACT_BROKER_URL} \
791
+ --broker-token ${PACT_BROKER_TOKEN} \
792
+ --keep-latest-for-branch 1 \
793
+ --keep-min-age 30`,
794
+ { stdio: 'inherit' },
795
+ );
796
+ }
797
+
798
+ /**
799
+ * Check deployment compatibility
800
+ */
801
+ function canIDeploy(version: string, toEnvironment: string): boolean {
802
+ console.log(`🔍 Checking if ${PACTICIPANT} v${version} can deploy to ${toEnvironment}`);
803
+
804
+ try {
805
+ execSync(
806
+ `npx pact-broker can-i-deploy \
807
+ --pacticipant ${PACTICIPANT} \
808
+ --version ${version} \
809
+ --to-environment ${toEnvironment} \
810
+ --broker-base-url ${PACT_BROKER_URL} \
811
+ --broker-token ${PACT_BROKER_TOKEN} \
812
+ --retry-while-unknown 6 \
813
+ --retry-interval 10`,
814
+ { stdio: 'inherit' },
815
+ );
816
+ return true;
817
+ } catch (error) {
818
+ console.error(`❌ Cannot deploy to ${toEnvironment}`);
819
+ return false;
820
+ }
821
+ }
822
+
823
+ /**
824
+ * Main housekeeping workflow
825
+ */
826
+ async function main() {
827
+ const command = process.argv[2];
828
+ const version = process.argv[3];
829
+ const environment = process.argv[4] as 'staging' | 'production';
830
+
831
+ switch (command) {
832
+ case 'tag-release':
833
+ tagRelease(version, environment);
834
+ break;
835
+
836
+ case 'record-deployment':
837
+ recordDeployment(version, environment);
838
+ break;
839
+
840
+ case 'can-i-deploy':
841
+ const canDeploy = canIDeploy(version, environment);
842
+ process.exit(canDeploy ? 0 : 1);
843
+
844
+ case 'cleanup':
845
+ cleanupOldPacts();
846
+ break;
847
+
848
+ default:
849
+ console.error('Unknown command. Use: tag-release | record-deployment | can-i-deploy | cleanup');
850
+ process.exit(1);
851
+ }
852
+ }
853
+
854
+ main();
855
+ ```
856
+
857
+ **package.json scripts**:
858
+
859
+ ```json
860
+ {
861
+ "scripts": {
862
+ "pact:tag": "ts-node scripts/pact-broker-housekeeping.ts tag-release",
863
+ "pact:record": "ts-node scripts/pact-broker-housekeeping.ts record-deployment",
864
+ "pact:can-deploy": "ts-node scripts/pact-broker-housekeeping.ts can-i-deploy",
865
+ "pact:cleanup": "ts-node scripts/pact-broker-housekeeping.ts cleanup"
866
+ }
867
+ }
868
+ ```
869
+
870
+ **Deployment workflow integration**:
871
+
872
+ ```yaml
873
+ # .github/workflows/deploy-production.yml
874
+ name: Deploy to Production
875
+ on:
876
+ push:
877
+ tags:
878
+ - 'v*'
879
+
880
+ jobs:
881
+ verify-contracts:
882
+ runs-on: ubuntu-latest
883
+ steps:
884
+ - uses: actions/checkout@v4
885
+
886
+ - name: Check pact compatibility
887
+ run: npm run pact:can-deploy ${{ github.ref_name }} production
888
+ env:
889
+ PACT_BROKER_URL: ${{ secrets.PACT_BROKER_URL }}
890
+ PACT_BROKER_TOKEN: ${{ secrets.PACT_BROKER_TOKEN }}
891
+
892
+ deploy:
893
+ needs: verify-contracts
894
+ runs-on: ubuntu-latest
895
+ steps:
896
+ - name: Deploy to production
897
+ run: ./scripts/deploy.sh production
898
+
899
+ - name: Record deployment in Pact Broker
900
+ run: npm run pact:record ${{ github.ref_name }} production
901
+ env:
902
+ PACT_BROKER_URL: ${{ secrets.PACT_BROKER_URL }}
903
+ PACT_BROKER_TOKEN: ${{ secrets.PACT_BROKER_TOKEN }}
904
+ ```
905
+
906
+ **Scheduled cleanup**:
907
+
908
+ ```yaml
909
+ # .github/workflows/pact-housekeeping.yml
910
+ name: Pact Broker Housekeeping
911
+ on:
912
+ schedule:
913
+ - cron: '0 2 * * 0' # Weekly on Sunday at 2 AM
914
+
915
+ jobs:
916
+ cleanup:
917
+ runs-on: ubuntu-latest
918
+ steps:
919
+ - uses: actions/checkout@v4
920
+
921
+ - name: Cleanup old pacts
922
+ run: npm run pact:cleanup
923
+ env:
924
+ PACT_BROKER_URL: ${{ secrets.PACT_BROKER_URL }}
925
+ PACT_BROKER_TOKEN: ${{ secrets.PACT_BROKER_TOKEN }}
926
+ ```
927
+
928
+ **Key Points**:
929
+
930
+ - **Automated tagging**: Releases tagged with environment
931
+ - **Deployment tracking**: Broker knows which version is where
932
+ - **Safety gate**: can-i-deploy blocks incompatible deployments
933
+ - **Retention policy**: Keep recent, production, and branch-latest pacts
934
+ - **Webhook triggers**: Provider verification runs on consumer changes
935
+
936
+ ---
937
+
938
+ ## Contract Testing Checklist
939
+
940
+ Before implementing contract testing, verify:
941
+
942
+ - [ ] **Pact Broker setup**: Hosted (Pactflow) or self-hosted broker configured
943
+ - [ ] **Consumer tests**: Generate pacts in CI, publish to broker on merge
944
+ - [ ] **Provider verification**: Runs on PR, verifies all consumer pacts
945
+ - [ ] **State handlers**: Provider implements all given() states
946
+ - [ ] **can-i-deploy**: Blocks deployment if contracts incompatible
947
+ - [ ] **Webhooks configured**: Consumer changes trigger provider verification
948
+ - [ ] **Retention policy**: Old pacts archived (keep 30 days, all production tags)
949
+ - [ ] **Resilience tested**: Timeouts, retries, error codes in contracts
950
+
951
+ ## Integration Points
952
+
953
+ - Used in workflows: `*automate` (integration test generation), `*ci` (contract CI setup)
954
+ - Related fragments: `test-levels-framework.md`, `ci-burn-in.md`
955
+ - Tools: Pact.js, Pact Broker (Pactflow or self-hosted), Pact CLI
956
+
957
+ _Source: Pact consumer/provider sample repos, Murat contract testing blog, Pact official documentation_