bmad-studio 0.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 (798) hide show
  1. package/.prettierrc +8 -0
  2. package/CONTRIBUTING.md +109 -0
  3. package/LICENSE +21 -0
  4. package/README.md +110 -0
  5. package/_bmad/_config/agent-manifest.csv +11 -0
  6. package/_bmad/_config/bmad-help.csv +57 -0
  7. package/_bmad/_config/files-manifest.csv +646 -0
  8. package/_bmad/_config/ides/claude-code.yaml +5 -0
  9. package/_bmad/_config/manifest.yaml +42 -0
  10. package/_bmad/_config/skill-manifest.csv +48 -0
  11. package/_bmad/_config/task-manifest.csv +1 -0
  12. package/_bmad/_config/tool-manifest.csv +1 -0
  13. package/_bmad/_config/workflow-manifest.csv +1 -0
  14. package/_bmad/bmb/config.yaml +13 -0
  15. package/_bmad/bmb/module-help.csv +7 -0
  16. package/_bmad/bmb/skills/bmad-agent-builder/SKILL.md +65 -0
  17. package/_bmad/bmb/skills/bmad-agent-builder/assets/SKILL-template.md +97 -0
  18. package/_bmad/bmb/skills/bmad-agent-builder/assets/autonomous-wake.md +37 -0
  19. package/_bmad/bmb/skills/bmad-agent-builder/assets/init-template.md +47 -0
  20. package/_bmad/bmb/skills/bmad-agent-builder/assets/memory-system.md +129 -0
  21. package/_bmad/bmb/skills/bmad-agent-builder/assets/quality-report-template.md +282 -0
  22. package/_bmad/bmb/skills/bmad-agent-builder/assets/save-memory.md +29 -0
  23. package/_bmad/bmb/skills/bmad-agent-builder/bmad-manifest.json +24 -0
  24. package/_bmad/bmb/skills/bmad-agent-builder/bmad-skill-manifest.yaml +1 -0
  25. package/_bmad/bmb/skills/bmad-agent-builder/build-process.md +199 -0
  26. package/_bmad/bmb/skills/bmad-agent-builder/quality-optimizer.md +208 -0
  27. package/_bmad/bmb/skills/bmad-agent-builder/quality-scan-agent-cohesion.md +272 -0
  28. package/_bmad/bmb/skills/bmad-agent-builder/quality-scan-enhancement-opportunities.md +277 -0
  29. package/_bmad/bmb/skills/bmad-agent-builder/quality-scan-execution-efficiency.md +181 -0
  30. package/_bmad/bmb/skills/bmad-agent-builder/quality-scan-prompt-craft.md +245 -0
  31. package/_bmad/bmb/skills/bmad-agent-builder/quality-scan-script-opportunities.md +262 -0
  32. package/_bmad/bmb/skills/bmad-agent-builder/quality-scan-structure.md +183 -0
  33. package/_bmad/bmb/skills/bmad-agent-builder/references/metadata-reference.md +126 -0
  34. package/_bmad/bmb/skills/bmad-agent-builder/references/quality-dimensions.md +46 -0
  35. package/_bmad/bmb/skills/bmad-agent-builder/references/script-opportunities-reference.md +385 -0
  36. package/_bmad/bmb/skills/bmad-agent-builder/references/skill-best-practices.md +218 -0
  37. package/_bmad/bmb/skills/bmad-agent-builder/references/standard-fields.md +103 -0
  38. package/_bmad/bmb/skills/bmad-agent-builder/references/template-substitution-rules.md +72 -0
  39. package/_bmad/bmb/skills/bmad-agent-builder/references/universal-scan-schema.md +267 -0
  40. package/_bmad/bmb/skills/bmad-agent-builder/report-quality-scan-creator.md +138 -0
  41. package/_bmad/bmb/skills/bmad-agent-builder/scripts/bmad-manifest-schema.json +103 -0
  42. package/_bmad/bmb/skills/bmad-agent-builder/scripts/generate-html-report.py +1002 -0
  43. package/_bmad/bmb/skills/bmad-agent-builder/scripts/manifest.py +420 -0
  44. package/_bmad/bmb/skills/bmad-agent-builder/scripts/prepass-execution-deps.py +368 -0
  45. package/_bmad/bmb/skills/bmad-agent-builder/scripts/prepass-prompt-metrics.py +476 -0
  46. package/_bmad/bmb/skills/bmad-agent-builder/scripts/prepass-structure-capabilities.py +636 -0
  47. package/_bmad/bmb/skills/bmad-agent-builder/scripts/scan-path-standards.py +253 -0
  48. package/_bmad/bmb/skills/bmad-agent-builder/scripts/scan-scripts.py +745 -0
  49. package/_bmad/bmb/skills/bmad-workflow-builder/SKILL.md +65 -0
  50. package/_bmad/bmb/skills/bmad-workflow-builder/assets/SKILL-template.md +117 -0
  51. package/_bmad/bmb/skills/bmad-workflow-builder/assets/quality-report-template.md +260 -0
  52. package/_bmad/bmb/skills/bmad-workflow-builder/bmad-manifest.json +23 -0
  53. package/_bmad/bmb/skills/bmad-workflow-builder/bmad-skill-manifest.yaml +1 -0
  54. package/_bmad/bmb/skills/bmad-workflow-builder/build-process.md +208 -0
  55. package/_bmad/bmb/skills/bmad-workflow-builder/quality-optimizer.md +209 -0
  56. package/_bmad/bmb/skills/bmad-workflow-builder/quality-scan-enhancement-opportunities.md +273 -0
  57. package/_bmad/bmb/skills/bmad-workflow-builder/quality-scan-execution-efficiency.md +322 -0
  58. package/_bmad/bmb/skills/bmad-workflow-builder/quality-scan-prompt-craft.md +328 -0
  59. package/_bmad/bmb/skills/bmad-workflow-builder/quality-scan-script-opportunities.md +261 -0
  60. package/_bmad/bmb/skills/bmad-workflow-builder/quality-scan-skill-cohesion.md +340 -0
  61. package/_bmad/bmb/skills/bmad-workflow-builder/quality-scan-workflow-integrity.md +280 -0
  62. package/_bmad/bmb/skills/bmad-workflow-builder/references/classification-reference.md +61 -0
  63. package/_bmad/bmb/skills/bmad-workflow-builder/references/complex-workflow-patterns.md +523 -0
  64. package/_bmad/bmb/skills/bmad-workflow-builder/references/metadata-reference.md +126 -0
  65. package/_bmad/bmb/skills/bmad-workflow-builder/references/quality-dimensions.md +45 -0
  66. package/_bmad/bmb/skills/bmad-workflow-builder/references/script-opportunities-reference.md +354 -0
  67. package/_bmad/bmb/skills/bmad-workflow-builder/references/skill-best-practices.md +218 -0
  68. package/_bmad/bmb/skills/bmad-workflow-builder/references/standard-fields.md +121 -0
  69. package/_bmad/bmb/skills/bmad-workflow-builder/references/template-substitution-rules.md +85 -0
  70. package/_bmad/bmb/skills/bmad-workflow-builder/references/universal-scan-schema.md +267 -0
  71. package/_bmad/bmb/skills/bmad-workflow-builder/report-quality-scan-creator.md +134 -0
  72. package/_bmad/bmb/skills/bmad-workflow-builder/scripts/bmad-manifest-schema.json +103 -0
  73. package/_bmad/bmb/skills/bmad-workflow-builder/scripts/generate-html-report.py +1002 -0
  74. package/_bmad/bmb/skills/bmad-workflow-builder/scripts/manifest.py +420 -0
  75. package/_bmad/bmb/skills/bmad-workflow-builder/scripts/prepass-execution-deps.py +313 -0
  76. package/_bmad/bmb/skills/bmad-workflow-builder/scripts/prepass-prompt-metrics.py +285 -0
  77. package/_bmad/bmb/skills/bmad-workflow-builder/scripts/prepass-workflow-integrity.py +485 -0
  78. package/_bmad/bmb/skills/bmad-workflow-builder/scripts/scan-path-standards.py +213 -0
  79. package/_bmad/bmb/skills/bmad-workflow-builder/scripts/scan-scripts.py +745 -0
  80. package/_bmad/bmm/agents/analyst.md +69 -0
  81. package/_bmad/bmm/agents/architect.md +59 -0
  82. package/_bmad/bmm/agents/bmad-skill-manifest.yaml +39 -0
  83. package/_bmad/bmm/agents/dev.md +66 -0
  84. package/_bmad/bmm/agents/pm.md +63 -0
  85. package/_bmad/bmm/agents/qa.md +89 -0
  86. package/_bmad/bmm/agents/quick-flow-solo-dev.md +61 -0
  87. package/_bmad/bmm/agents/sm.md +67 -0
  88. package/_bmad/bmm/agents/tech-writer/bmad-skill-manifest.yaml +3 -0
  89. package/_bmad/bmm/agents/tech-writer/tech-writer.md +67 -0
  90. package/_bmad/bmm/agents/ux-designer.md +58 -0
  91. package/_bmad/bmm/config.yaml +16 -0
  92. package/_bmad/bmm/data/project-context-template.md +26 -0
  93. package/_bmad/bmm/module-help.csv +32 -0
  94. package/_bmad/bmm/teams/default-party.csv +20 -0
  95. package/_bmad/bmm/teams/team-fullstack.yaml +12 -0
  96. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/SKILL.md +6 -0
  97. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/bmad-skill-manifest.yaml +1 -0
  98. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/product-brief.template.md +10 -0
  99. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/steps/step-01-init.md +170 -0
  100. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/steps/step-01b-continue.md +158 -0
  101. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/steps/step-02-vision.md +193 -0
  102. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/steps/step-03-users.md +196 -0
  103. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/steps/step-04-metrics.md +199 -0
  104. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/steps/step-05-scope.md +213 -0
  105. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/steps/step-06-complete.md +159 -0
  106. package/_bmad/bmm/workflows/1-analysis/bmad-create-product-brief/workflow.md +55 -0
  107. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/SKILL.md +88 -0
  108. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/agents/artifact-analyzer.md +60 -0
  109. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/agents/opportunity-reviewer.md +44 -0
  110. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/agents/skeptic-reviewer.md +44 -0
  111. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/agents/web-researcher.md +49 -0
  112. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/bmad-manifest.json +17 -0
  113. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/bmad-skill-manifest.yaml +1 -0
  114. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/prompts/contextual-discovery.md +57 -0
  115. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/prompts/draft-and-review.md +86 -0
  116. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/prompts/finalize.md +75 -0
  117. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/prompts/guided-elicitation.md +70 -0
  118. package/_bmad/bmm/workflows/1-analysis/bmad-product-brief-preview/resources/brief-template.md +60 -0
  119. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/SKILL.md +6 -0
  120. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/bmad-skill-manifest.yaml +1 -0
  121. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/domain-steps/step-01-init.md +137 -0
  122. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/domain-steps/step-02-domain-analysis.md +229 -0
  123. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/domain-steps/step-03-competitive-landscape.md +238 -0
  124. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/domain-steps/step-04-regulatory-focus.md +206 -0
  125. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/domain-steps/step-05-technical-trends.md +234 -0
  126. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/domain-steps/step-06-research-synthesis.md +444 -0
  127. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/research.template.md +29 -0
  128. package/_bmad/bmm/workflows/1-analysis/research/bmad-domain-research/workflow.md +49 -0
  129. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/SKILL.md +6 -0
  130. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/bmad-skill-manifest.yaml +1 -0
  131. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/research.template.md +29 -0
  132. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/steps/step-01-init.md +184 -0
  133. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/steps/step-02-customer-behavior.md +239 -0
  134. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/steps/step-03-customer-pain-points.md +251 -0
  135. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/steps/step-04-customer-decisions.md +261 -0
  136. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/steps/step-05-competitive-analysis.md +173 -0
  137. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/steps/step-06-research-completion.md +478 -0
  138. package/_bmad/bmm/workflows/1-analysis/research/bmad-market-research/workflow.md +49 -0
  139. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/SKILL.md +6 -0
  140. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/bmad-skill-manifest.yaml +1 -0
  141. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/research.template.md +29 -0
  142. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/technical-steps/step-01-init.md +137 -0
  143. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/technical-steps/step-02-technical-overview.md +239 -0
  144. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/technical-steps/step-03-integration-patterns.md +248 -0
  145. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/technical-steps/step-04-architectural-patterns.md +202 -0
  146. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/technical-steps/step-05-implementation-research.md +233 -0
  147. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/technical-steps/step-06-research-synthesis.md +487 -0
  148. package/_bmad/bmm/workflows/1-analysis/research/bmad-technical-research/workflow.md +50 -0
  149. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
  150. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
  151. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
  152. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
  153. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
  154. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +476 -0
  155. package/_bmad/bmm/workflows/1-analysis/research/research.template.md +29 -0
  156. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/SKILL.md +6 -0
  157. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/bmad-skill-manifest.yaml +1 -0
  158. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-01-init.md +135 -0
  159. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-01b-continue.md +127 -0
  160. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-02-discovery.md +190 -0
  161. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-03-core-experience.md +217 -0
  162. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-04-emotional-response.md +220 -0
  163. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-05-inspiration.md +235 -0
  164. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-06-design-system.md +253 -0
  165. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-07-defining-experience.md +255 -0
  166. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-08-visual-foundation.md +225 -0
  167. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-09-design-directions.md +225 -0
  168. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-10-user-journeys.md +242 -0
  169. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-11-component-strategy.md +249 -0
  170. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-12-ux-patterns.md +238 -0
  171. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-13-responsive-accessibility.md +265 -0
  172. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/steps/step-14-complete.md +171 -0
  173. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/ux-design-template.md +13 -0
  174. package/_bmad/bmm/workflows/2-plan-workflows/bmad-create-ux-design/workflow.md +36 -0
  175. package/_bmad/bmm/workflows/2-plan-workflows/bmad-edit-prd/SKILL.md +6 -0
  176. package/_bmad/bmm/workflows/2-plan-workflows/bmad-edit-prd/bmad-skill-manifest.yaml +1 -0
  177. package/_bmad/bmm/workflows/2-plan-workflows/bmad-edit-prd/steps-e/step-e-01-discovery.md +242 -0
  178. package/_bmad/bmm/workflows/2-plan-workflows/bmad-edit-prd/steps-e/step-e-01b-legacy-conversion.md +204 -0
  179. package/_bmad/bmm/workflows/2-plan-workflows/bmad-edit-prd/steps-e/step-e-02-review.md +245 -0
  180. package/_bmad/bmm/workflows/2-plan-workflows/bmad-edit-prd/steps-e/step-e-03-edit.md +250 -0
  181. package/_bmad/bmm/workflows/2-plan-workflows/bmad-edit-prd/steps-e/step-e-04-complete.md +165 -0
  182. package/_bmad/bmm/workflows/2-plan-workflows/bmad-edit-prd/workflow.md +63 -0
  183. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/SKILL.md +6 -0
  184. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/bmad-skill-manifest.yaml +1 -0
  185. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/data/domain-complexity.csv +15 -0
  186. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/data/prd-purpose.md +197 -0
  187. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/data/project-types.csv +11 -0
  188. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-01-discovery.md +221 -0
  189. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-02-format-detection.md +188 -0
  190. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-02b-parity-check.md +206 -0
  191. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-03-density-validation.md +171 -0
  192. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-04-brief-coverage-validation.md +211 -0
  193. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-05-measurability-validation.md +225 -0
  194. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-06-traceability-validation.md +214 -0
  195. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-07-implementation-leakage-validation.md +202 -0
  196. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-08-domain-compliance-validation.md +240 -0
  197. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-09-project-type-validation.md +260 -0
  198. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-10-smart-validation.md +206 -0
  199. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-11-holistic-quality-validation.md +261 -0
  200. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-12-completeness-validation.md +239 -0
  201. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/steps-v/step-v-13-report-complete.md +229 -0
  202. package/_bmad/bmm/workflows/2-plan-workflows/bmad-validate-prd/workflow.md +62 -0
  203. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +15 -0
  204. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +197 -0
  205. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/project-types.csv +11 -0
  206. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +224 -0
  207. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +191 -0
  208. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +209 -0
  209. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +174 -0
  210. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
  211. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +228 -0
  212. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +217 -0
  213. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
  214. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
  215. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +263 -0
  216. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +209 -0
  217. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
  218. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +242 -0
  219. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +232 -0
  220. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/workflow-validate-prd.md +65 -0
  221. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/SKILL.md +6 -0
  222. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/bmad-skill-manifest.yaml +1 -0
  223. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/steps/step-01-document-discovery.md +179 -0
  224. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/steps/step-02-prd-analysis.md +168 -0
  225. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/steps/step-03-epic-coverage-validation.md +169 -0
  226. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/steps/step-04-ux-alignment.md +129 -0
  227. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/steps/step-05-epic-quality-review.md +241 -0
  228. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/steps/step-06-final-assessment.md +126 -0
  229. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/templates/readiness-report-template.md +4 -0
  230. package/_bmad/bmm/workflows/3-solutioning/bmad-check-implementation-readiness/workflow.md +49 -0
  231. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/SKILL.md +6 -0
  232. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/architecture-decision-template.md +12 -0
  233. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/bmad-skill-manifest.yaml +1 -0
  234. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/data/domain-complexity.csv +13 -0
  235. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/data/project-types.csv +7 -0
  236. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-01-init.md +153 -0
  237. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-01b-continue.md +173 -0
  238. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-02-context.md +224 -0
  239. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-03-starter.md +329 -0
  240. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-04-decisions.md +318 -0
  241. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-05-patterns.md +359 -0
  242. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-06-structure.md +379 -0
  243. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-07-validation.md +359 -0
  244. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/steps/step-08-complete.md +76 -0
  245. package/_bmad/bmm/workflows/3-solutioning/bmad-create-architecture/workflow.md +38 -0
  246. package/_bmad/bmm/workflows/3-solutioning/bmad-create-epics-and-stories/SKILL.md +6 -0
  247. package/_bmad/bmm/workflows/3-solutioning/bmad-create-epics-and-stories/bmad-skill-manifest.yaml +1 -0
  248. package/_bmad/bmm/workflows/3-solutioning/bmad-create-epics-and-stories/steps/step-01-validate-prerequisites.md +255 -0
  249. package/_bmad/bmm/workflows/3-solutioning/bmad-create-epics-and-stories/steps/step-02-design-epics.md +212 -0
  250. package/_bmad/bmm/workflows/3-solutioning/bmad-create-epics-and-stories/steps/step-03-create-stories.md +255 -0
  251. package/_bmad/bmm/workflows/3-solutioning/bmad-create-epics-and-stories/steps/step-04-final-validation.md +131 -0
  252. package/_bmad/bmm/workflows/3-solutioning/bmad-create-epics-and-stories/templates/epics-template.md +61 -0
  253. package/_bmad/bmm/workflows/3-solutioning/bmad-create-epics-and-stories/workflow.md +53 -0
  254. package/_bmad/bmm/workflows/4-implementation/bmad-code-review/SKILL.md +6 -0
  255. package/_bmad/bmm/workflows/4-implementation/bmad-code-review/bmad-skill-manifest.yaml +1 -0
  256. package/_bmad/bmm/workflows/4-implementation/bmad-code-review/steps/step-01-gather-context.md +61 -0
  257. package/_bmad/bmm/workflows/4-implementation/bmad-code-review/steps/step-02-review.md +41 -0
  258. package/_bmad/bmm/workflows/4-implementation/bmad-code-review/steps/step-03-triage.md +50 -0
  259. package/_bmad/bmm/workflows/4-implementation/bmad-code-review/steps/step-04-present.md +38 -0
  260. package/_bmad/bmm/workflows/4-implementation/bmad-code-review/workflow.md +54 -0
  261. package/_bmad/bmm/workflows/4-implementation/bmad-correct-course/SKILL.md +6 -0
  262. package/_bmad/bmm/workflows/4-implementation/bmad-correct-course/bmad-skill-manifest.yaml +1 -0
  263. package/_bmad/bmm/workflows/4-implementation/bmad-correct-course/checklist.md +288 -0
  264. package/_bmad/bmm/workflows/4-implementation/bmad-correct-course/workflow.md +267 -0
  265. package/_bmad/bmm/workflows/4-implementation/bmad-create-story/SKILL.md +6 -0
  266. package/_bmad/bmm/workflows/4-implementation/bmad-create-story/bmad-skill-manifest.yaml +1 -0
  267. package/_bmad/bmm/workflows/4-implementation/bmad-create-story/checklist.md +357 -0
  268. package/_bmad/bmm/workflows/4-implementation/bmad-create-story/discover-inputs.md +88 -0
  269. package/_bmad/bmm/workflows/4-implementation/bmad-create-story/template.md +49 -0
  270. package/_bmad/bmm/workflows/4-implementation/bmad-create-story/workflow.md +380 -0
  271. package/_bmad/bmm/workflows/4-implementation/bmad-dev-story/SKILL.md +6 -0
  272. package/_bmad/bmm/workflows/4-implementation/bmad-dev-story/bmad-skill-manifest.yaml +1 -0
  273. package/_bmad/bmm/workflows/4-implementation/bmad-dev-story/checklist.md +80 -0
  274. package/_bmad/bmm/workflows/4-implementation/bmad-dev-story/workflow.md +450 -0
  275. package/_bmad/bmm/workflows/4-implementation/bmad-retrospective/SKILL.md +6 -0
  276. package/_bmad/bmm/workflows/4-implementation/bmad-retrospective/bmad-skill-manifest.yaml +1 -0
  277. package/_bmad/bmm/workflows/4-implementation/bmad-retrospective/workflow.md +1479 -0
  278. package/_bmad/bmm/workflows/4-implementation/bmad-sprint-planning/SKILL.md +6 -0
  279. package/_bmad/bmm/workflows/4-implementation/bmad-sprint-planning/bmad-skill-manifest.yaml +1 -0
  280. package/_bmad/bmm/workflows/4-implementation/bmad-sprint-planning/checklist.md +33 -0
  281. package/_bmad/bmm/workflows/4-implementation/bmad-sprint-planning/sprint-status-template.yaml +56 -0
  282. package/_bmad/bmm/workflows/4-implementation/bmad-sprint-planning/workflow.md +263 -0
  283. package/_bmad/bmm/workflows/4-implementation/bmad-sprint-status/SKILL.md +6 -0
  284. package/_bmad/bmm/workflows/4-implementation/bmad-sprint-status/bmad-skill-manifest.yaml +1 -0
  285. package/_bmad/bmm/workflows/4-implementation/bmad-sprint-status/workflow.md +261 -0
  286. package/_bmad/bmm/workflows/bmad-document-project/SKILL.md +6 -0
  287. package/_bmad/bmm/workflows/bmad-document-project/bmad-skill-manifest.yaml +1 -0
  288. package/_bmad/bmm/workflows/bmad-document-project/checklist.md +245 -0
  289. package/_bmad/bmm/workflows/bmad-document-project/documentation-requirements.csv +12 -0
  290. package/_bmad/bmm/workflows/bmad-document-project/instructions.md +128 -0
  291. package/_bmad/bmm/workflows/bmad-document-project/templates/deep-dive-template.md +345 -0
  292. package/_bmad/bmm/workflows/bmad-document-project/templates/index-template.md +169 -0
  293. package/_bmad/bmm/workflows/bmad-document-project/templates/project-overview-template.md +103 -0
  294. package/_bmad/bmm/workflows/bmad-document-project/templates/project-scan-report-schema.json +160 -0
  295. package/_bmad/bmm/workflows/bmad-document-project/templates/source-tree-template.md +135 -0
  296. package/_bmad/bmm/workflows/bmad-document-project/workflow.md +27 -0
  297. package/_bmad/bmm/workflows/bmad-document-project/workflows/deep-dive-instructions.md +299 -0
  298. package/_bmad/bmm/workflows/bmad-document-project/workflows/deep-dive-workflow.md +34 -0
  299. package/_bmad/bmm/workflows/bmad-document-project/workflows/full-scan-instructions.md +1107 -0
  300. package/_bmad/bmm/workflows/bmad-document-project/workflows/full-scan-workflow.md +34 -0
  301. package/_bmad/bmm/workflows/bmad-generate-project-context/SKILL.md +6 -0
  302. package/_bmad/bmm/workflows/bmad-generate-project-context/bmad-skill-manifest.yaml +1 -0
  303. package/_bmad/bmm/workflows/bmad-generate-project-context/project-context-template.md +21 -0
  304. package/_bmad/bmm/workflows/bmad-generate-project-context/steps/step-01-discover.md +186 -0
  305. package/_bmad/bmm/workflows/bmad-generate-project-context/steps/step-02-generate.md +321 -0
  306. package/_bmad/bmm/workflows/bmad-generate-project-context/steps/step-03-complete.md +278 -0
  307. package/_bmad/bmm/workflows/bmad-generate-project-context/workflow.md +43 -0
  308. package/_bmad/bmm/workflows/bmad-qa-generate-e2e-tests/SKILL.md +6 -0
  309. package/_bmad/bmm/workflows/bmad-qa-generate-e2e-tests/bmad-skill-manifest.yaml +1 -0
  310. package/_bmad/bmm/workflows/bmad-qa-generate-e2e-tests/checklist.md +33 -0
  311. package/_bmad/bmm/workflows/bmad-qa-generate-e2e-tests/workflow.md +136 -0
  312. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/SKILL.md +6 -0
  313. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/bmad-skill-manifest.yaml +1 -0
  314. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/steps/step-01-mode-detection.md +169 -0
  315. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/steps/step-02-context-gathering.md +114 -0
  316. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/steps/step-03-execute.md +107 -0
  317. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/steps/step-04-self-check.md +107 -0
  318. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/steps/step-05-adversarial-review.md +94 -0
  319. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/steps/step-06-resolve-findings.md +144 -0
  320. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev/workflow.md +38 -0
  321. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/SKILL.md +6 -0
  322. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/bmad-skill-manifest.yaml +1 -0
  323. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/steps/step-01-clarify-and-route.md +51 -0
  324. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/steps/step-02-plan.md +35 -0
  325. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/steps/step-03-implement.md +33 -0
  326. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/steps/step-04-review.md +50 -0
  327. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/steps/step-05-present.md +17 -0
  328. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/tech-spec-template.md +90 -0
  329. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-dev-new-preview/workflow.md +79 -0
  330. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-spec/SKILL.md +6 -0
  331. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-spec/bmad-skill-manifest.yaml +1 -0
  332. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-spec/steps/step-01-understand.md +185 -0
  333. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-spec/steps/step-02-investigate.md +140 -0
  334. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-spec/steps/step-03-generate.md +123 -0
  335. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-spec/steps/step-04-review.md +195 -0
  336. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-spec/tech-spec-template.md +74 -0
  337. package/_bmad/bmm/workflows/bmad-quick-flow/bmad-quick-spec/workflow.md +73 -0
  338. package/_bmad/core/config.yaml +9 -0
  339. package/_bmad/core/module-help.csv +11 -0
  340. package/_bmad/core/skills/bmad-advanced-elicitation/SKILL.md +6 -0
  341. package/_bmad/core/skills/bmad-advanced-elicitation/bmad-skill-manifest.yaml +1 -0
  342. package/_bmad/core/skills/bmad-advanced-elicitation/methods.csv +51 -0
  343. package/_bmad/core/skills/bmad-advanced-elicitation/workflow.md +135 -0
  344. package/_bmad/core/skills/bmad-brainstorming/SKILL.md +6 -0
  345. package/_bmad/core/skills/bmad-brainstorming/bmad-skill-manifest.yaml +1 -0
  346. package/_bmad/core/skills/bmad-brainstorming/brain-methods.csv +62 -0
  347. package/_bmad/core/skills/bmad-brainstorming/steps/step-01-session-setup.md +214 -0
  348. package/_bmad/core/skills/bmad-brainstorming/steps/step-01b-continue.md +124 -0
  349. package/_bmad/core/skills/bmad-brainstorming/steps/step-02a-user-selected.md +229 -0
  350. package/_bmad/core/skills/bmad-brainstorming/steps/step-02b-ai-recommended.md +239 -0
  351. package/_bmad/core/skills/bmad-brainstorming/steps/step-02c-random-selection.md +211 -0
  352. package/_bmad/core/skills/bmad-brainstorming/steps/step-02d-progressive-flow.md +266 -0
  353. package/_bmad/core/skills/bmad-brainstorming/steps/step-03-technique-execution.md +401 -0
  354. package/_bmad/core/skills/bmad-brainstorming/steps/step-04-idea-organization.md +305 -0
  355. package/_bmad/core/skills/bmad-brainstorming/template.md +15 -0
  356. package/_bmad/core/skills/bmad-brainstorming/workflow.md +53 -0
  357. package/_bmad/core/skills/bmad-distillator/SKILL.md +178 -0
  358. package/_bmad/core/skills/bmad-distillator/agents/distillate-compressor.md +116 -0
  359. package/_bmad/core/skills/bmad-distillator/agents/round-trip-reconstructor.md +68 -0
  360. package/_bmad/core/skills/bmad-distillator/bmad-skill-manifest.yaml +15 -0
  361. package/_bmad/core/skills/bmad-distillator/resources/compression-rules.md +51 -0
  362. package/_bmad/core/skills/bmad-distillator/resources/distillate-format-reference.md +227 -0
  363. package/_bmad/core/skills/bmad-distillator/resources/splitting-strategy.md +78 -0
  364. package/_bmad/core/skills/bmad-distillator/scripts/analyze_sources.py +300 -0
  365. package/_bmad/core/skills/bmad-distillator/scripts/tests/test_analyze_sources.py +204 -0
  366. package/_bmad/core/skills/bmad-editorial-review-prose/SKILL.md +6 -0
  367. package/_bmad/core/skills/bmad-editorial-review-prose/bmad-skill-manifest.yaml +1 -0
  368. package/_bmad/core/skills/bmad-editorial-review-prose/workflow.md +81 -0
  369. package/_bmad/core/skills/bmad-editorial-review-structure/SKILL.md +6 -0
  370. package/_bmad/core/skills/bmad-editorial-review-structure/bmad-skill-manifest.yaml +1 -0
  371. package/_bmad/core/skills/bmad-editorial-review-structure/workflow.md +174 -0
  372. package/_bmad/core/skills/bmad-help/SKILL.md +6 -0
  373. package/_bmad/core/skills/bmad-help/bmad-skill-manifest.yaml +1 -0
  374. package/_bmad/core/skills/bmad-help/workflow.md +88 -0
  375. package/_bmad/core/skills/bmad-index-docs/SKILL.md +6 -0
  376. package/_bmad/core/skills/bmad-index-docs/bmad-skill-manifest.yaml +1 -0
  377. package/_bmad/core/skills/bmad-index-docs/workflow.md +61 -0
  378. package/_bmad/core/skills/bmad-party-mode/SKILL.md +6 -0
  379. package/_bmad/core/skills/bmad-party-mode/bmad-skill-manifest.yaml +1 -0
  380. package/_bmad/core/skills/bmad-party-mode/steps/step-01-agent-loading.md +138 -0
  381. package/_bmad/core/skills/bmad-party-mode/steps/step-02-discussion-orchestration.md +187 -0
  382. package/_bmad/core/skills/bmad-party-mode/steps/step-03-graceful-exit.md +167 -0
  383. package/_bmad/core/skills/bmad-party-mode/workflow.md +190 -0
  384. package/_bmad/core/skills/bmad-review-adversarial-general/SKILL.md +6 -0
  385. package/_bmad/core/skills/bmad-review-adversarial-general/bmad-skill-manifest.yaml +1 -0
  386. package/_bmad/core/skills/bmad-review-adversarial-general/workflow.md +32 -0
  387. package/_bmad/core/skills/bmad-review-edge-case-hunter/SKILL.md +6 -0
  388. package/_bmad/core/skills/bmad-review-edge-case-hunter/bmad-skill-manifest.yaml +1 -0
  389. package/_bmad/core/skills/bmad-review-edge-case-hunter/workflow.md +62 -0
  390. package/_bmad/core/skills/bmad-shard-doc/SKILL.md +6 -0
  391. package/_bmad/core/skills/bmad-shard-doc/bmad-skill-manifest.yaml +1 -0
  392. package/_bmad/core/skills/bmad-shard-doc/workflow.md +100 -0
  393. package/_bmad/core/tasks/bmad-create-prd/SKILL.md +6 -0
  394. package/_bmad/core/tasks/bmad-create-prd/bmad-skill-manifest.yaml +1 -0
  395. package/_bmad/core/tasks/bmad-create-prd/data/domain-complexity.csv +15 -0
  396. package/_bmad/core/tasks/bmad-create-prd/data/prd-purpose.md +197 -0
  397. package/_bmad/core/tasks/bmad-create-prd/data/project-types.csv +11 -0
  398. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-01-init.md +178 -0
  399. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-01b-continue.md +161 -0
  400. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-02-discovery.md +208 -0
  401. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-02b-vision.md +142 -0
  402. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-02c-executive-summary.md +158 -0
  403. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-03-success.md +214 -0
  404. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-04-journeys.md +201 -0
  405. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-05-domain.md +194 -0
  406. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-06-innovation.md +211 -0
  407. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-07-project-type.md +222 -0
  408. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-08-scoping.md +216 -0
  409. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-09-functional.md +219 -0
  410. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-10-nonfunctional.md +230 -0
  411. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-11-polish.md +221 -0
  412. package/_bmad/core/tasks/bmad-create-prd/steps-c/step-12-complete.md +115 -0
  413. package/_bmad/core/tasks/bmad-create-prd/templates/prd-template.md +10 -0
  414. package/_bmad/core/tasks/bmad-create-prd/workflow.md +62 -0
  415. package/_bmad/tea/agents/tea.md +63 -0
  416. package/_bmad/tea/config.yaml +25 -0
  417. package/_bmad/tea/module-help.csv +10 -0
  418. package/_bmad/tea/teams/default-party.csv +2 -0
  419. package/_bmad/tea/testarch/knowledge/adr-quality-readiness-checklist.md +377 -0
  420. package/_bmad/tea/testarch/knowledge/api-request.md +563 -0
  421. package/_bmad/tea/testarch/knowledge/api-testing-patterns.md +915 -0
  422. package/_bmad/tea/testarch/knowledge/auth-session.md +548 -0
  423. package/_bmad/tea/testarch/knowledge/burn-in.md +273 -0
  424. package/_bmad/tea/testarch/knowledge/ci-burn-in.md +717 -0
  425. package/_bmad/tea/testarch/knowledge/component-tdd.md +486 -0
  426. package/_bmad/tea/testarch/knowledge/contract-testing.md +1050 -0
  427. package/_bmad/tea/testarch/knowledge/data-factories.md +500 -0
  428. package/_bmad/tea/testarch/knowledge/email-auth.md +721 -0
  429. package/_bmad/tea/testarch/knowledge/error-handling.md +725 -0
  430. package/_bmad/tea/testarch/knowledge/feature-flags.md +750 -0
  431. package/_bmad/tea/testarch/knowledge/file-utils.md +456 -0
  432. package/_bmad/tea/testarch/knowledge/fixture-architecture.md +401 -0
  433. package/_bmad/tea/testarch/knowledge/fixtures-composition.md +382 -0
  434. package/_bmad/tea/testarch/knowledge/intercept-network-call.md +426 -0
  435. package/_bmad/tea/testarch/knowledge/log.md +426 -0
  436. package/_bmad/tea/testarch/knowledge/network-error-monitor.md +401 -0
  437. package/_bmad/tea/testarch/knowledge/network-first.md +486 -0
  438. package/_bmad/tea/testarch/knowledge/network-recorder.md +527 -0
  439. package/_bmad/tea/testarch/knowledge/nfr-criteria.md +670 -0
  440. package/_bmad/tea/testarch/knowledge/overview.md +286 -0
  441. package/_bmad/tea/testarch/knowledge/pact-consumer-di.md +310 -0
  442. package/_bmad/tea/testarch/knowledge/pact-consumer-framework-setup.md +635 -0
  443. package/_bmad/tea/testarch/knowledge/pact-mcp.md +204 -0
  444. package/_bmad/tea/testarch/knowledge/pactjs-utils-consumer-helpers.md +270 -0
  445. package/_bmad/tea/testarch/knowledge/pactjs-utils-overview.md +216 -0
  446. package/_bmad/tea/testarch/knowledge/pactjs-utils-provider-verifier.md +315 -0
  447. package/_bmad/tea/testarch/knowledge/pactjs-utils-request-filter.md +224 -0
  448. package/_bmad/tea/testarch/knowledge/playwright-cli.md +165 -0
  449. package/_bmad/tea/testarch/knowledge/playwright-config.md +730 -0
  450. package/_bmad/tea/testarch/knowledge/probability-impact.md +601 -0
  451. package/_bmad/tea/testarch/knowledge/recurse.md +421 -0
  452. package/_bmad/tea/testarch/knowledge/risk-governance.md +615 -0
  453. package/_bmad/tea/testarch/knowledge/selective-testing.md +732 -0
  454. package/_bmad/tea/testarch/knowledge/selector-resilience.md +527 -0
  455. package/_bmad/tea/testarch/knowledge/test-healing-patterns.md +644 -0
  456. package/_bmad/tea/testarch/knowledge/test-levels-framework.md +473 -0
  457. package/_bmad/tea/testarch/knowledge/test-priorities-matrix.md +373 -0
  458. package/_bmad/tea/testarch/knowledge/test-quality.md +664 -0
  459. package/_bmad/tea/testarch/knowledge/timing-debugging.md +372 -0
  460. package/_bmad/tea/testarch/knowledge/visual-debugging.md +524 -0
  461. package/_bmad/tea/testarch/tea-index.csv +43 -0
  462. package/_bmad/tea/workflows/testarch/README.md +74 -0
  463. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/SKILL.md +6 -0
  464. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/bmad-skill-manifest.yaml +1 -0
  465. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/checklist.md +197 -0
  466. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/data/curriculum.yaml +129 -0
  467. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/data/quiz-questions.yaml +206 -0
  468. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/data/role-paths.yaml +136 -0
  469. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/data/session-content-map.yaml +207 -0
  470. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/data/tea-resources-index.yaml +359 -0
  471. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/instructions.md +130 -0
  472. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-01-init.md +235 -0
  473. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-01b-continue.md +147 -0
  474. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-02-assess.md +258 -0
  475. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-03-session-menu.md +219 -0
  476. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-01.md +460 -0
  477. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-02.md +465 -0
  478. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-03.md +301 -0
  479. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-04.md +234 -0
  480. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-05.md +234 -0
  481. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-06.md +209 -0
  482. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-07.md +212 -0
  483. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-c/step-05-completion.md +339 -0
  484. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-e/step-e-01-assess-workflow.md +141 -0
  485. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-e/step-e-02-apply-edits.md +122 -0
  486. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/steps-v/step-v-01-validate.md +263 -0
  487. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/templates/certificate-template.md +86 -0
  488. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/templates/progress-template.yaml +95 -0
  489. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/templates/session-notes-template.md +83 -0
  490. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/workflow-plan-teach-me-testing.md +950 -0
  491. package/_bmad/tea/workflows/testarch/bmad-teach-me-testing/workflow.md +90 -0
  492. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/SKILL.md +6 -0
  493. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/atdd-checklist-template.md +371 -0
  494. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/bmad-skill-manifest.yaml +1 -0
  495. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/checklist.md +374 -0
  496. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/instructions.md +45 -0
  497. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-01-preflight-and-context.md +226 -0
  498. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-01b-resume.md +96 -0
  499. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-02-generation-mode.md +125 -0
  500. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-03-test-strategy.md +110 -0
  501. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-04-generate-tests.md +334 -0
  502. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-04a-subagent-api-failing.md +286 -0
  503. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-04b-subagent-e2e-failing.md +244 -0
  504. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-04c-aggregate.md +370 -0
  505. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-c/step-05-validate-and-complete.md +106 -0
  506. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-e/step-01-assess.md +65 -0
  507. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-e/step-02-apply-edit.md +60 -0
  508. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/steps-v/step-01-validate.md +67 -0
  509. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/validation-report-20260127-095021.md +73 -0
  510. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/validation-report-20260127-102401.md +116 -0
  511. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/workflow-plan.md +21 -0
  512. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/workflow.md +41 -0
  513. package/_bmad/tea/workflows/testarch/bmad-testarch-atdd/workflow.yaml +46 -0
  514. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/SKILL.md +6 -0
  515. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/bmad-skill-manifest.yaml +1 -0
  516. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/checklist.md +611 -0
  517. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/instructions.md +50 -0
  518. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-01-preflight-and-context.md +237 -0
  519. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-01b-resume.md +94 -0
  520. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-02-identify-targets.md +169 -0
  521. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-03-generate-tests.md +394 -0
  522. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-03a-subagent-api.md +263 -0
  523. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-03b-subagent-backend.md +246 -0
  524. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-03b-subagent-e2e.md +213 -0
  525. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-03c-aggregate.md +393 -0
  526. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-c/step-04-validate-and-summarize.md +106 -0
  527. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-e/step-01-assess.md +65 -0
  528. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-e/step-02-apply-edit.md +60 -0
  529. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/steps-v/step-01-validate.md +67 -0
  530. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/validation-report-20260127-095021.md +72 -0
  531. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/validation-report-20260127-102401.md +114 -0
  532. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/workflow-plan.md +20 -0
  533. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/workflow.md +41 -0
  534. package/_bmad/tea/workflows/testarch/bmad-testarch-automate/workflow.yaml +53 -0
  535. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/SKILL.md +6 -0
  536. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/azure-pipelines-template.yaml +155 -0
  537. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/bmad-skill-manifest.yaml +1 -0
  538. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/checklist.md +289 -0
  539. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/github-actions-template.yaml +328 -0
  540. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/gitlab-ci-template.yaml +158 -0
  541. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/harness-pipeline-template.yaml +159 -0
  542. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/instructions.md +45 -0
  543. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/jenkins-pipeline-template.groovy +129 -0
  544. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/steps-c/step-01-preflight.md +158 -0
  545. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/steps-c/step-01b-resume.md +110 -0
  546. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/steps-c/step-02-generate-pipeline.md +279 -0
  547. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/steps-c/step-03-configure-quality-gates.md +135 -0
  548. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/steps-c/step-04-validate-and-summary.md +92 -0
  549. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/steps-e/step-01-assess.md +65 -0
  550. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/steps-e/step-02-apply-edit.md +60 -0
  551. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/steps-v/step-01-validate.md +81 -0
  552. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/validation-report-20260127-095021.md +72 -0
  553. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/validation-report-20260127-102401.md +114 -0
  554. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/workflow-plan.md +20 -0
  555. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/workflow.md +41 -0
  556. package/_bmad/tea/workflows/testarch/bmad-testarch-ci/workflow.yaml +48 -0
  557. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/SKILL.md +6 -0
  558. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/bmad-skill-manifest.yaml +1 -0
  559. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/checklist.md +345 -0
  560. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/instructions.md +45 -0
  561. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-c/step-01-preflight.md +132 -0
  562. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-c/step-01b-resume.md +116 -0
  563. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-c/step-02-select-framework.md +117 -0
  564. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-c/step-03-scaffold-framework.md +323 -0
  565. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-c/step-04-docs-and-scripts.md +105 -0
  566. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-c/step-05-validate-and-summary.md +93 -0
  567. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-e/step-01-assess.md +65 -0
  568. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-e/step-02-apply-edit.md +60 -0
  569. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/steps-v/step-01-validate.md +67 -0
  570. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/validation-report-20260127-095021.md +73 -0
  571. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/validation-report-20260127-102401.md +116 -0
  572. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/workflow-plan.md +22 -0
  573. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/workflow.md +41 -0
  574. package/_bmad/tea/workflows/testarch/bmad-testarch-framework/workflow.yaml +48 -0
  575. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/SKILL.md +6 -0
  576. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/bmad-skill-manifest.yaml +1 -0
  577. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/checklist.md +407 -0
  578. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/instructions.md +43 -0
  579. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/nfr-report-template.md +470 -0
  580. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-01-load-context.md +138 -0
  581. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-01b-resume.md +106 -0
  582. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-02-define-thresholds.md +107 -0
  583. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-03-gather-evidence.md +108 -0
  584. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-04-evaluate-and-score.md +254 -0
  585. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-04a-subagent-security.md +138 -0
  586. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-04b-subagent-performance.md +84 -0
  587. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-04c-subagent-reliability.md +85 -0
  588. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-04d-subagent-scalability.md +88 -0
  589. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-04e-aggregate-nfr.md +264 -0
  590. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-c/step-05-generate-report.md +108 -0
  591. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-e/step-01-assess.md +65 -0
  592. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-e/step-02-apply-edit.md +60 -0
  593. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/steps-v/step-01-validate.md +67 -0
  594. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/validation-report-20260127-095021.md +73 -0
  595. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/validation-report-20260127-102401.md +116 -0
  596. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/workflow-plan.md +19 -0
  597. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/workflow.md +41 -0
  598. package/_bmad/tea/workflows/testarch/bmad-testarch-nfr/workflow.yaml +48 -0
  599. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/SKILL.md +6 -0
  600. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/bmad-skill-manifest.yaml +1 -0
  601. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/checklist.md +464 -0
  602. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/instructions.md +105 -0
  603. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-c/step-01-detect-mode.md +134 -0
  604. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-c/step-01b-resume.md +102 -0
  605. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-c/step-02-load-context.md +242 -0
  606. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-c/step-03-risk-and-testability.md +110 -0
  607. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-c/step-04-coverage-plan.md +123 -0
  608. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-c/step-05-generate-output.md +222 -0
  609. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-e/step-01-assess.md +65 -0
  610. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-e/step-02-apply-edit.md +60 -0
  611. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/steps-v/step-01-validate.md +67 -0
  612. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/test-design-architecture-template.md +230 -0
  613. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/test-design-handoff-template.md +70 -0
  614. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/test-design-qa-template.md +396 -0
  615. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/test-design-template.md +344 -0
  616. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/validation-report-20260127-095021.md +73 -0
  617. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/validation-report-20260127-102401.md +116 -0
  618. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/workflow-plan.md +22 -0
  619. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/workflow.md +41 -0
  620. package/_bmad/tea/workflows/testarch/bmad-testarch-test-design/workflow.yaml +77 -0
  621. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/SKILL.md +6 -0
  622. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/bmad-skill-manifest.yaml +1 -0
  623. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/checklist.md +475 -0
  624. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/instructions.md +45 -0
  625. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-01-load-context.md +197 -0
  626. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-01b-resume.md +104 -0
  627. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-02-discover-tests.md +113 -0
  628. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-03-quality-evaluation.md +274 -0
  629. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-03a-subagent-determinism.md +214 -0
  630. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-03b-subagent-isolation.md +125 -0
  631. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-03c-subagent-maintainability.md +102 -0
  632. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-03e-subagent-performance.md +117 -0
  633. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-03f-aggregate-scores.md +277 -0
  634. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-c/step-04-generate-report.md +111 -0
  635. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-e/step-01-assess.md +65 -0
  636. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-e/step-02-apply-edit.md +60 -0
  637. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/steps-v/step-01-validate.md +67 -0
  638. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/test-review-template.md +387 -0
  639. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/validation-report-20260127-095021.md +72 -0
  640. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/validation-report-20260127-102401.md +114 -0
  641. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/workflow-plan.md +18 -0
  642. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/workflow.md +41 -0
  643. package/_bmad/tea/workflows/testarch/bmad-testarch-test-review/workflow.yaml +48 -0
  644. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/SKILL.md +6 -0
  645. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/bmad-skill-manifest.yaml +1 -0
  646. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/checklist.md +647 -0
  647. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/instructions.md +43 -0
  648. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-c/step-01-load-context.md +105 -0
  649. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-c/step-01b-resume.md +102 -0
  650. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-c/step-02-discover-tests.md +112 -0
  651. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-c/step-03-map-criteria.md +97 -0
  652. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-c/step-04-analyze-gaps.md +421 -0
  653. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-c/step-05-gate-decision.md +266 -0
  654. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-e/step-01-assess.md +65 -0
  655. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-e/step-02-apply-edit.md +60 -0
  656. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/steps-v/step-01-validate.md +67 -0
  657. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/trace-template.md +708 -0
  658. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/validation-report-20260127-095021.md +73 -0
  659. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/validation-report-20260127-102401.md +116 -0
  660. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/workflow-plan.md +21 -0
  661. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/workflow.md +41 -0
  662. package/_bmad/tea/workflows/testarch/bmad-testarch-trace/workflow.yaml +56 -0
  663. package/bin/bmad-studio.mjs +25 -0
  664. package/eslint.config.js +38 -0
  665. package/package.json +56 -0
  666. package/packages/client/index.html +12 -0
  667. package/packages/client/package.json +46 -0
  668. package/packages/client/src/app.tsx +57 -0
  669. package/packages/client/src/features/about/AboutPage.tsx +144 -0
  670. package/packages/client/src/features/agents/AgentCard.tsx +52 -0
  671. package/packages/client/src/features/agents/AgentDetail.tsx +338 -0
  672. package/packages/client/src/features/agents/AgentOverrideEditor.tsx +127 -0
  673. package/packages/client/src/features/agents/AgentsPage.tsx +114 -0
  674. package/packages/client/src/features/agents/EditAgentDialog.tsx +260 -0
  675. package/packages/client/src/features/agents/SkillAssignment.tsx +153 -0
  676. package/packages/client/src/features/agents/use-agent-detail.ts +17 -0
  677. package/packages/client/src/features/agents/use-agent-mutations.ts +47 -0
  678. package/packages/client/src/features/agents/use-agents.ts +17 -0
  679. package/packages/client/src/features/connections/ConnectionsPage.tsx +165 -0
  680. package/packages/client/src/features/files/FilesPage.tsx +177 -0
  681. package/packages/client/src/features/outputs/OutputsPage.tsx +190 -0
  682. package/packages/client/src/features/overview/OverviewPage.tsx +282 -0
  683. package/packages/client/src/features/packages/EditModuleDialog.tsx +118 -0
  684. package/packages/client/src/features/packages/PackagesPage.tsx +982 -0
  685. package/packages/client/src/features/settings/SettingsPage.tsx +141 -0
  686. package/packages/client/src/features/settings/use-settings.ts +34 -0
  687. package/packages/client/src/features/skills/CreateSkillDialog.tsx +328 -0
  688. package/packages/client/src/features/skills/SkillDetailSlideOver.tsx +179 -0
  689. package/packages/client/src/features/skills/SkillsPage.tsx +142 -0
  690. package/packages/client/src/features/skills/use-skills.ts +27 -0
  691. package/packages/client/src/features/teams/CreateTeamDialog.tsx +239 -0
  692. package/packages/client/src/features/teams/TeamDetailPanel.tsx +549 -0
  693. package/packages/client/src/features/teams/TeamsPage.tsx +196 -0
  694. package/packages/client/src/features/teams/use-teams.ts +39 -0
  695. package/packages/client/src/features/workflows/CreateWorkflowDialog.tsx +395 -0
  696. package/packages/client/src/features/workflows/EditWorkflowDialog.tsx +131 -0
  697. package/packages/client/src/features/workflows/WorkflowDetailPanel.tsx +503 -0
  698. package/packages/client/src/features/workflows/WorkflowGraph.tsx +108 -0
  699. package/packages/client/src/features/workflows/WorkflowsPage.tsx +277 -0
  700. package/packages/client/src/features/workflows/use-workflows.ts +27 -0
  701. package/packages/client/src/features/workspace/WorkspacePage.tsx +304 -0
  702. package/packages/client/src/globals.css +184 -0
  703. package/packages/client/src/hooks/use-detail-param.ts +31 -0
  704. package/packages/client/src/hooks/use-file-save.ts +22 -0
  705. package/packages/client/src/hooks/use-websocket.ts +38 -0
  706. package/packages/client/src/layout/AppShell.tsx +20 -0
  707. package/packages/client/src/layout/Breadcrumbs.tsx +52 -0
  708. package/packages/client/src/layout/NotificationProvider.tsx +95 -0
  709. package/packages/client/src/layout/Sidebar.tsx +176 -0
  710. package/packages/client/src/lib/theme.ts +30 -0
  711. package/packages/client/src/lib/websocket-client.ts +97 -0
  712. package/packages/client/src/main.tsx +14 -0
  713. package/packages/client/src/shared/CommandPalette.tsx +151 -0
  714. package/packages/client/src/shared/CsvViewer.tsx +120 -0
  715. package/packages/client/src/shared/EmptyState.tsx +20 -0
  716. package/packages/client/src/shared/EntityPageHeader.tsx +95 -0
  717. package/packages/client/src/shared/FilepathLink.tsx +22 -0
  718. package/packages/client/src/shared/Skeleton.tsx +31 -0
  719. package/packages/client/src/shared/SlideOver.tsx +63 -0
  720. package/packages/client/src/shared/VocabularyHelper.tsx +48 -0
  721. package/packages/client/src/shared/diff-viewer/DiffViewer.tsx +93 -0
  722. package/packages/client/src/shared/markdown-editor/CodeMirrorEditor.tsx +199 -0
  723. package/packages/client/src/shared/markdown-editor/MarkdownEditor.tsx +95 -0
  724. package/packages/client/src/stores/ui-store.ts +13 -0
  725. package/packages/client/tsconfig.json +13 -0
  726. package/packages/client/vite.config.ts +20 -0
  727. package/packages/server/package.json +30 -0
  728. package/packages/server/src/app.test.ts +89 -0
  729. package/packages/server/src/app.ts +101 -0
  730. package/packages/server/src/core/errors.test.ts +49 -0
  731. package/packages/server/src/core/errors.ts +62 -0
  732. package/packages/server/src/core/file-store.test.ts +104 -0
  733. package/packages/server/src/core/file-store.ts +209 -0
  734. package/packages/server/src/core/project-detector.test.ts +94 -0
  735. package/packages/server/src/core/project-detector.ts +97 -0
  736. package/packages/server/src/core/websocket.test.ts +80 -0
  737. package/packages/server/src/core/websocket.ts +47 -0
  738. package/packages/server/src/core/write-service.test.ts +87 -0
  739. package/packages/server/src/core/write-service.ts +75 -0
  740. package/packages/server/src/index.ts +97 -0
  741. package/packages/server/src/parsers/agent-parser.test.ts +71 -0
  742. package/packages/server/src/parsers/agent-parser.ts +83 -0
  743. package/packages/server/src/parsers/config-parser.test.ts +65 -0
  744. package/packages/server/src/parsers/config-parser.ts +51 -0
  745. package/packages/server/src/parsers/csv-parser.test.ts +53 -0
  746. package/packages/server/src/parsers/csv-parser.ts +55 -0
  747. package/packages/server/src/parsers/ide-config-parser.test.ts +35 -0
  748. package/packages/server/src/parsers/ide-config-parser.ts +37 -0
  749. package/packages/server/src/parsers/index-builder.test.ts +78 -0
  750. package/packages/server/src/parsers/index-builder.ts +195 -0
  751. package/packages/server/src/parsers/package-parser.test.ts +36 -0
  752. package/packages/server/src/parsers/package-parser.ts +34 -0
  753. package/packages/server/src/parsers/skill-parser.test.ts +51 -0
  754. package/packages/server/src/parsers/skill-parser.ts +26 -0
  755. package/packages/server/src/parsers/team-parser.test.ts +186 -0
  756. package/packages/server/src/parsers/team-parser.ts +128 -0
  757. package/packages/server/src/parsers/workflow-parser.test.ts +415 -0
  758. package/packages/server/src/parsers/workflow-parser.ts +311 -0
  759. package/packages/server/src/plugins/agents-plugin.test.ts +111 -0
  760. package/packages/server/src/plugins/agents-plugin.ts +164 -0
  761. package/packages/server/src/plugins/files-plugin.test.ts +121 -0
  762. package/packages/server/src/plugins/files-plugin.ts +93 -0
  763. package/packages/server/src/plugins/modules-plugin.test.ts +264 -0
  764. package/packages/server/src/plugins/modules-plugin.ts +386 -0
  765. package/packages/server/src/plugins/outputs-plugin.test.ts +89 -0
  766. package/packages/server/src/plugins/outputs-plugin.ts +93 -0
  767. package/packages/server/src/plugins/overview-plugin.ts +73 -0
  768. package/packages/server/src/plugins/search-plugin.ts +63 -0
  769. package/packages/server/src/plugins/settings-plugin.test.ts +82 -0
  770. package/packages/server/src/plugins/settings-plugin.ts +46 -0
  771. package/packages/server/src/plugins/skills-plugin.ts +87 -0
  772. package/packages/server/src/plugins/teams-plugin.test.ts +157 -0
  773. package/packages/server/src/plugins/teams-plugin.ts +198 -0
  774. package/packages/server/src/plugins/validation-plugin.test.ts +229 -0
  775. package/packages/server/src/plugins/validation-plugin.ts +116 -0
  776. package/packages/server/src/plugins/workflows-plugin.test.ts +145 -0
  777. package/packages/server/src/plugins/workflows-plugin.ts +270 -0
  778. package/packages/server/src/static.ts +29 -0
  779. package/packages/server/tsconfig.json +8 -0
  780. package/packages/shared/package.json +20 -0
  781. package/packages/shared/src/agents.ts +39 -0
  782. package/packages/shared/src/config.ts +33 -0
  783. package/packages/shared/src/connections.ts +28 -0
  784. package/packages/shared/src/errors.ts +17 -0
  785. package/packages/shared/src/events.ts +35 -0
  786. package/packages/shared/src/files.ts +11 -0
  787. package/packages/shared/src/index.ts +40 -0
  788. package/packages/shared/src/outputs.ts +25 -0
  789. package/packages/shared/src/packages.ts +30 -0
  790. package/packages/shared/src/skills.ts +17 -0
  791. package/packages/shared/src/teams.ts +33 -0
  792. package/packages/shared/src/types.test.ts +164 -0
  793. package/packages/shared/src/validation.ts +15 -0
  794. package/packages/shared/src/workflows.ts +47 -0
  795. package/packages/shared/src/workspace.ts +12 -0
  796. package/packages/shared/tsconfig.json +8 -0
  797. package/tsconfig.base.json +19 -0
  798. package/vitest.config.ts +7 -0
