create-byan-agent 2.1.0 → 2.1.1

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 (751) hide show
  1. package/API-BYAN-V2.md +741 -0
  2. package/BMAD-QUICK-REFERENCE.md +370 -0
  3. package/CHANGELOG-v2.1.0.md +371 -0
  4. package/LICENSE +21 -0
  5. package/MIGRATION-v2.0-to-v2.1.md +430 -0
  6. package/README-BYAN-V2.md +446 -0
  7. package/README.md +361 -0
  8. package/package.json +8 -6
  9. package/.github/agents/bmad-agent-bmad-master.md +0 -40
  10. package/.github/agents/bmad-agent-bmb-agent-builder.md +0 -15
  11. package/.github/agents/bmad-agent-bmb-module-builder.md +0 -15
  12. package/.github/agents/bmad-agent-bmb-workflow-builder.md +0 -15
  13. package/.github/agents/bmad-agent-bmm-analyst.md +0 -15
  14. package/.github/agents/bmad-agent-bmm-architect.md +0 -15
  15. package/.github/agents/bmad-agent-bmm-dev.md +0 -15
  16. package/.github/agents/bmad-agent-bmm-pm.md +0 -15
  17. package/.github/agents/bmad-agent-bmm-quick-flow-solo-dev.md +0 -15
  18. package/.github/agents/bmad-agent-bmm-quinn.md +0 -15
  19. package/.github/agents/bmad-agent-bmm-sm.md +0 -15
  20. package/.github/agents/bmad-agent-bmm-tech-writer.md +0 -15
  21. package/.github/agents/bmad-agent-bmm-ux-designer.md +0 -15
  22. package/.github/agents/bmad-agent-byan-test.md +0 -32
  23. package/.github/agents/bmad-agent-byan-v2.md +0 -44
  24. package/.github/agents/bmad-agent-byan.md +0 -251
  25. package/.github/agents/bmad-agent-carmack.md +0 -18
  26. package/.github/agents/bmad-agent-cis-brainstorming-coach.md +0 -15
  27. package/.github/agents/bmad-agent-cis-creative-problem-solver.md +0 -15
  28. package/.github/agents/bmad-agent-cis-design-thinking-coach.md +0 -15
  29. package/.github/agents/bmad-agent-cis-innovation-strategist.md +0 -15
  30. package/.github/agents/bmad-agent-cis-presentation-master.md +0 -15
  31. package/.github/agents/bmad-agent-cis-storyteller.md +0 -15
  32. package/.github/agents/bmad-agent-drawio.md +0 -44
  33. package/.github/agents/bmad-agent-marc.md +0 -98
  34. package/.github/agents/bmad-agent-patnote.md +0 -48
  35. package/.github/agents/bmad-agent-rachid.md +0 -47
  36. package/.github/agents/bmad-agent-tea-tea.md +0 -15
  37. package/.github/agents/bmad-agent-test-dynamic.md +0 -21
  38. package/.github/agents/franck.md +0 -379
  39. package/README.MD +0 -225
  40. package/__tests__/byan-v2/context/copilot-context.test.js +0 -327
  41. package/__tests__/byan-v2/context/session-state.test.js +0 -322
  42. package/__tests__/byan-v2/dispatcher/complexity-scorer.test.js +0 -358
  43. package/__tests__/byan-v2/dispatcher/five-whys-analyzer.test.js +0 -473
  44. package/__tests__/byan-v2/dispatcher/local-executor.test.js +0 -496
  45. package/__tests__/byan-v2/dispatcher/task-router.test.js +0 -265
  46. package/__tests__/byan-v2/dispatcher/task-tool-interface.test.js +0 -328
  47. package/__tests__/byan-v2/generation/agent-profile-validator.test.js +0 -386
  48. package/__tests__/byan-v2/generation/mantra-validator.test.js +0 -640
  49. package/__tests__/byan-v2/generation/profile-template.test.js +0 -338
  50. package/__tests__/byan-v2/integration/active-listening-flow.test.js +0 -577
  51. package/__tests__/byan-v2/integration/five-whys-flow.test.js +0 -559
  52. package/__tests__/byan-v2/integration/full-bmad-workflow.test.js +0 -903
  53. package/__tests__/byan-v2/integration/full-bmad-workflow.test.js.backup +0 -889
  54. package/__tests__/byan-v2/integration/glossary-flow.test.js +0 -479
  55. package/__tests__/byan-v2/integration/system-integration.test.js +0 -306
  56. package/__tests__/byan-v2/integration/voice-integration.test.js +0 -157
  57. package/__tests__/byan-v2/observability/error-tracker.test.js +0 -461
  58. package/__tests__/byan-v2/observability/logger.test.js +0 -419
  59. package/__tests__/byan-v2/observability/metrics-collector.test.js +0 -346
  60. package/__tests__/byan-v2/orchestrator/active-listener.test.js +0 -694
  61. package/__tests__/byan-v2/orchestrator/analysis-state.test.js +0 -493
  62. package/__tests__/byan-v2/orchestrator/generation-state.test.js +0 -518
  63. package/__tests__/byan-v2/orchestrator/glossary-builder.test.js +0 -464
  64. package/__tests__/byan-v2/orchestrator/interview-state.test.js +0 -470
  65. package/__tests__/byan-v2/orchestrator/state-machine.test.js +0 -495
  66. package/__tests__/cache.test.js +0 -241
  67. package/__tests__/context.test.js +0 -135
  68. package/__tests__/dashboard.test.js +0 -444
  69. package/__tests__/dispatcher.test.js +0 -245
  70. package/__tests__/integration.test.js +0 -163
  71. package/__tests__/metrics-collector.test.js +0 -433
  72. package/__tests__/structured-logger.test.js +0 -358
  73. package/__tests__/worker-pool.test.js +0 -343
  74. package/__tests__/workflow-executor.test.js +0 -356
  75. package/_bmad/_config/agent-manifest.csv +0 -25
  76. package/_bmad/_config/agents/bmb-agent-builder.customize.yaml +0 -41
  77. package/_bmad/_config/agents/bmb-module-builder.customize.yaml +0 -41
  78. package/_bmad/_config/agents/bmb-workflow-builder.customize.yaml +0 -41
  79. package/_bmad/_config/agents/bmm-analyst.customize.yaml +0 -41
  80. package/_bmad/_config/agents/bmm-architect.customize.yaml +0 -41
  81. package/_bmad/_config/agents/bmm-dev.customize.yaml +0 -41
  82. package/_bmad/_config/agents/bmm-pm.customize.yaml +0 -41
  83. package/_bmad/_config/agents/bmm-quick-flow-solo-dev.customize.yaml +0 -41
  84. package/_bmad/_config/agents/bmm-quinn.customize.yaml +0 -41
  85. package/_bmad/_config/agents/bmm-sm.customize.yaml +0 -41
  86. package/_bmad/_config/agents/bmm-tech-writer.customize.yaml +0 -41
  87. package/_bmad/_config/agents/bmm-ux-designer.customize.yaml +0 -41
  88. package/_bmad/_config/agents/byan.customize.yaml +0 -29
  89. package/_bmad/_config/agents/cis-brainstorming-coach.customize.yaml +0 -41
  90. package/_bmad/_config/agents/cis-creative-problem-solver.customize.yaml +0 -41
  91. package/_bmad/_config/agents/cis-design-thinking-coach.customize.yaml +0 -41
  92. package/_bmad/_config/agents/cis-innovation-strategist.customize.yaml +0 -41
  93. package/_bmad/_config/agents/cis-presentation-master.customize.yaml +0 -41
  94. package/_bmad/_config/agents/cis-storyteller.customize.yaml +0 -41
  95. package/_bmad/_config/agents/core-bmad-master.customize.yaml +0 -41
  96. package/_bmad/_config/agents/tea-tea.customize.yaml +0 -41
  97. package/_bmad/_config/bmad-help.csv +0 -72
  98. package/_bmad/_config/files-manifest.csv +0 -607
  99. package/_bmad/_config/ides/codex.yaml +0 -5
  100. package/_bmad/_config/manifest.yaml +0 -43
  101. package/_bmad/_config/task-manifest.csv +0 -9
  102. package/_bmad/_config/tool-manifest.csv +0 -1
  103. package/_bmad/_config/workflow-manifest.csv +0 -46
  104. package/_bmad/_memory/config.yaml +0 -11
  105. package/_bmad/_memory/storyteller-sidecar/stories-told.md +0 -7
  106. package/_bmad/_memory/storyteller-sidecar/story-preferences.md +0 -7
  107. package/_bmad/_memory/tech-writer-sidecar/documentation-standards.md +0 -224
  108. package/_bmad/bmb/agents/agent-builder.md +0 -59
  109. package/_bmad/bmb/agents/byan-test.md +0 -116
  110. package/_bmad/bmb/agents/byan.backup.20260202_212559.md +0 -215
  111. package/_bmad/bmb/agents/byan.md +0 -215
  112. package/_bmad/bmb/agents/byan.optimized-v2.md +0 -116
  113. package/_bmad/bmb/agents/byan.optimized.md +0 -189
  114. package/_bmad/bmb/agents/drawio.md +0 -359
  115. package/_bmad/bmb/agents/marc.md +0 -351
  116. package/_bmad/bmb/agents/module-builder.md +0 -60
  117. package/_bmad/bmb/agents/patnote.md +0 -495
  118. package/_bmad/bmb/agents/rachid.md +0 -184
  119. package/_bmad/bmb/agents/turbo-whisper-integration.md +0 -312
  120. package/_bmad/bmb/agents/workflow-builder.md +0 -61
  121. package/_bmad/bmb/config.yaml +0 -12
  122. package/_bmad/bmb/module-help.csv +0 -13
  123. package/_bmad/bmb/workflows/agent/data/agent-compilation.md +0 -273
  124. package/_bmad/bmb/workflows/agent/data/agent-menu-patterns.md +0 -233
  125. package/_bmad/bmb/workflows/agent/data/agent-metadata.md +0 -208
  126. package/_bmad/bmb/workflows/agent/data/brainstorm-context.md +0 -146
  127. package/_bmad/bmb/workflows/agent/data/communication-presets.csv +0 -61
  128. package/_bmad/bmb/workflows/agent/data/critical-actions.md +0 -120
  129. package/_bmad/bmb/workflows/agent/data/expert-agent-architecture.md +0 -236
  130. package/_bmad/bmb/workflows/agent/data/expert-agent-validation.md +0 -174
  131. package/_bmad/bmb/workflows/agent/data/module-agent-validation.md +0 -126
  132. package/_bmad/bmb/workflows/agent/data/persona-properties.md +0 -266
  133. package/_bmad/bmb/workflows/agent/data/principles-crafting.md +0 -292
  134. package/_bmad/bmb/workflows/agent/data/reference/module-examples/architect.md +0 -68
  135. package/_bmad/bmb/workflows/agent/data/simple-agent-architecture.md +0 -204
  136. package/_bmad/bmb/workflows/agent/data/simple-agent-validation.md +0 -133
  137. package/_bmad/bmb/workflows/agent/data/understanding-agent-types.md +0 -222
  138. package/_bmad/bmb/workflows/agent/steps-c/step-01-brainstorm.md +0 -128
  139. package/_bmad/bmb/workflows/agent/steps-c/step-02-discovery.md +0 -170
  140. package/_bmad/bmb/workflows/agent/steps-c/step-03-type-metadata.md +0 -296
  141. package/_bmad/bmb/workflows/agent/steps-c/step-04-persona.md +0 -212
  142. package/_bmad/bmb/workflows/agent/steps-c/step-05-commands-menu.md +0 -178
  143. package/_bmad/bmb/workflows/agent/steps-c/step-06-activation.md +0 -279
  144. package/_bmad/bmb/workflows/agent/steps-c/step-07a-build-simple.md +0 -187
  145. package/_bmad/bmb/workflows/agent/steps-c/step-07b-build-expert.md +0 -201
  146. package/_bmad/bmb/workflows/agent/steps-c/step-07c-build-module.md +0 -258
  147. package/_bmad/bmb/workflows/agent/steps-c/step-08-celebrate.md +0 -249
  148. package/_bmad/bmb/workflows/agent/steps-e/e-01-load-existing.md +0 -221
  149. package/_bmad/bmb/workflows/agent/steps-e/e-02-discover-edits.md +0 -193
  150. package/_bmad/bmb/workflows/agent/steps-e/e-03-placeholder.md +0 -1
  151. package/_bmad/bmb/workflows/agent/steps-e/e-04-type-metadata.md +0 -124
  152. package/_bmad/bmb/workflows/agent/steps-e/e-05-persona.md +0 -134
  153. package/_bmad/bmb/workflows/agent/steps-e/e-06-commands-menu.md +0 -122
  154. package/_bmad/bmb/workflows/agent/steps-e/e-07-activation.md +0 -125
  155. package/_bmad/bmb/workflows/agent/steps-e/e-08a-edit-simple.md +0 -137
  156. package/_bmad/bmb/workflows/agent/steps-e/e-08b-edit-expert.md +0 -119
  157. package/_bmad/bmb/workflows/agent/steps-e/e-08c-edit-module.md +0 -123
  158. package/_bmad/bmb/workflows/agent/steps-e/e-09-celebrate.md +0 -155
  159. package/_bmad/bmb/workflows/agent/steps-v/v-01-load-review.md +0 -136
  160. package/_bmad/bmb/workflows/agent/steps-v/v-02a-validate-metadata.md +0 -116
  161. package/_bmad/bmb/workflows/agent/steps-v/v-02b-validate-persona.md +0 -124
  162. package/_bmad/bmb/workflows/agent/steps-v/v-02c-validate-menu.md +0 -145
  163. package/_bmad/bmb/workflows/agent/steps-v/v-02d-validate-structure.md +0 -136
  164. package/_bmad/bmb/workflows/agent/steps-v/v-02e-validate-sidecar.md +0 -136
  165. package/_bmad/bmb/workflows/agent/steps-v/v-03-summary.md +0 -104
  166. package/_bmad/bmb/workflows/agent/templates/agent-plan.template.md +0 -5
  167. package/_bmad/bmb/workflows/agent/templates/expert-agent-template/expert-agent.template.md +0 -77
  168. package/_bmad/bmb/workflows/agent/templates/simple-agent.template.md +0 -72
  169. package/_bmad/bmb/workflows/agent/workflow.md +0 -123
  170. package/_bmad/bmb/workflows/byan/data/mantras.yaml +0 -272
  171. package/_bmad/bmb/workflows/byan/data/templates.yaml +0 -59
  172. package/_bmad/bmb/workflows/byan/delete-agent-workflow.md +0 -657
  173. package/_bmad/bmb/workflows/byan/edit-agent-workflow.md +0 -688
  174. package/_bmad/bmb/workflows/byan/interview-workflow.md +0 -753
  175. package/_bmad/bmb/workflows/byan/quick-create-workflow.md +0 -450
  176. package/_bmad/bmb/workflows/byan/templates/base-agent-template.md +0 -79
  177. package/_bmad/bmb/workflows/byan/validate-agent-workflow.md +0 -676
  178. package/_bmad/bmb/workflows/module/data/agent-architecture.md +0 -179
  179. package/_bmad/bmb/workflows/module/data/agent-spec-template.md +0 -79
  180. package/_bmad/bmb/workflows/module/data/module-installer-standards.md +0 -348
  181. package/_bmad/bmb/workflows/module/data/module-standards.md +0 -280
  182. package/_bmad/bmb/workflows/module/data/module-yaml-conventions.md +0 -392
  183. package/_bmad/bmb/workflows/module/steps-b/step-01-welcome.md +0 -147
  184. package/_bmad/bmb/workflows/module/steps-b/step-02-spark.md +0 -140
  185. package/_bmad/bmb/workflows/module/steps-b/step-03-module-type.md +0 -148
  186. package/_bmad/bmb/workflows/module/steps-b/step-04-vision.md +0 -82
  187. package/_bmad/bmb/workflows/module/steps-b/step-05-identity.md +0 -96
  188. package/_bmad/bmb/workflows/module/steps-b/step-06-users.md +0 -85
  189. package/_bmad/bmb/workflows/module/steps-b/step-07-value.md +0 -75
  190. package/_bmad/bmb/workflows/module/steps-b/step-08-agents.md +0 -96
  191. package/_bmad/bmb/workflows/module/steps-b/step-09-workflows.md +0 -82
  192. package/_bmad/bmb/workflows/module/steps-b/step-10-tools.md +0 -90
  193. package/_bmad/bmb/workflows/module/steps-b/step-11-scenarios.md +0 -83
  194. package/_bmad/bmb/workflows/module/steps-b/step-12-creative.md +0 -94
  195. package/_bmad/bmb/workflows/module/steps-b/step-13-review.md +0 -104
  196. package/_bmad/bmb/workflows/module/steps-b/step-14-finalize.md +0 -117
  197. package/_bmad/bmb/workflows/module/steps-c/step-01-load-brief.md +0 -178
  198. package/_bmad/bmb/workflows/module/steps-c/step-01b-continue.md +0 -83
  199. package/_bmad/bmb/workflows/module/steps-c/step-02-structure.md +0 -109
  200. package/_bmad/bmb/workflows/module/steps-c/step-03-config.md +0 -118
  201. package/_bmad/bmb/workflows/module/steps-c/step-04-installer.md +0 -160
  202. package/_bmad/bmb/workflows/module/steps-c/step-05-agents.md +0 -167
  203. package/_bmad/bmb/workflows/module/steps-c/step-06-workflows.md +0 -183
  204. package/_bmad/bmb/workflows/module/steps-c/step-07-docs.md +0 -402
  205. package/_bmad/bmb/workflows/module/steps-c/step-08-complete.md +0 -123
  206. package/_bmad/bmb/workflows/module/steps-e/step-01-load-target.md +0 -81
  207. package/_bmad/bmb/workflows/module/steps-e/step-02-select-edit.md +0 -77
  208. package/_bmad/bmb/workflows/module/steps-e/step-03-apply-edit.md +0 -77
  209. package/_bmad/bmb/workflows/module/steps-e/step-04-review.md +0 -80
  210. package/_bmad/bmb/workflows/module/steps-e/step-05-confirm.md +0 -75
  211. package/_bmad/bmb/workflows/module/steps-v/step-01-load-target.md +0 -96
  212. package/_bmad/bmb/workflows/module/steps-v/step-02-file-structure.md +0 -94
  213. package/_bmad/bmb/workflows/module/steps-v/step-03-module-yaml.md +0 -99
  214. package/_bmad/bmb/workflows/module/steps-v/step-04-agent-specs.md +0 -152
  215. package/_bmad/bmb/workflows/module/steps-v/step-05-workflow-specs.md +0 -152
  216. package/_bmad/bmb/workflows/module/steps-v/step-06-documentation.md +0 -143
  217. package/_bmad/bmb/workflows/module/steps-v/step-07-installation.md +0 -113
  218. package/_bmad/bmb/workflows/module/steps-v/step-08-report.md +0 -197
  219. package/_bmad/bmb/workflows/module/templates/brief-template.md +0 -154
  220. package/_bmad/bmb/workflows/module/templates/workflow-spec-template.md +0 -96
  221. package/_bmad/bmb/workflows/module/workflow.md +0 -100
  222. package/_bmad/bmb/workflows/turbo-whisper/configure-workflow.md +0 -488
  223. package/_bmad/bmb/workflows/turbo-whisper/docker-setup-workflow.md +0 -478
  224. package/_bmad/bmb/workflows/turbo-whisper/install-workflow.md +0 -426
  225. package/_bmad/bmb/workflows/turbo-whisper/integrate-workflow.md +0 -510
  226. package/_bmad/bmb/workflows/workflow/data/architecture.md +0 -152
  227. package/_bmad/bmb/workflows/workflow/data/common-workflow-tools.csv +0 -19
  228. package/_bmad/bmb/workflows/workflow/data/csv-data-file-standards.md +0 -81
  229. package/_bmad/bmb/workflows/workflow/data/frontmatter-standards.md +0 -225
  230. package/_bmad/bmb/workflows/workflow/data/input-discovery-standards.md +0 -269
  231. package/_bmad/bmb/workflows/workflow/data/intent-vs-prescriptive-spectrum.md +0 -50
  232. package/_bmad/bmb/workflows/workflow/data/menu-handling-standards.md +0 -167
  233. package/_bmad/bmb/workflows/workflow/data/output-format-standards.md +0 -188
  234. package/_bmad/bmb/workflows/workflow/data/step-file-rules.md +0 -235
  235. package/_bmad/bmb/workflows/workflow/data/step-type-patterns.md +0 -311
  236. package/_bmad/bmb/workflows/workflow/data/subprocess-optimization-patterns.md +0 -386
  237. package/_bmad/bmb/workflows/workflow/data/trimodal-workflow-structure.md +0 -209
  238. package/_bmad/bmb/workflows/workflow/data/workflow-chaining-standards.md +0 -271
  239. package/_bmad/bmb/workflows/workflow/data/workflow-examples.md +0 -276
  240. package/_bmad/bmb/workflows/workflow/data/workflow-type-criteria.md +0 -172
  241. package/_bmad/bmb/workflows/workflow/steps-c/step-00-conversion.md +0 -262
  242. package/_bmad/bmb/workflows/workflow/steps-c/step-01-discovery.md +0 -194
  243. package/_bmad/bmb/workflows/workflow/steps-c/step-01b-continuation.md +0 -3
  244. package/_bmad/bmb/workflows/workflow/steps-c/step-02-classification.md +0 -269
  245. package/_bmad/bmb/workflows/workflow/steps-c/step-03-requirements.md +0 -282
  246. package/_bmad/bmb/workflows/workflow/steps-c/step-04-tools.md +0 -281
  247. package/_bmad/bmb/workflows/workflow/steps-c/step-05-plan-review.md +0 -242
  248. package/_bmad/bmb/workflows/workflow/steps-c/step-06-design.md +0 -329
  249. package/_bmad/bmb/workflows/workflow/steps-c/step-07-foundation.md +0 -238
  250. package/_bmad/bmb/workflows/workflow/steps-c/step-08-build-step-01.md +0 -377
  251. package/_bmad/bmb/workflows/workflow/steps-c/step-09-build-next-step.md +0 -350
  252. package/_bmad/bmb/workflows/workflow/steps-c/step-10-confirmation.md +0 -320
  253. package/_bmad/bmb/workflows/workflow/steps-c/step-11-completion.md +0 -191
  254. package/_bmad/bmb/workflows/workflow/steps-e/step-e-01-assess-workflow.md +0 -237
  255. package/_bmad/bmb/workflows/workflow/steps-e/step-e-02-discover-edits.md +0 -248
  256. package/_bmad/bmb/workflows/workflow/steps-e/step-e-03-fix-validation.md +0 -252
  257. package/_bmad/bmb/workflows/workflow/steps-e/step-e-04-direct-edit.md +0 -275
  258. package/_bmad/bmb/workflows/workflow/steps-e/step-e-05-apply-edit.md +0 -154
  259. package/_bmad/bmb/workflows/workflow/steps-e/step-e-06-validate-after.md +0 -190
  260. package/_bmad/bmb/workflows/workflow/steps-e/step-e-07-complete.md +0 -206
  261. package/_bmad/bmb/workflows/workflow/steps-v/step-01-validate-max-mode.md +0 -109
  262. package/_bmad/bmb/workflows/workflow/steps-v/step-01-validate.md +0 -221
  263. package/_bmad/bmb/workflows/workflow/steps-v/step-01b-structure.md +0 -152
  264. package/_bmad/bmb/workflows/workflow/steps-v/step-02-frontmatter-validation.md +0 -199
  265. package/_bmad/bmb/workflows/workflow/steps-v/step-02b-path-violations.md +0 -265
  266. package/_bmad/bmb/workflows/workflow/steps-v/step-03-menu-validation.md +0 -164
  267. package/_bmad/bmb/workflows/workflow/steps-v/step-04-step-type-validation.md +0 -211
  268. package/_bmad/bmb/workflows/workflow/steps-v/step-05-output-format-validation.md +0 -200
  269. package/_bmad/bmb/workflows/workflow/steps-v/step-06-validation-design-check.md +0 -195
  270. package/_bmad/bmb/workflows/workflow/steps-v/step-07-instruction-style-check.md +0 -209
  271. package/_bmad/bmb/workflows/workflow/steps-v/step-08-collaborative-experience-check.md +0 -199
  272. package/_bmad/bmb/workflows/workflow/steps-v/step-08b-subprocess-optimization.md +0 -179
  273. package/_bmad/bmb/workflows/workflow/steps-v/step-09-cohesive-review.md +0 -186
  274. package/_bmad/bmb/workflows/workflow/steps-v/step-10-report-complete.md +0 -154
  275. package/_bmad/bmb/workflows/workflow/steps-v/step-11-plan-validation.md +0 -237
  276. package/_bmad/bmb/workflows/workflow/templates/minimal-output-template.md +0 -11
  277. package/_bmad/bmb/workflows/workflow/templates/step-01-init-continuable-template.md +0 -241
  278. package/_bmad/bmb/workflows/workflow/templates/step-1b-template.md +0 -223
  279. package/_bmad/bmb/workflows/workflow/templates/step-template.md +0 -290
  280. package/_bmad/bmb/workflows/workflow/templates/workflow-template.md +0 -102
  281. package/_bmad/bmb/workflows/workflow/workflow.md +0 -109
  282. package/_bmad/bmm/agents/analyst.md +0 -76
  283. package/_bmad/bmm/agents/architect.md +0 -58
  284. package/_bmad/bmm/agents/dev.md +0 -69
  285. package/_bmad/bmm/agents/expert-merise-agile.md +0 -177
  286. package/_bmad/bmm/agents/pm.md +0 -72
  287. package/_bmad/bmm/agents/quick-flow-solo-dev.md +0 -69
  288. package/_bmad/bmm/agents/quinn.md +0 -92
  289. package/_bmad/bmm/agents/sm.md +0 -70
  290. package/_bmad/bmm/agents/tech-writer/tech-writer.md +0 -70
  291. package/_bmad/bmm/agents/ux-designer.md +0 -57
  292. package/_bmad/bmm/config.yaml +0 -16
  293. package/_bmad/bmm/data/project-context-template.md +0 -26
  294. package/_bmad/bmm/module-help.csv +0 -38
  295. package/_bmad/bmm/teams/default-party.csv +0 -20
  296. package/_bmad/bmm/teams/team-fullstack.yaml +0 -12
  297. package/_bmad/bmm/workflows/1-analysis/create-product-brief/product-brief.template.md +0 -10
  298. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-01-init.md +0 -177
  299. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +0 -161
  300. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +0 -199
  301. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-03-users.md +0 -202
  302. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +0 -205
  303. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +0 -219
  304. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +0 -162
  305. package/_bmad/bmm/workflows/1-analysis/create-product-brief/workflow.md +0 -58
  306. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-01-init.md +0 -137
  307. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +0 -229
  308. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +0 -238
  309. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +0 -206
  310. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +0 -234
  311. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +0 -443
  312. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +0 -182
  313. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +0 -237
  314. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +0 -249
  315. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +0 -259
  316. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +0 -177
  317. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +0 -475
  318. package/_bmad/bmm/workflows/1-analysis/research/research.template.md +0 -29
  319. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-01-init.md +0 -137
  320. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +0 -239
  321. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +0 -248
  322. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +0 -202
  323. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +0 -239
  324. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +0 -486
  325. package/_bmad/bmm/workflows/1-analysis/research/workflow.md +0 -173
  326. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +0 -13
  327. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +0 -197
  328. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/project-types.csv +0 -11
  329. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01-init.md +0 -191
  330. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01b-continue.md +0 -153
  331. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02-discovery.md +0 -224
  332. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-03-success.md +0 -226
  333. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-04-journeys.md +0 -213
  334. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-05-domain.md +0 -207
  335. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-06-innovation.md +0 -226
  336. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-07-project-type.md +0 -237
  337. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-08-scoping.md +0 -228
  338. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-09-functional.md +0 -231
  339. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-10-nonfunctional.md +0 -242
  340. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-11-polish.md +0 -217
  341. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-12-complete.md +0 -124
  342. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01-discovery.md +0 -247
  343. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01b-legacy-conversion.md +0 -208
  344. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-02-review.md +0 -249
  345. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-03-edit.md +0 -253
  346. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-04-complete.md +0 -168
  347. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +0 -218
  348. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +0 -191
  349. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +0 -209
  350. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +0 -174
  351. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +0 -214
  352. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +0 -228
  353. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +0 -217
  354. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +0 -205
  355. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +0 -243
  356. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +0 -263
  357. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +0 -209
  358. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +0 -264
  359. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +0 -242
  360. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +0 -231
  361. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/templates/prd-template.md +0 -10
  362. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/validation-report-prd-workflow.md +0 -433
  363. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/workflow.md +0 -150
  364. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +0 -135
  365. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +0 -127
  366. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +0 -190
  367. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +0 -216
  368. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +0 -219
  369. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +0 -234
  370. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +0 -252
  371. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +0 -254
  372. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +0 -224
  373. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +0 -224
  374. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +0 -241
  375. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +0 -248
  376. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +0 -237
  377. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +0 -264
  378. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +0 -171
  379. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +0 -13
  380. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +0 -43
  381. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +0 -190
  382. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +0 -178
  383. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +0 -179
  384. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +0 -139
  385. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +0 -252
  386. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +0 -135
  387. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +0 -4
  388. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +0 -55
  389. package/_bmad/bmm/workflows/3-solutioning/create-architecture/architecture-decision-template.md +0 -12
  390. package/_bmad/bmm/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +0 -11
  391. package/_bmad/bmm/workflows/3-solutioning/create-architecture/data/project-types.csv +0 -7
  392. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-01-init.md +0 -153
  393. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +0 -164
  394. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-02-context.md +0 -224
  395. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +0 -331
  396. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +0 -318
  397. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +0 -359
  398. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +0 -379
  399. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +0 -359
  400. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +0 -76
  401. package/_bmad/bmm/workflows/3-solutioning/create-architecture/workflow.md +0 -50
  402. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +0 -259
  403. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +0 -233
  404. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +0 -272
  405. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +0 -149
  406. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +0 -57
  407. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +0 -59
  408. package/_bmad/bmm/workflows/4-implementation/code-review/checklist.md +0 -23
  409. package/_bmad/bmm/workflows/4-implementation/code-review/instructions.xml +0 -227
  410. package/_bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +0 -50
  411. package/_bmad/bmm/workflows/4-implementation/correct-course/checklist.md +0 -288
  412. package/_bmad/bmm/workflows/4-implementation/correct-course/instructions.md +0 -206
  413. package/_bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +0 -58
  414. package/_bmad/bmm/workflows/4-implementation/create-story/checklist.md +0 -358
  415. package/_bmad/bmm/workflows/4-implementation/create-story/instructions.xml +0 -345
  416. package/_bmad/bmm/workflows/4-implementation/create-story/template.md +0 -49
  417. package/_bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +0 -59
  418. package/_bmad/bmm/workflows/4-implementation/dev-story/checklist.md +0 -80
  419. package/_bmad/bmm/workflows/4-implementation/dev-story/instructions.xml +0 -410
  420. package/_bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +0 -25
  421. package/_bmad/bmm/workflows/4-implementation/retrospective/instructions.md +0 -1443
  422. package/_bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +0 -57
  423. package/_bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +0 -33
  424. package/_bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +0 -225
  425. package/_bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +0 -55
  426. package/_bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +0 -53
  427. package/_bmad/bmm/workflows/4-implementation/sprint-status/instructions.md +0 -229
  428. package/_bmad/bmm/workflows/4-implementation/sprint-status/workflow.yaml +0 -35
  429. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +0 -176
  430. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +0 -120
  431. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +0 -113
  432. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +0 -113
  433. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +0 -106
  434. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +0 -149
  435. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +0 -50
  436. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-01-understand.md +0 -192
  437. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-02-investigate.md +0 -145
  438. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +0 -128
  439. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +0 -201
  440. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/tech-spec-template.md +0 -74
  441. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +0 -79
  442. package/_bmad/bmm/workflows/document-project/checklist.md +0 -245
  443. package/_bmad/bmm/workflows/document-project/documentation-requirements.csv +0 -12
  444. package/_bmad/bmm/workflows/document-project/instructions.md +0 -221
  445. package/_bmad/bmm/workflows/document-project/templates/deep-dive-template.md +0 -345
  446. package/_bmad/bmm/workflows/document-project/templates/index-template.md +0 -169
  447. package/_bmad/bmm/workflows/document-project/templates/project-overview-template.md +0 -103
  448. package/_bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +0 -160
  449. package/_bmad/bmm/workflows/document-project/templates/source-tree-template.md +0 -135
  450. package/_bmad/bmm/workflows/document-project/workflow.yaml +0 -28
  451. package/_bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +0 -298
  452. package/_bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +0 -31
  453. package/_bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +0 -1106
  454. package/_bmad/bmm/workflows/document-project/workflows/full-scan.yaml +0 -31
  455. package/_bmad/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-library.json +0 -90
  456. package/_bmad/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-templates.yaml +0 -127
  457. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/checklist.md +0 -39
  458. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/instructions.md +0 -130
  459. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/workflow.yaml +0 -26
  460. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/checklist.md +0 -43
  461. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/instructions.md +0 -141
  462. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/workflow.yaml +0 -26
  463. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/checklist.md +0 -49
  464. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/instructions.md +0 -241
  465. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/workflow.yaml +0 -26
  466. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/checklist.md +0 -38
  467. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/instructions.md +0 -133
  468. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/workflow.yaml +0 -26
  469. package/_bmad/bmm/workflows/generate-project-context/project-context-template.md +0 -21
  470. package/_bmad/bmm/workflows/generate-project-context/steps/step-01-discover.md +0 -184
  471. package/_bmad/bmm/workflows/generate-project-context/steps/step-02-generate.md +0 -318
  472. package/_bmad/bmm/workflows/generate-project-context/steps/step-03-complete.md +0 -278
  473. package/_bmad/bmm/workflows/generate-project-context/workflow.md +0 -49
  474. package/_bmad/bmm/workflows/qa/automate/checklist.md +0 -33
  475. package/_bmad/bmm/workflows/qa/automate/instructions.md +0 -110
  476. package/_bmad/bmm/workflows/qa/automate/workflow.yaml +0 -47
  477. package/_bmad/cis/agents/brainstorming-coach.md +0 -61
  478. package/_bmad/cis/agents/creative-problem-solver.md +0 -61
  479. package/_bmad/cis/agents/design-thinking-coach.md +0 -61
  480. package/_bmad/cis/agents/innovation-strategist.md +0 -61
  481. package/_bmad/cis/agents/presentation-master.md +0 -67
  482. package/_bmad/cis/agents/storyteller/storyteller.md +0 -58
  483. package/_bmad/cis/config.yaml +0 -12
  484. package/_bmad/cis/module-help.csv +0 -6
  485. package/_bmad/cis/teams/creative-squad.yaml +0 -7
  486. package/_bmad/cis/teams/default-party.csv +0 -12
  487. package/_bmad/cis/workflows/README.md +0 -139
  488. package/_bmad/cis/workflows/design-thinking/README.md +0 -56
  489. package/_bmad/cis/workflows/design-thinking/design-methods.csv +0 -31
  490. package/_bmad/cis/workflows/design-thinking/instructions.md +0 -202
  491. package/_bmad/cis/workflows/design-thinking/template.md +0 -111
  492. package/_bmad/cis/workflows/design-thinking/workflow.yaml +0 -27
  493. package/_bmad/cis/workflows/innovation-strategy/README.md +0 -56
  494. package/_bmad/cis/workflows/innovation-strategy/innovation-frameworks.csv +0 -31
  495. package/_bmad/cis/workflows/innovation-strategy/instructions.md +0 -276
  496. package/_bmad/cis/workflows/innovation-strategy/template.md +0 -189
  497. package/_bmad/cis/workflows/innovation-strategy/workflow.yaml +0 -27
  498. package/_bmad/cis/workflows/problem-solving/README.md +0 -56
  499. package/_bmad/cis/workflows/problem-solving/instructions.md +0 -252
  500. package/_bmad/cis/workflows/problem-solving/solving-methods.csv +0 -31
  501. package/_bmad/cis/workflows/problem-solving/template.md +0 -165
  502. package/_bmad/cis/workflows/problem-solving/workflow.yaml +0 -27
  503. package/_bmad/cis/workflows/storytelling/README.md +0 -58
  504. package/_bmad/cis/workflows/storytelling/instructions.md +0 -293
  505. package/_bmad/cis/workflows/storytelling/story-types.csv +0 -26
  506. package/_bmad/cis/workflows/storytelling/template.md +0 -113
  507. package/_bmad/cis/workflows/storytelling/workflow.yaml +0 -27
  508. package/_bmad/core/agents/bmad-master.md +0 -56
  509. package/_bmad/core/agents/carmack.md +0 -238
  510. package/_bmad/core/agents/test-dynamic.md +0 -40
  511. package/_bmad/core/base/bmad-base-agent.md +0 -42
  512. package/_bmad/core/config.yaml +0 -9
  513. package/_bmad/core/module-help.csv +0 -9
  514. package/_bmad/core/resources/excalidraw/README.md +0 -160
  515. package/_bmad/core/resources/excalidraw/excalidraw-helpers.md +0 -127
  516. package/_bmad/core/resources/excalidraw/library-loader.md +0 -50
  517. package/_bmad/core/resources/excalidraw/validate-json-instructions.md +0 -79
  518. package/_bmad/core/tasks/editorial-review-prose.xml +0 -100
  519. package/_bmad/core/tasks/editorial-review-structure.xml +0 -209
  520. package/_bmad/core/tasks/help.md +0 -62
  521. package/_bmad/core/tasks/index-docs.xml +0 -65
  522. package/_bmad/core/tasks/review-adversarial-general.xml +0 -48
  523. package/_bmad/core/tasks/shard-doc.xml +0 -109
  524. package/_bmad/core/tasks/workflow.xml +0 -235
  525. package/_bmad/core/workflows/advanced-elicitation/methods.csv +0 -51
  526. package/_bmad/core/workflows/advanced-elicitation/workflow.xml +0 -117
  527. package/_bmad/core/workflows/brainstorming/brain-methods.csv +0 -62
  528. package/_bmad/core/workflows/brainstorming/steps/step-01-session-setup.md +0 -197
  529. package/_bmad/core/workflows/brainstorming/steps/step-01b-continue.md +0 -122
  530. package/_bmad/core/workflows/brainstorming/steps/step-02a-user-selected.md +0 -225
  531. package/_bmad/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +0 -237
  532. package/_bmad/core/workflows/brainstorming/steps/step-02c-random-selection.md +0 -209
  533. package/_bmad/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +0 -264
  534. package/_bmad/core/workflows/brainstorming/steps/step-03-technique-execution.md +0 -399
  535. package/_bmad/core/workflows/brainstorming/steps/step-04-idea-organization.md +0 -303
  536. package/_bmad/core/workflows/brainstorming/template.md +0 -15
  537. package/_bmad/core/workflows/brainstorming/workflow.md +0 -58
  538. package/_bmad/core/workflows/party-mode/steps/step-01-agent-loading.md +0 -138
  539. package/_bmad/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +0 -187
  540. package/_bmad/core/workflows/party-mode/steps/step-03-graceful-exit.md +0 -157
  541. package/_bmad/core/workflows/party-mode/workflow.md +0 -194
  542. package/_bmad/tea/agents/tea.md +0 -71
  543. package/_bmad/tea/config.yaml +0 -19
  544. package/_bmad/tea/module-help.csv +0 -10
  545. package/_bmad/tea/teams/default-party.csv +0 -2
  546. package/_bmad/tea/testarch/knowledge/adr-quality-readiness-checklist.md +0 -377
  547. package/_bmad/tea/testarch/knowledge/api-request.md +0 -442
  548. package/_bmad/tea/testarch/knowledge/api-testing-patterns.md +0 -851
  549. package/_bmad/tea/testarch/knowledge/auth-session.md +0 -548
  550. package/_bmad/tea/testarch/knowledge/burn-in.md +0 -273
  551. package/_bmad/tea/testarch/knowledge/ci-burn-in.md +0 -675
  552. package/_bmad/tea/testarch/knowledge/component-tdd.md +0 -486
  553. package/_bmad/tea/testarch/knowledge/contract-testing.md +0 -957
  554. package/_bmad/tea/testarch/knowledge/data-factories.md +0 -500
  555. package/_bmad/tea/testarch/knowledge/email-auth.md +0 -721
  556. package/_bmad/tea/testarch/knowledge/error-handling.md +0 -725
  557. package/_bmad/tea/testarch/knowledge/feature-flags.md +0 -750
  558. package/_bmad/tea/testarch/knowledge/file-utils.md +0 -456
  559. package/_bmad/tea/testarch/knowledge/fixture-architecture.md +0 -401
  560. package/_bmad/tea/testarch/knowledge/fixtures-composition.md +0 -382
  561. package/_bmad/tea/testarch/knowledge/intercept-network-call.md +0 -426
  562. package/_bmad/tea/testarch/knowledge/log.md +0 -426
  563. package/_bmad/tea/testarch/knowledge/network-error-monitor.md +0 -401
  564. package/_bmad/tea/testarch/knowledge/network-first.md +0 -486
  565. package/_bmad/tea/testarch/knowledge/network-recorder.md +0 -527
  566. package/_bmad/tea/testarch/knowledge/nfr-criteria.md +0 -670
  567. package/_bmad/tea/testarch/knowledge/overview.md +0 -286
  568. package/_bmad/tea/testarch/knowledge/playwright-config.md +0 -730
  569. package/_bmad/tea/testarch/knowledge/probability-impact.md +0 -601
  570. package/_bmad/tea/testarch/knowledge/recurse.md +0 -421
  571. package/_bmad/tea/testarch/knowledge/risk-governance.md +0 -615
  572. package/_bmad/tea/testarch/knowledge/selective-testing.md +0 -732
  573. package/_bmad/tea/testarch/knowledge/selector-resilience.md +0 -527
  574. package/_bmad/tea/testarch/knowledge/test-healing-patterns.md +0 -644
  575. package/_bmad/tea/testarch/knowledge/test-levels-framework.md +0 -473
  576. package/_bmad/tea/testarch/knowledge/test-priorities-matrix.md +0 -373
  577. package/_bmad/tea/testarch/knowledge/test-quality.md +0 -664
  578. package/_bmad/tea/testarch/knowledge/timing-debugging.md +0 -372
  579. package/_bmad/tea/testarch/knowledge/visual-debugging.md +0 -524
  580. package/_bmad/tea/testarch/tea-index.csv +0 -35
  581. package/_bmad/tea/workflows/testarch/README.md +0 -74
  582. package/_bmad/tea/workflows/testarch/atdd/atdd-checklist-template.md +0 -363
  583. package/_bmad/tea/workflows/testarch/atdd/checklist.md +0 -374
  584. package/_bmad/tea/workflows/testarch/atdd/instructions.md +0 -38
  585. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-01-preflight-and-context.md +0 -110
  586. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-02-generation-mode.md +0 -79
  587. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-03-test-strategy.md +0 -76
  588. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04-generate-tests.md +0 -228
  589. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04a-subprocess-api-failing.md +0 -215
  590. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04b-subprocess-e2e-failing.md +0 -212
  591. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04c-aggregate.md +0 -329
  592. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-05-validate-and-complete.md +0 -68
  593. package/_bmad/tea/workflows/testarch/atdd/steps-e/step-01-assess.md +0 -65
  594. package/_bmad/tea/workflows/testarch/atdd/steps-e/step-02-apply-edit.md +0 -60
  595. package/_bmad/tea/workflows/testarch/atdd/steps-v/step-01-validate.md +0 -67
  596. package/_bmad/tea/workflows/testarch/atdd/validation-report-20260127-095021.md +0 -73
  597. package/_bmad/tea/workflows/testarch/atdd/validation-report-20260127-102401.md +0 -116
  598. package/_bmad/tea/workflows/testarch/atdd/workflow-plan.md +0 -21
  599. package/_bmad/tea/workflows/testarch/atdd/workflow.md +0 -39
  600. package/_bmad/tea/workflows/testarch/atdd/workflow.yaml +0 -45
  601. package/_bmad/tea/workflows/testarch/automate/checklist.md +0 -582
  602. package/_bmad/tea/workflows/testarch/automate/instructions.md +0 -43
  603. package/_bmad/tea/workflows/testarch/automate/steps-c/step-01-preflight-and-context.md +0 -127
  604. package/_bmad/tea/workflows/testarch/automate/steps-c/step-02-identify-targets.md +0 -95
  605. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03-generate-tests.md +0 -199
  606. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03a-subprocess-api.md +0 -183
  607. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03b-subprocess-e2e.md +0 -181
  608. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03c-aggregate.md +0 -300
  609. package/_bmad/tea/workflows/testarch/automate/steps-c/step-04-validate-and-summarize.md +0 -69
  610. package/_bmad/tea/workflows/testarch/automate/steps-e/step-01-assess.md +0 -65
  611. package/_bmad/tea/workflows/testarch/automate/steps-e/step-02-apply-edit.md +0 -60
  612. package/_bmad/tea/workflows/testarch/automate/steps-v/step-01-validate.md +0 -67
  613. package/_bmad/tea/workflows/testarch/automate/validation-report-20260127-095021.md +0 -72
  614. package/_bmad/tea/workflows/testarch/automate/validation-report-20260127-102401.md +0 -114
  615. package/_bmad/tea/workflows/testarch/automate/workflow-plan.md +0 -20
  616. package/_bmad/tea/workflows/testarch/automate/workflow.md +0 -39
  617. package/_bmad/tea/workflows/testarch/automate/workflow.yaml +0 -52
  618. package/_bmad/tea/workflows/testarch/ci/checklist.md +0 -247
  619. package/_bmad/tea/workflows/testarch/ci/github-actions-template.yaml +0 -198
  620. package/_bmad/tea/workflows/testarch/ci/gitlab-ci-template.yaml +0 -149
  621. package/_bmad/tea/workflows/testarch/ci/instructions.md +0 -38
  622. package/_bmad/tea/workflows/testarch/ci/steps-c/step-01-preflight.md +0 -92
  623. package/_bmad/tea/workflows/testarch/ci/steps-c/step-02-generate-pipeline.md +0 -82
  624. package/_bmad/tea/workflows/testarch/ci/steps-c/step-03-configure-quality-gates.md +0 -75
  625. package/_bmad/tea/workflows/testarch/ci/steps-c/step-04-validate-and-summary.md +0 -67
  626. package/_bmad/tea/workflows/testarch/ci/steps-e/step-01-assess.md +0 -65
  627. package/_bmad/tea/workflows/testarch/ci/steps-e/step-02-apply-edit.md +0 -60
  628. package/_bmad/tea/workflows/testarch/ci/steps-v/step-01-validate.md +0 -67
  629. package/_bmad/tea/workflows/testarch/ci/validation-report-20260127-095021.md +0 -72
  630. package/_bmad/tea/workflows/testarch/ci/validation-report-20260127-102401.md +0 -114
  631. package/_bmad/tea/workflows/testarch/ci/workflow-plan.md +0 -20
  632. package/_bmad/tea/workflows/testarch/ci/workflow.md +0 -39
  633. package/_bmad/tea/workflows/testarch/ci/workflow.yaml +0 -45
  634. package/_bmad/tea/workflows/testarch/framework/checklist.md +0 -320
  635. package/_bmad/tea/workflows/testarch/framework/instructions.md +0 -38
  636. package/_bmad/tea/workflows/testarch/framework/steps-c/step-01-preflight.md +0 -75
  637. package/_bmad/tea/workflows/testarch/framework/steps-c/step-02-select-framework.md +0 -73
  638. package/_bmad/tea/workflows/testarch/framework/steps-c/step-03-scaffold-framework.md +0 -120
  639. package/_bmad/tea/workflows/testarch/framework/steps-c/step-04-docs-and-scripts.md +0 -70
  640. package/_bmad/tea/workflows/testarch/framework/steps-c/step-05-validate-and-summary.md +0 -68
  641. package/_bmad/tea/workflows/testarch/framework/steps-e/step-01-assess.md +0 -65
  642. package/_bmad/tea/workflows/testarch/framework/steps-e/step-02-apply-edit.md +0 -60
  643. package/_bmad/tea/workflows/testarch/framework/steps-v/step-01-validate.md +0 -67
  644. package/_bmad/tea/workflows/testarch/framework/validation-report-20260127-095021.md +0 -73
  645. package/_bmad/tea/workflows/testarch/framework/validation-report-20260127-102401.md +0 -116
  646. package/_bmad/tea/workflows/testarch/framework/workflow-plan.md +0 -22
  647. package/_bmad/tea/workflows/testarch/framework/workflow.md +0 -39
  648. package/_bmad/tea/workflows/testarch/framework/workflow.yaml +0 -47
  649. package/_bmad/tea/workflows/testarch/nfr-assess/checklist.md +0 -407
  650. package/_bmad/tea/workflows/testarch/nfr-assess/instructions.md +0 -36
  651. package/_bmad/tea/workflows/testarch/nfr-assess/nfr-report-template.md +0 -462
  652. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-01-load-context.md +0 -85
  653. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-02-define-thresholds.md +0 -82
  654. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-03-gather-evidence.md +0 -64
  655. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04-evaluate-and-score.md +0 -140
  656. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04a-subprocess-security.md +0 -138
  657. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04b-subprocess-performance.md +0 -84
  658. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04c-subprocess-reliability.md +0 -85
  659. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04d-subprocess-scalability.md +0 -88
  660. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04e-aggregate-nfr.md +0 -219
  661. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-05-generate-report.md +0 -71
  662. package/_bmad/tea/workflows/testarch/nfr-assess/steps-e/step-01-assess.md +0 -65
  663. package/_bmad/tea/workflows/testarch/nfr-assess/steps-e/step-02-apply-edit.md +0 -60
  664. package/_bmad/tea/workflows/testarch/nfr-assess/steps-v/step-01-validate.md +0 -67
  665. package/_bmad/tea/workflows/testarch/nfr-assess/validation-report-20260127-095021.md +0 -73
  666. package/_bmad/tea/workflows/testarch/nfr-assess/validation-report-20260127-102401.md +0 -116
  667. package/_bmad/tea/workflows/testarch/nfr-assess/workflow-plan.md +0 -19
  668. package/_bmad/tea/workflows/testarch/nfr-assess/workflow.md +0 -39
  669. package/_bmad/tea/workflows/testarch/nfr-assess/workflow.yaml +0 -47
  670. package/_bmad/tea/workflows/testarch/teach-me-testing/checklist.md +0 -197
  671. package/_bmad/tea/workflows/testarch/teach-me-testing/data/curriculum.yaml +0 -129
  672. package/_bmad/tea/workflows/testarch/teach-me-testing/data/quiz-questions.yaml +0 -206
  673. package/_bmad/tea/workflows/testarch/teach-me-testing/data/role-paths.yaml +0 -136
  674. package/_bmad/tea/workflows/testarch/teach-me-testing/data/session-content-map.yaml +0 -204
  675. package/_bmad/tea/workflows/testarch/teach-me-testing/data/tea-resources-index.yaml +0 -359
  676. package/_bmad/tea/workflows/testarch/teach-me-testing/instructions.md +0 -130
  677. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-01-init.md +0 -235
  678. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-01b-continue.md +0 -147
  679. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-02-assess.md +0 -258
  680. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-03-session-menu.md +0 -219
  681. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-01.md +0 -460
  682. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-02.md +0 -465
  683. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-03.md +0 -301
  684. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-04.md +0 -234
  685. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-05.md +0 -234
  686. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-06.md +0 -209
  687. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-07.md +0 -212
  688. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-05-completion.md +0 -339
  689. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-e/step-e-01-assess-workflow.md +0 -141
  690. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-e/step-e-02-apply-edits.md +0 -122
  691. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-v/step-v-01-validate.md +0 -263
  692. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/certificate-template.md +0 -86
  693. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/progress-template.yaml +0 -95
  694. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/session-notes-template.md +0 -83
  695. package/_bmad/tea/workflows/testarch/teach-me-testing/workflow-plan-teach-me-testing.md +0 -950
  696. package/_bmad/tea/workflows/testarch/teach-me-testing/workflow.md +0 -90
  697. package/_bmad/tea/workflows/testarch/test-design/checklist.md +0 -410
  698. package/_bmad/tea/workflows/testarch/test-design/instructions.md +0 -52
  699. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-01-detect-mode.md +0 -109
  700. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-02-load-context.md +0 -127
  701. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-03-risk-and-testability.md +0 -85
  702. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-04-coverage-plan.md +0 -98
  703. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-05-generate-output.md +0 -97
  704. package/_bmad/tea/workflows/testarch/test-design/steps-e/step-01-assess.md +0 -65
  705. package/_bmad/tea/workflows/testarch/test-design/steps-e/step-02-apply-edit.md +0 -60
  706. package/_bmad/tea/workflows/testarch/test-design/steps-v/step-01-validate.md +0 -67
  707. package/_bmad/tea/workflows/testarch/test-design/test-design-architecture-template.md +0 -222
  708. package/_bmad/tea/workflows/testarch/test-design/test-design-qa-template.md +0 -296
  709. package/_bmad/tea/workflows/testarch/test-design/test-design-template.md +0 -294
  710. package/_bmad/tea/workflows/testarch/test-design/validation-report-20260127-095021.md +0 -73
  711. package/_bmad/tea/workflows/testarch/test-design/validation-report-20260127-102401.md +0 -116
  712. package/_bmad/tea/workflows/testarch/test-design/workflow-plan.md +0 -22
  713. package/_bmad/tea/workflows/testarch/test-design/workflow.md +0 -39
  714. package/_bmad/tea/workflows/testarch/test-design/workflow.yaml +0 -69
  715. package/_bmad/tea/workflows/testarch/test-review/checklist.md +0 -472
  716. package/_bmad/tea/workflows/testarch/test-review/instructions.md +0 -36
  717. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-01-load-context.md +0 -101
  718. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-02-discover-tests.md +0 -69
  719. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03-quality-evaluation.md +0 -184
  720. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03a-subprocess-determinism.md +0 -214
  721. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03b-subprocess-isolation.md +0 -125
  722. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03c-subprocess-maintainability.md +0 -102
  723. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03d-subprocess-coverage.md +0 -111
  724. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03e-subprocess-performance.md +0 -117
  725. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03f-aggregate-scores.md +0 -246
  726. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-04-generate-report.md +0 -72
  727. package/_bmad/tea/workflows/testarch/test-review/steps-e/step-01-assess.md +0 -65
  728. package/_bmad/tea/workflows/testarch/test-review/steps-e/step-02-apply-edit.md +0 -60
  729. package/_bmad/tea/workflows/testarch/test-review/steps-v/step-01-validate.md +0 -67
  730. package/_bmad/tea/workflows/testarch/test-review/test-review-template.md +0 -390
  731. package/_bmad/tea/workflows/testarch/test-review/validation-report-20260127-095021.md +0 -72
  732. package/_bmad/tea/workflows/testarch/test-review/validation-report-20260127-102401.md +0 -114
  733. package/_bmad/tea/workflows/testarch/test-review/workflow-plan.md +0 -18
  734. package/_bmad/tea/workflows/testarch/test-review/workflow.md +0 -39
  735. package/_bmad/tea/workflows/testarch/test-review/workflow.yaml +0 -46
  736. package/_bmad/tea/workflows/testarch/trace/checklist.md +0 -642
  737. package/_bmad/tea/workflows/testarch/trace/instructions.md +0 -36
  738. package/_bmad/tea/workflows/testarch/trace/steps-c/step-01-load-context.md +0 -80
  739. package/_bmad/tea/workflows/testarch/trace/steps-c/step-02-discover-tests.md +0 -69
  740. package/_bmad/tea/workflows/testarch/trace/steps-c/step-03-map-criteria.md +0 -65
  741. package/_bmad/tea/workflows/testarch/trace/steps-c/step-04-analyze-gaps.md +0 -244
  742. package/_bmad/tea/workflows/testarch/trace/steps-c/step-05-gate-decision.md +0 -232
  743. package/_bmad/tea/workflows/testarch/trace/steps-e/step-01-assess.md +0 -65
  744. package/_bmad/tea/workflows/testarch/trace/steps-e/step-02-apply-edit.md +0 -60
  745. package/_bmad/tea/workflows/testarch/trace/steps-v/step-01-validate.md +0 -67
  746. package/_bmad/tea/workflows/testarch/trace/trace-template.md +0 -675
  747. package/_bmad/tea/workflows/testarch/trace/validation-report-20260127-095021.md +0 -73
  748. package/_bmad/tea/workflows/testarch/trace/validation-report-20260127-102401.md +0 -116
  749. package/_bmad/tea/workflows/testarch/trace/workflow-plan.md +0 -21
  750. package/_bmad/tea/workflows/testarch/trace/workflow.md +0 -39
  751. package/_bmad/tea/workflows/testarch/trace/workflow.yaml +0 -55
@@ -1,957 +0,0 @@
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_