@@ -0,0 +1,204 @@
1
+ # Pact MCP Server (SmartBear)
2
+
3
+ ## Principle
4
+
5
+ Use the SmartBear MCP server to enable AI agent interaction with PactFlow/Pact Broker during contract testing workflows. The MCP server provides tools for generating pact tests, fetching provider states, reviewing test quality, and checking deployment safety — all accessible through the Model Context Protocol.
6
+
7
+ ## Rationale
8
+
9
+ ### Why MCP for contract testing?
10
+
11
+ - **Live broker queries**: AI agents can fetch existing provider states, verification results, and deployment status directly from PactFlow
12
+ - **Test generation assistance**: MCP tools generate consumer and provider tests based on existing contracts, OpenAPI specs, or templates
13
+ - **Automated review**: MCP-powered review checks tests against best practices without manual inspection
14
+ - **Deployment safety**: `can-i-deploy` checks integrated into agent workflows for real-time compatibility verification
15
+
16
+ ### When TEA uses it
17
+
18
+ - **test-design workflow**: Fetch existing provider states to understand current contract landscape
19
+ - **automate workflow**: Generate pact tests using broker knowledge and existing contracts
20
+ - **test-review workflow**: Review pact tests against best practices with automated feedback
21
+ - **ci workflow**: Reference can-i-deploy and matrix tools for pipeline guidance
22
+
23
+ ## Available Tools
24
+
25
+ | # | Tool | Description | When Used |
26
+ | --- | ------------------------- | ----------------------------------------------------------------------- | --------------------- |
27
+ | 1 | **Generate Pact Tests** | Create consumer/provider tests from code, OpenAPI, or templates | automate workflow |
28
+ | 2 | **Fetch Provider States** | List all provider states from broker for a given consumer-provider pair | test-design, automate |
29
+ | 3 | **Review Pact Tests** | Analyze tests against contract testing best practices | test-review |
30
+ | 4 | **Can I Deploy** | Check deployment safety via broker verification matrix | ci workflow |
31
+ | 5 | **Matrix** | Query consumer-provider verification matrix | ci, test-design |
32
+ | 6 | **PactFlow AI Status** | Check AI credits and permissions (PactFlow Cloud only) | diagnostics |
33
+ | 7 | **Metrics - All** | Workspace-wide contract testing metrics | reporting |
34
+ | 8 | **Metrics - Team** | Team-level adoption statistics (PactFlow Cloud only) | reporting |
35
+
36
+ ## Installation
37
+
38
+ ### Config file locations
39
+
40
+ | Tool | Global Config File | Format |
41
+ | ----------------- | ------------------------------------- | ---------------------- |
42
+ | Claude Code | `~/.claude.json` | JSON (`mcpServers`) |
43
+ | Codex | `~/.codex/config.toml` | TOML (`[mcp_servers]`) |
44
+ | Gemini CLI | `~/.gemini/settings.json` | JSON (`mcpServers`) |
45
+ | Cursor | `~/.cursor/mcp.json` | JSON (`mcpServers`) |
46
+ | Windsurf | `~/.codeium/windsurf/mcp_config.json` | JSON (`mcpServers`) |
47
+ | VS Code (Copilot) | `.vscode/mcp.json` | JSON (`servers`) |
48
+
49
+ > **Claude Code tip**: Prefer the `claude mcp add` CLI over manual JSON editing. Use `-s user` for global (all projects) or omit for per-project (default).
50
+
51
+ ### CLI shortcuts (Claude Code and Codex)
52
+
53
+ ```bash
54
+ # Claude Code — use add-json for servers with env vars (-s user = global)
55
+ claude mcp add-json -s user smartbear \
56
+ '{"type":"stdio","command":"npx","args":["-y","@smartbear/mcp@latest"],"env":{"PACT_BROKER_BASE_URL":"https://{tenant}.pactflow.io","PACT_BROKER_TOKEN":"<your-token>"}}'
57
+
58
+ # Codex
59
+ codex mcp add smartbear -- npx -y @smartbear/mcp@latest
60
+ ```
61
+
62
+ ### JSON config (Gemini CLI, Cursor, Windsurf)
63
+
64
+ Add a `"smartbear"` entry to the `mcpServers` object in the config file for your tool:
65
+
66
+ ```json
67
+ {
68
+ "mcpServers": {
69
+ "smartbear": {
70
+ "type": "stdio",
71
+ "command": "npx",
72
+ "args": ["-y", "@smartbear/mcp@latest"],
73
+ "env": {
74
+ "PACT_BROKER_BASE_URL": "https://{tenant}.pactflow.io",
75
+ "PACT_BROKER_TOKEN": "<your-api-token>"
76
+ }
77
+ }
78
+ }
79
+ }
80
+ ```
81
+
82
+ ### Codex TOML config
83
+
84
+ Codex uses TOML instead of JSON. Add to `~/.codex/config.toml`:
85
+
86
+ ```toml
87
+ [mcp_servers.smartbear]
88
+ command = "npx"
89
+ args = ["-y", "@smartbear/mcp@latest"]
90
+
91
+ [mcp_servers.smartbear.env]
92
+ PACT_BROKER_BASE_URL = "https://{tenant}.pactflow.io"
93
+ PACT_BROKER_TOKEN = "<your-api-token>"
94
+ ```
95
+
96
+ Note the key is `mcp_servers` (underscored), not `mcpServers`.
97
+
98
+ ### VS Code (GitHub Copilot)
99
+
100
+ Add to `.vscode/mcp.json` (note: uses `servers` key, not `mcpServers`):
101
+
102
+ ```json
103
+ {
104
+ "servers": {
105
+ "smartbear": {
106
+ "type": "stdio",
107
+ "command": "npx",
108
+ "args": ["-y", "@smartbear/mcp@latest"],
109
+ "env": {
110
+ "PACT_BROKER_BASE_URL": "https://{tenant}.pactflow.io",
111
+ "PACT_BROKER_TOKEN": "${input:pactToken}"
112
+ }
113
+ }
114
+ }
115
+ }
116
+ ```
117
+
118
+ > **Note**: Set either `PACT_BROKER_TOKEN` (for PactFlow) or `PACT_BROKER_USERNAME`+`PACT_BROKER_PASSWORD` (for self-hosted). Leave unused vars empty.
119
+
120
+ ## Required Environment Variables
121
+
122
+ | Variable | Required | Description |
123
+ | ---------------------- | ---------------------------- | --------------------------------------- |
124
+ | `PACT_BROKER_BASE_URL` | Yes (for Pact features) | PactFlow or self-hosted Pact Broker URL |
125
+ | `PACT_BROKER_TOKEN` | For PactFlow / token auth | API token for broker authentication |
126
+ | `PACT_BROKER_USERNAME` | For basic auth (self-hosted) | Username for basic authentication |
127
+ | `PACT_BROKER_PASSWORD` | For basic auth (self-hosted) | Password for basic authentication |
128
+
129
+ **Authentication**: Use token auth (`PACT_BROKER_TOKEN`) for PactFlow. Use basic auth (`PACT_BROKER_USERNAME` + `PACT_BROKER_PASSWORD`) for self-hosted Pact Broker instances. Only one auth method is needed.
130
+
131
+ **Requirements**: Node.js 20+
132
+
133
+ ## Pattern Examples
134
+
135
+ ### Example 1: Fetching Provider States During Test Design
136
+
137
+ When designing contract tests, use MCP to query existing provider states:
138
+
139
+ ```
140
+ # Agent queries SmartBear MCP during test-design workflow:
141
+ # → Fetch Provider States for consumer="movie-web", provider="SampleMoviesAPI"
142
+ # ← Returns: ["movie with id 1 exists", "no movies exist", "user is authenticated"]
143
+ #
144
+ # Agent uses this to generate comprehensive consumer tests covering all states
145
+ ```
146
+
147
+ ### Example 2: Reviewing Pact Tests
148
+
149
+ During test-review workflow, use MCP to evaluate test quality:
150
+
151
+ ```
152
+ # Agent submits test file to SmartBear MCP Review tool:
153
+ # → Review Pact Tests with test file content
154
+ # ← Returns: feedback on matcher usage, state coverage, interaction naming
155
+ #
156
+ # Agent incorporates feedback into review report
157
+ ```
158
+
159
+ ### Example 3: Can I Deploy Check in CI
160
+
161
+ During CI workflow design, reference the can-i-deploy tool:
162
+
163
+ ```
164
+ # Agent generates CI pipeline with can-i-deploy gate:
165
+ # → Can I Deploy: pacticipant="SampleMoviesAPI", version="${GITHUB_SHA}", to="production"
166
+ # ← Returns: { ok: true/false, reason: "..." }
167
+ #
168
+ # Agent designs pipeline to block deployment if can-i-deploy fails
169
+ ```
170
+
171
+ ## Key Points
172
+
173
+ - **Per-project install recommended**: Different projects may target different PactFlow tenants — match TEA's per-project config philosophy
174
+ - **Env vars are project-specific**: `PACT_BROKER_BASE_URL` and `PACT_BROKER_TOKEN` vary by project/team
175
+ - **Node.js 20+ required**: SmartBear MCP server requires Node.js 20 or higher
176
+ - **PactFlow Cloud features**: Some tools (AI Status, Team Metrics) are only available with PactFlow Cloud, not self-hosted Pact Broker
177
+ - **Complements pactjs-utils**: MCP provides broker interaction during design/review; pactjs-utils provides runtime utilities for test code
178
+
179
+ ## Related Fragments
180
+
181
+ - `pactjs-utils-overview.md` — runtime utilities that pact tests import
182
+ - `pactjs-utils-provider-verifier.md` — verifier options that reference broker config
183
+ - `contract-testing.md` — foundational contract testing patterns
184
+
185
+ ## Anti-Patterns
186
+
187
+ ### Wrong: Using MCP for runtime test execution
188
+
189
+ ```
190
+ # ❌ Don't use MCP to run pact tests — use npm scripts and CI pipelines
191
+ # MCP is for agent-assisted design, generation, and review
192
+ ```
193
+
194
+ ### Right: Use MCP for design-time assistance
195
+
196
+ ```
197
+ # ✅ Use MCP during planning and review:
198
+ # - Fetch provider states to inform test design
199
+ # - Generate test scaffolds from existing contracts
200
+ # - Review tests for best practice compliance
201
+ # - Check can-i-deploy during CI pipeline design
202
+ ```
203
+
204
+ _Source: SmartBear MCP documentation, PactFlow developer docs_
@@ -0,0 +1,270 @@
1
+ # Pact.js Utils Consumer Helpers
2
+
3
+ ## Principle
4
+
5
+ Use `createProviderState`, `toJsonMap`, `setJsonContent`, and `setJsonBody` from `@seontechnologies/pactjs-utils` to build type-safe provider state tuples and reusable PactV4 JSON callbacks for consumer contract tests. These helpers eliminate manual `JsonMap` casting and repetitive inline builder lambdas.
6
+
7
+ ## Rationale
8
+
9
+ ### Problems with raw consumer helper handling
10
+
11
+ - **JsonMap requirement**: Pact's `.given(stateName, params)` requires `params` to be `JsonMap` — a flat object where every value must be `string | number | boolean | null`
12
+ - **Type gymnastics**: Complex params (Date objects, nested objects, null values) require manual casting that TypeScript can't verify
13
+ - **Inconsistent serialization**: Different developers serialize the same data differently (e.g., dates as ISO strings vs timestamps)
14
+ - **Verbose `.given()` calls**: Repeating state name and params inline makes consumer tests harder to read
15
+ - **Repeated interaction callbacks**: PactV4 interactions duplicate inline `(builder) => { ... }` blocks for body/query/header setup
16
+
17
+ ### Solutions
18
+
19
+ - **`createProviderState`**: Returns a `[string, JsonMap]` tuple that spreads directly into `.given()` — one function handles name and params
20
+ - **`toJsonMap`**: Explicit coercion rules documented and tested — Date→ISO string, null→"null" string, nested objects→JSON string
21
+ - **`setJsonContent`**: Curried callback helper for request/response builders — set `query`, `headers`, and/or `body` from one reusable function
22
+ - **`setJsonBody`**: Body-only shorthand for `setJsonContent({ body })` — ideal for concise `.willRespondWith(...)` bodies
23
+
24
+ ## Pattern Examples
25
+
26
+ ### Example 1: Basic Provider State Creation
27
+
28
+ ```typescript
29
+ import { PactV3, MatchersV3 } from '@pact-foundation/pact';
30
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
31
+
32
+ const provider = new PactV3({
33
+ consumer: 'movie-web',
34
+ provider: 'SampleMoviesAPI',
35
+ dir: './pacts',
36
+ });
37
+
38
+ describe('Movie API Contract', () => {
39
+ it('should return movie by id', async () => {
40
+ // createProviderState returns [stateName, JsonMap] tuple
41
+ const providerState = createProviderState({
42
+ name: 'movie with id 1 exists',
43
+ params: { id: 1, name: 'Inception', year: 2010 },
44
+ });
45
+
46
+ await provider
47
+ .given(...providerState) // Spread tuple into .given(name, params)
48
+ .uponReceiving('a request for movie 1')
49
+ .withRequest({ method: 'GET', path: '/movies/1' })
50
+ .willRespondWith({
51
+ status: 200,
52
+ body: MatchersV3.like({ id: 1, name: 'Inception', year: 2010 }),
53
+ })
54
+ .executeTest(async (mockServer) => {
55
+ const res = await fetch(`${mockServer.url}/movies/1`);
56
+ const movie = await res.json();
57
+ expect(movie.name).toBe('Inception');
58
+ });
59
+ });
60
+ });
61
+ ```
62
+
63
+ **Key Points**:
64
+
65
+ - `createProviderState` accepts `{ name: string, params: Record<string, unknown> }`
66
+ - Both `name` and `params` are required (pass `params: {}` for states without parameters)
67
+ - Returns `[string, JsonMap]` — spread with `...` into `.given()`
68
+ - `params` values are automatically converted to JsonMap-compatible types
69
+ - Works identically with HTTP (`PactV3`) and message (`MessageConsumerPact`) pacts
70
+
71
+ ### Example 2: Complex Parameters with toJsonMap
72
+
73
+ ```typescript
74
+ import { toJsonMap } from '@seontechnologies/pactjs-utils';
75
+
76
+ // toJsonMap conversion rules:
77
+ // - string, number, boolean → passed through
78
+ // - null → "null" (string)
79
+ // - undefined → "null" (string, same as null)
80
+ // - Date → ISO string (e.g., "2025-01-15T10:00:00.000Z")
81
+ // - nested object → JSON string
82
+ // - array → comma-separated string via String() (e.g., [1,2,3] → "1,2,3")
83
+
84
+ const params = toJsonMap({
85
+ id: 42,
86
+ name: 'John Doe',
87
+ active: true,
88
+ score: null,
89
+ createdAt: new Date('2025-01-15T10:00:00Z'),
90
+ metadata: { role: 'admin', permissions: ['read', 'write'] },
91
+ });
92
+
93
+ // Result:
94
+ // {
95
+ // id: 42,
96
+ // name: "John Doe",
97
+ // active: true,
98
+ // score: "null",
99
+ // createdAt: "2025-01-15T10:00:00.000Z",
100
+ // metadata: '{"role":"admin","permissions":["read","write"]}'
101
+ // }
102
+ ```
103
+
104
+ **Key Points**:
105
+
106
+ - `toJsonMap` is called internally by `createProviderState` — you rarely need it directly
107
+ - Use it when you need explicit control over parameter conversion outside of provider states
108
+ - Conversion rules are deterministic: same input always produces same output
109
+
110
+ ### Example 3: Provider State Without Parameters
111
+
112
+ ```typescript
113
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
114
+
115
+ // State without params — second tuple element is empty object
116
+ const emptyState = createProviderState({ name: 'no movies exist', params: {} });
117
+ // Returns: ['no movies exist', {}]
118
+
119
+ await provider
120
+ .given(...emptyState)
121
+ .uponReceiving('a request when no movies exist')
122
+ .withRequest({ method: 'GET', path: '/movies' })
123
+ .willRespondWith({ status: 200, body: [] })
124
+ .executeTest(async (mockServer) => {
125
+ const res = await fetch(`${mockServer.url}/movies`);
126
+ const movies = await res.json();
127
+ expect(movies).toEqual([]);
128
+ });
129
+ ```
130
+
131
+ ### Example 4: Multiple Provider States
132
+
133
+ ```typescript
134
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
135
+
136
+ // Some interactions require multiple provider states
137
+ // Call .given() multiple times with different states
138
+ await provider
139
+ .given(...createProviderState({ name: 'user is authenticated', params: { userId: 1 } }))
140
+ .given(...createProviderState({ name: 'movie with id 5 exists', params: { id: 5 } }))
141
+ .uponReceiving('an authenticated request for movie 5')
142
+ .withRequest({
143
+ method: 'GET',
144
+ path: '/movies/5',
145
+ headers: { Authorization: MatchersV3.like('Bearer token') },
146
+ })
147
+ .willRespondWith({ status: 200, body: MatchersV3.like({ id: 5 }) })
148
+ .executeTest(async (mockServer) => {
149
+ // test implementation
150
+ });
151
+ ```
152
+
153
+ ### Example 5: When to Use setJsonBody vs setJsonContent
154
+
155
+ ```typescript
156
+ import { MatchersV3 } from '@pact-foundation/pact';
157
+ import { setJsonBody, setJsonContent } from '@seontechnologies/pactjs-utils';
158
+
159
+ const { integer, string } = MatchersV3;
160
+
161
+ await pact
162
+ .addInteraction()
163
+ .given('movie exists')
164
+ .uponReceiving('a request to get movie by name')
165
+ .withRequest(
166
+ 'GET',
167
+ '/movies',
168
+ setJsonContent({
169
+ query: { name: 'Inception' },
170
+ headers: { Accept: 'application/json' },
171
+ }),
172
+ )
173
+ .willRespondWith(
174
+ 200,
175
+ setJsonBody({
176
+ status: 200,
177
+ data: { id: integer(1), name: string('Inception') },
178
+ }),
179
+ );
180
+ ```
181
+
182
+ **Key Points**:
183
+
184
+ - Use `setJsonContent` when the interaction needs `query`, `headers`, and/or `body` in one callback (most request builders)
185
+ - Use `setJsonBody` when you only need `jsonBody` and want the shorter `.willRespondWith(status, setJsonBody(...))` form
186
+ - `setJsonBody` is equivalent to `setJsonContent({ body: ... })`
187
+
188
+ ## Key Points
189
+
190
+ - **Spread pattern**: Always use `...createProviderState()` — the tuple spreads into `.given(stateName, params)`
191
+ - **Type safety**: TypeScript enforces `{ name: string, params: Record<string, unknown> }` input (both fields required)
192
+ - **Null handling**: `null` becomes `"null"` string in JsonMap (Pact requirement)
193
+ - **Date handling**: Date objects become ISO 8601 strings
194
+ - **No nested objects in JsonMap**: Nested objects are JSON-stringified — provider state handlers must parse them
195
+ - **Array serialization is lossy**: Arrays are converted via `String()` (e.g., `[1,2,3]` → `"1,2,3"`) — prefer passing arrays as JSON-stringified objects for round-trip safety
196
+ - **Message pacts**: Works identically with `MessageConsumerPact` — same `.given()` API
197
+ - **Builder reuse**: `setJsonContent` works for both `.withRequest(...)` and `.willRespondWith(...)` callbacks (query is ignored on response builders)
198
+ - **Body shorthand**: `setJsonBody` keeps body-only responses concise and readable
199
+ - **Matchers check type, not value**: `string('My movie')` means "any string", `integer(1)` means "any integer". The example values are arbitrary — the provider can return different values and verification still passes as long as the type matches. Use matchers only in `.willRespondWith()` (responses), never in `.withRequest()` (requests) — Postel's Law applies.
200
+ - **Reuse test values across files**: Interactions are uniquely identified by `uponReceiving` + `.given()`, not by placeholder values. Two test files can both use `testId: 100` without conflicting. On the provider side, shared values simplify state handlers — idempotent handlers (check if exists, create if not) only need to ensure one record exists. Use different values only when testing different states of the same entity type (e.g., `movieExists(100)` for happy paths vs. `movieNotFound(999)` for error paths).
201
+
202
+ ## Related Fragments
203
+
204
+ - `pactjs-utils-overview.md` — installation, decision tree, design philosophy
205
+ - `pactjs-utils-provider-verifier.md` — provider-side state handler implementation
206
+ - `contract-testing.md` — foundational patterns with raw Pact.js
207
+
208
+ ## Anti-Patterns
209
+
210
+ ### Wrong: Manual JsonMap assembly
211
+
212
+ ```typescript
213
+ // ❌ Manual casting — verbose, error-prone, no type safety
214
+ provider.given('user exists', {
215
+ id: 1 as unknown as string,
216
+ createdAt: new Date().toISOString(),
217
+ metadata: JSON.stringify({ role: 'admin' }),
218
+ } as JsonMap);
219
+ ```
220
+
221
+ ### Right: Use createProviderState
222
+
223
+ ```typescript
224
+ // ✅ Automatic conversion with type safety
225
+ provider.given(
226
+ ...createProviderState({
227
+ name: 'user exists',
228
+ params: { id: 1, createdAt: new Date(), metadata: { role: 'admin' } },
229
+ }),
230
+ );
231
+ ```
232
+
233
+ ### Wrong: Inline state names without helper
234
+
235
+ ```typescript
236
+ // ❌ Duplicated state names between consumer and provider — easy to mismatch
237
+ provider.given('a user with id 1 exists', { id: '1' });
238
+ // Later in provider: 'user with id 1 exists' — different string!
239
+ ```
240
+
241
+ ### Right: Share state constants
242
+
243
+ ```typescript
244
+ // ✅ Define state names as constants shared between consumer and provider
245
+ const STATES = {
246
+ USER_EXISTS: 'user with id exists',
247
+ NO_USERS: 'no users exist',
248
+ } as const;
249
+
250
+ provider.given(...createProviderState({ name: STATES.USER_EXISTS, params: { id: 1 } }));
251
+ ```
252
+
253
+ ### Wrong: Repeating inline builder lambdas everywhere
254
+
255
+ ```typescript
256
+ // ❌ Repetitive callback boilerplate in every interaction
257
+ .willRespondWith(200, (builder) => {
258
+ builder.jsonBody({ status: 200 });
259
+ });
260
+ ```
261
+
262
+ ### Right: Use setJsonBody / setJsonContent
263
+
264
+ ```typescript
265
+ // ✅ Reusable callbacks with less boilerplate
266
+ .withRequest('GET', '/movies', setJsonContent({ query: { name: 'Inception' } }))
267
+ .willRespondWith(200, setJsonBody({ status: 200 }));
268
+ ```
269
+
270
+ _Source: @seontechnologies/pactjs-utils consumer-helpers module, pactjs-utils sample-app consumer tests_
@@ -0,0 +1,216 @@
1
+ # Pact.js Utils Overview
2
+
3
+ ## Principle
4
+
5
+ Use production-ready utilities from `@seontechnologies/pactjs-utils` to eliminate boilerplate in consumer-driven contract testing. The library wraps `@pact-foundation/pact` with type-safe helpers for provider state creation, PactV4 JSON interaction builders, verifier configuration, and request filter injection — working equally well for HTTP and message (async/Kafka) contracts.
6
+
7
+ ## Rationale
8
+
9
+ ### Problems with raw @pact-foundation/pact
10
+
11
+ - **JsonMap casting**: Provider state parameters require `JsonMap` type — manually casting every value is error-prone and verbose
12
+ - **Repeated builder lambdas**: PactV4 interactions often repeat inline callbacks with `builder.query(...)`, `builder.headers(...)`, and `builder.jsonBody(...)`
13
+ - **Verifier configuration sprawl**: `VerifierOptions` requires 30+ lines of scattered configuration (broker URL, selectors, state handlers, request filters, version tags)
14
+ - **Environment variable juggling**: Different env vars for local vs remote flows, breaking change coordination, payload URL matching
15
+ - **Express middleware types**: Request filter requires Express types that aren't re-exported from Pact
16
+ - **Bearer prefix bugs**: Easy to double-prefix tokens as `Bearer Bearer ...` in request filters
17
+ - **CI version tagging**: Manual logic to extract branch/tag info from CI environment
18
+
19
+ ### Solutions from pactjs-utils
20
+
21
+ - **`createProviderState`**: One-call tuple builder for `.given()` — handles all JsonMap conversion automatically
22
+ - **`toJsonMap`**: Explicit type coercion (null→"null", Date→ISO string, nested objects flattened)
23
+ - **`setJsonContent`**: Curried callback helper for PactV4 `.withRequest(...)` / `.willRespondWith(...)` builders (query/headers/body)
24
+ - **`setJsonBody`**: Body-only shorthand alias of `setJsonContent({ body })`
25
+ - **`buildVerifierOptions`**: Single function assembles complete VerifierOptions from minimal inputs — handles local/remote/BDCT flows
26
+ - **`buildMessageVerifierOptions`**: Same as above but for message/Kafka provider verification
27
+ - **`handlePactBrokerUrlAndSelectors`**: Resolves broker URL and consumer version selectors from env vars with breaking change awareness
28
+ - **`getProviderVersionTags`**: CI-aware version tagging (extracts branch/tag from GitHub Actions, GitLab CI, etc.)
29
+ - **`createRequestFilter`**: Pluggable token generator pattern — prevents double-Bearer bugs by contract
30
+ - **`noOpRequestFilter`**: Pass-through for providers that don't require auth injection
31
+
32
+ ## Installation
33
+
34
+ ```bash
35
+ npm install -D @seontechnologies/pactjs-utils
36
+
37
+ # Peer dependency
38
+ npm install -D @pact-foundation/pact
39
+ ```
40
+
41
+ **Requirements**: `@pact-foundation/pact` >= 16.2.0, Node.js >= 18
42
+
43
+ ## Available Utilities
44
+
45
+ | Category | Function | Description | Use Case |
46
+ | ----------------- | --------------------------------- | ---------------------------------------------------- | ---------------------------------------------------------------- |
47
+ | Consumer Helpers | `createProviderState` | Builds `[stateName, JsonMap]` tuple from typed input | Consumer tests: `.given(...createProviderState(input))` |
48
+ | Consumer Helpers | `toJsonMap` | Converts any object to Pact-compatible `JsonMap` | Explicit type coercion for provider state params |
49
+ | Consumer Helpers | `setJsonContent` | Curried request/response JSON callback helper | PactV4 `.withRequest(...)` and `.willRespondWith(...)` builders |
50
+ | Consumer Helpers | `setJsonBody` | Body-only alias of `setJsonContent` | Body-only `.willRespondWith(...)` responses |
51
+ | Provider Verifier | `buildVerifierOptions` | Assembles complete HTTP `VerifierOptions` | Provider verification: `new Verifier(buildVerifierOptions(...))` |
52
+ | Provider Verifier | `buildMessageVerifierOptions` | Assembles message `VerifierOptions` | Kafka/async provider verification |
53
+ | Provider Verifier | `handlePactBrokerUrlAndSelectors` | Resolves broker URL + selectors from env vars | Env-aware broker configuration |
54
+ | Provider Verifier | `getProviderVersionTags` | CI-aware version tag extraction | Provider version tagging in CI |
55
+ | Request Filter | `createRequestFilter` | Express middleware with pluggable token generator | Auth injection for provider verification |
56
+ | Request Filter | `noOpRequestFilter` | Pass-through filter (no-op) | Providers without auth requirements |
57
+
58
+ ## Decision Tree: Which Flow?
59
+
60
+ ```
61
+ Is this a monorepo (consumer + provider in same repo)?
62
+ ├── YES → Local Flow
63
+ │ - Consumer generates pact files to ./pacts/
64
+ │ - Provider reads pact files from ./pacts/ (no broker needed)
65
+ │ - Use buildVerifierOptions with pactUrls option
66
+
67
+ └── NO → Do you have a Pact Broker / PactFlow?
68
+ ├── YES → Remote (CDCT) Flow
69
+ │ - Consumer publishes pacts to broker
70
+ │ - Provider verifies from broker
71
+ │ - Use buildVerifierOptions with broker config
72
+ │ - Set PACT_BROKER_BASE_URL + PACT_BROKER_TOKEN
73
+
74
+ └── Do you have an OpenAPI spec?
75
+ ├── YES → BDCT Flow (PactFlow only)
76
+ │ - Provider publishes OpenAPI spec to PactFlow
77
+ │ - PactFlow cross-validates consumer pacts against spec
78
+ │ - No provider verification test needed
79
+
80
+ └── NO → Start with Local Flow, migrate to Remote later
81
+ ```
82
+
83
+ ## Design Philosophy
84
+
85
+ 1. **One-call setup**: Each utility does one thing completely — no multi-step assembly required
86
+ 2. **Environment-aware**: Utilities read env vars for CI/CD integration without manual wiring
87
+ 3. **Type-safe**: Full TypeScript types for all inputs and outputs, exported for consumer use
88
+ 4. **Fail-safe defaults**: Sensible defaults that work locally; env vars override for CI
89
+ 5. **Composable**: Utilities work independently — use only what you need
90
+
91
+ ## Pattern Examples
92
+
93
+ ### Example 1: Minimal Consumer Test
94
+
95
+ ```typescript
96
+ import { PactV3 } from '@pact-foundation/pact';
97
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
98
+
99
+ const provider = new PactV3({
100
+ consumer: 'my-frontend',
101
+ provider: 'my-api',
102
+ dir: './pacts',
103
+ });
104
+
105
+ it('should get user by id', async () => {
106
+ await provider
107
+ .given(...createProviderState({ name: 'user exists', params: { id: 1 } }))
108
+ .uponReceiving('a request for user 1')
109
+ .withRequest({ method: 'GET', path: '/users/1' })
110
+ .willRespondWith({ status: 200, body: { id: 1, name: 'John' } })
111
+ .executeTest(async (mockServer) => {
112
+ const res = await fetch(`${mockServer.url}/users/1`);
113
+ expect(res.status).toBe(200);
114
+ });
115
+ });
116
+ ```
117
+
118
+ ### Example 2: Minimal Provider Verification
119
+
120
+ ```typescript
121
+ import { Verifier } from '@pact-foundation/pact';
122
+ import { buildVerifierOptions, createRequestFilter } from '@seontechnologies/pactjs-utils';
123
+
124
+ const opts = buildVerifierOptions({
125
+ provider: 'my-api',
126
+ port: '3001',
127
+ includeMainAndDeployed: true,
128
+ stateHandlers: {
129
+ 'user exists': async (params) => {
130
+ await db.seed({ users: [{ id: params?.id }] });
131
+ },
132
+ },
133
+ requestFilter: createRequestFilter({
134
+ tokenGenerator: () => 'test-token-123',
135
+ }),
136
+ });
137
+
138
+ await new Verifier(opts).verifyProvider();
139
+ ```
140
+
141
+ ## Key Points
142
+
143
+ - **Import path**: Always use `@seontechnologies/pactjs-utils` (no subpath exports)
144
+ - **Peer dependency**: `@pact-foundation/pact` must be installed separately
145
+ - **Local flow**: No broker needed — set `pactUrls` in verifier options pointing to local pact files
146
+ - **Remote flow**: Set `PACT_BROKER_BASE_URL` and `PACT_BROKER_TOKEN` env vars
147
+ - **Breaking changes**: Set `includeMainAndDeployed: false` when coordinating breaking changes (verifies only matchingBranch)
148
+ - **Builder helpers**: Use `setJsonContent` when you need query/headers/body together; use `setJsonBody` for body-only callbacks
149
+ - **Type exports**: Library exports `StateHandlers`, `RequestFilter`, `JsonMap`, `JsonContentInput`, `ConsumerVersionSelector` types
150
+
151
+ ## Related Fragments
152
+
153
+ - `pactjs-utils-consumer-helpers.md` — detailed createProviderState, toJsonMap, setJsonContent, and setJsonBody usage
154
+ - `pactjs-utils-provider-verifier.md` — detailed buildVerifierOptions and broker configuration
155
+ - `pactjs-utils-request-filter.md` — detailed createRequestFilter and auth patterns
156
+ - `contract-testing.md` — foundational contract testing patterns (raw Pact.js approach)
157
+ - `test-levels-framework.md` — where contract tests fit in the testing pyramid
158
+
159
+ ## Anti-Patterns
160
+
161
+ ### Wrong: Manual VerifierOptions assembly when pactjs-utils is available
162
+
163
+ ```typescript
164
+ // ❌ Don't assemble VerifierOptions manually
165
+ const opts: VerifierOptions = {
166
+ provider: 'my-api',
167
+ providerBaseUrl: 'http://localhost:3001',
168
+ pactBrokerUrl: process.env.PACT_BROKER_BASE_URL,
169
+ pactBrokerToken: process.env.PACT_BROKER_TOKEN,
170
+ publishVerificationResult: process.env.CI === 'true',
171
+ providerVersion: process.env.GIT_SHA || 'dev',
172
+ consumerVersionSelectors: [{ mainBranch: true }, { deployedOrReleased: true }],
173
+ stateHandlers: {
174
+ /* ... */
175
+ },
176
+ requestFilter: (req, res, next) => {
177
+ /* ... */
178
+ },
179
+ // ... 20 more lines
180
+ };
181
+ ```
182
+
183
+ ### Right: Use buildVerifierOptions
184
+
185
+ ```typescript
186
+ // ✅ Single call handles all configuration
187
+ const opts = buildVerifierOptions({
188
+ provider: 'my-api',
189
+ port: '3001',
190
+ includeMainAndDeployed: true,
191
+ stateHandlers: {
192
+ /* ... */
193
+ },
194
+ requestFilter: createRequestFilter({ tokenGenerator: () => 'token' }),
195
+ });
196
+ ```
197
+
198
+ ### Wrong: Importing raw Pact types for JsonMap conversion
199
+
200
+ ```typescript
201
+ // ❌ Manual JsonMap casting
202
+ import type { JsonMap } from '@pact-foundation/pact';
203
+
204
+ provider.given('user exists', { id: 1 as unknown as JsonMap['id'] });
205
+ ```
206
+
207
+ ### Right: Use createProviderState
208
+
209
+ ```typescript
210
+ // ✅ Automatic type conversion
211
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
212
+
213
+ provider.given(...createProviderState({ name: 'user exists', params: { id: 1 } }));
214
+ ```
215
+
216
+ _Source: @seontechnologies/pactjs-utils library, pactjs-utils README, pact-js-example-provider workflows_