@cregis-dev/cckit 0.3.0 → 0.4.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 (316) hide show
  1. package/README.md +15 -3
  2. package/package.json +1 -1
  3. package/registry.json +234 -200
  4. package/src/commands/init.js +19 -15
  5. package/src/commands/update.js +9 -4
  6. package/src/core/plugin-installer.js +59 -13
  7. package/src/utils/fs.js +6 -1
  8. package/templates/bmad/_config/bmad-help.csv +2 -1
  9. package/templates/bmad/_config/files-manifest.csv +437 -431
  10. package/templates/bmad/_config/ides/claude-code.yaml +5 -5
  11. package/templates/bmad/_config/ides/trae.yaml +5 -5
  12. package/templates/bmad/_config/task-manifest.csv +7 -6
  13. package/templates/bmad/_config/workflow-manifest.csv +34 -34
  14. package/templates/bmad/bmm/agents/qa.md +1 -1
  15. package/templates/bmad/bmm/config.yaml +1 -1
  16. package/templates/bmad/bmm/module-help.csv +1 -1
  17. package/templates/bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +1 -1
  18. package/templates/bmad/bmm/workflows/1-analysis/create-product-brief/workflow.md +1 -1
  19. package/templates/bmad/bmm/workflows/1-analysis/research/workflow-domain-research.md +1 -1
  20. package/templates/bmad/bmm/workflows/1-analysis/research/workflow-market-research.md +1 -1
  21. package/templates/bmad/bmm/workflows/1-analysis/research/workflow-technical-research.md +1 -1
  22. package/templates/bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-12-complete.md +1 -1
  23. package/templates/bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +1 -1
  24. package/templates/bmad/bmm/workflows/2-plan-workflows/create-prd/workflow-create-prd.md +1 -1
  25. package/templates/bmad/bmm/workflows/2-plan-workflows/create-prd/workflow-edit-prd.md +1 -1
  26. package/templates/bmad/bmm/workflows/2-plan-workflows/create-prd/workflow-validate-prd.md +1 -1
  27. package/templates/bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +1 -1
  28. package/templates/bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +1 -1
  29. package/templates/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +1 -1
  30. package/templates/bmad/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +1 -1
  31. package/templates/bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +1 -1
  32. package/templates/bmad/bmm/workflows/3-solutioning/create-architecture/workflow.md +1 -1
  33. package/templates/bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +1 -1
  34. package/templates/bmad/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +1 -1
  35. package/templates/bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +1 -1
  36. package/templates/bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +1 -1
  37. package/templates/bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +1 -1
  38. package/templates/bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +1 -1
  39. package/templates/bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +1 -1
  40. package/templates/bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +1 -1
  41. package/templates/bmad/bmm/workflows/4-implementation/sprint-status/workflow.yaml +1 -1
  42. package/templates/bmad/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +1 -1
  43. package/templates/bmad/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +1 -1
  44. package/templates/bmad/bmm/workflows/document-project/workflow.yaml +1 -1
  45. package/templates/bmad/bmm/workflows/generate-project-context/workflow.md +1 -1
  46. package/templates/bmad/bmm/workflows/qa-generate-e2e-tests/workflow.yaml +2 -2
  47. package/templates/bmad/commands/bmad-bmm-check-implementation-readiness.md +2 -2
  48. package/templates/bmad/commands/bmad-bmm-code-review.md +4 -4
  49. package/templates/bmad/commands/bmad-bmm-correct-course.md +4 -4
  50. package/templates/bmad/commands/bmad-bmm-create-architecture.md +2 -2
  51. package/templates/bmad/commands/bmad-bmm-create-epics-and-stories.md +2 -2
  52. package/templates/bmad/commands/bmad-bmm-create-prd.md +2 -2
  53. package/templates/bmad/commands/bmad-bmm-create-product-brief.md +2 -2
  54. package/templates/bmad/commands/bmad-bmm-create-story.md +4 -4
  55. package/templates/bmad/commands/bmad-bmm-create-ux-design.md +2 -2
  56. package/templates/bmad/commands/bmad-bmm-dev-story.md +4 -4
  57. package/templates/bmad/commands/bmad-bmm-document-project.md +4 -4
  58. package/templates/bmad/commands/bmad-bmm-domain-research.md +2 -2
  59. package/templates/bmad/commands/bmad-bmm-edit-prd.md +2 -2
  60. package/templates/bmad/commands/bmad-bmm-generate-project-context.md +2 -2
  61. package/templates/bmad/commands/bmad-bmm-market-research.md +2 -2
  62. package/templates/bmad/commands/bmad-bmm-qa-generate-e2e-tests.md +4 -4
  63. package/templates/bmad/commands/bmad-bmm-quick-dev.md +2 -2
  64. package/templates/bmad/commands/bmad-bmm-quick-spec.md +2 -2
  65. package/templates/bmad/commands/bmad-bmm-retrospective.md +4 -4
  66. package/templates/bmad/commands/bmad-bmm-sprint-planning.md +4 -4
  67. package/templates/bmad/commands/bmad-bmm-sprint-status.md +4 -4
  68. package/templates/bmad/commands/bmad-bmm-technical-research.md +2 -2
  69. package/templates/bmad/commands/bmad-bmm-validate-prd.md +2 -2
  70. package/templates/bmad/commands/bmad-brainstorming.md +2 -2
  71. package/templates/bmad/commands/bmad-editorial-review-prose.md +1 -1
  72. package/templates/bmad/commands/bmad-editorial-review-structure.md +1 -1
  73. package/templates/bmad/commands/bmad-help.md +1 -1
  74. package/templates/bmad/commands/bmad-index-docs.md +1 -1
  75. package/templates/bmad/commands/bmad-party-mode.md +2 -2
  76. package/templates/bmad/commands/bmad-review-adversarial-general.md +1 -1
  77. package/templates/bmad/commands/bmad-review-edge-case-hunter.md +10 -0
  78. package/templates/bmad/commands/bmad-shard-doc.md +1 -1
  79. package/templates/bmad/commands/bmad-tea-teach-me-testing.md +2 -2
  80. package/templates/bmad/commands/bmad-tea-testarch-atdd.md +4 -4
  81. package/templates/bmad/commands/bmad-tea-testarch-automate.md +4 -4
  82. package/templates/bmad/commands/bmad-tea-testarch-ci.md +4 -4
  83. package/templates/bmad/commands/bmad-tea-testarch-framework.md +4 -4
  84. package/templates/bmad/commands/bmad-tea-testarch-nfr.md +4 -4
  85. package/templates/bmad/commands/bmad-tea-testarch-test-design.md +4 -4
  86. package/templates/bmad/commands/bmad-tea-testarch-test-review.md +4 -4
  87. package/templates/bmad/commands/bmad-tea-testarch-trace.md +4 -4
  88. package/templates/bmad/core/config.yaml +1 -1
  89. package/templates/bmad/core/module-help.csv +1 -0
  90. package/templates/bmad/core/tasks/editorial-review-prose.xml +1 -1
  91. package/templates/bmad/core/tasks/editorial-review-structure.xml +1 -1
  92. package/templates/bmad/core/tasks/help.md +1 -1
  93. package/templates/bmad/core/tasks/index-docs.xml +1 -1
  94. package/templates/bmad/core/tasks/review-adversarial-general.xml +1 -1
  95. package/templates/bmad/core/tasks/review-edge-case-hunter.xml +63 -0
  96. package/templates/bmad/core/tasks/shard-doc.xml +1 -1
  97. package/templates/bmad/core/workflows/advanced-elicitation/workflow.xml +1 -1
  98. package/templates/bmad/core/workflows/brainstorming/steps/step-01-session-setup.md +31 -18
  99. package/templates/bmad/core/workflows/brainstorming/steps/step-01b-continue.md +1 -1
  100. package/templates/bmad/core/workflows/brainstorming/steps/step-03-technique-execution.md +2 -2
  101. package/templates/bmad/core/workflows/brainstorming/steps/step-04-idea-organization.md +2 -2
  102. package/templates/bmad/core/workflows/brainstorming/workflow.md +4 -2
  103. package/templates/bmad/core/workflows/party-mode/workflow.md +1 -1
  104. package/templates/bmad/tea/config.yaml +5 -1
  105. package/templates/bmad/tea/testarch/knowledge/contract-testing.md +24 -2
  106. package/templates/bmad/tea/testarch/knowledge/pact-mcp.md +204 -0
  107. package/templates/bmad/tea/testarch/knowledge/pactjs-utils-consumer-helpers.md +211 -0
  108. package/templates/bmad/tea/testarch/knowledge/pactjs-utils-overview.md +210 -0
  109. package/templates/bmad/tea/testarch/knowledge/pactjs-utils-provider-verifier.md +315 -0
  110. package/templates/bmad/tea/testarch/knowledge/pactjs-utils-request-filter.md +224 -0
  111. package/templates/bmad/tea/testarch/tea-index.csv +5 -0
  112. package/templates/bmad/tea/workflows/testarch/README.md +1 -1
  113. package/templates/bmad/tea/workflows/testarch/atdd/steps-c/step-01-preflight-and-context.md +30 -0
  114. package/templates/bmad/tea/workflows/testarch/atdd/steps-c/step-04-generate-tests.md +159 -57
  115. package/templates/bmad/tea/workflows/testarch/atdd/steps-c/step-04a-subagent-api-failing.md +215 -0
  116. package/templates/bmad/tea/workflows/testarch/atdd/steps-c/step-04b-subagent-e2e-failing.md +244 -0
  117. package/templates/bmad/tea/workflows/testarch/atdd/steps-c/step-04c-aggregate.md +31 -15
  118. package/templates/bmad/tea/workflows/testarch/atdd/validation-report-20260127-095021.md +1 -1
  119. package/templates/bmad/tea/workflows/testarch/atdd/validation-report-20260127-102401.md +3 -3
  120. package/templates/bmad/tea/workflows/testarch/atdd/workflow.yaml +2 -2
  121. package/templates/bmad/tea/workflows/testarch/automate/steps-c/step-01-preflight-and-context.md +32 -0
  122. package/templates/bmad/tea/workflows/testarch/automate/steps-c/step-03-generate-tests.md +215 -101
  123. package/templates/bmad/tea/workflows/testarch/automate/steps-c/step-03a-subagent-api.md +193 -0
  124. package/templates/bmad/tea/workflows/testarch/automate/steps-c/step-03b-subagent-backend.md +246 -0
  125. package/templates/bmad/tea/workflows/testarch/automate/steps-c/step-03b-subagent-e2e.md +213 -0
  126. package/templates/bmad/tea/workflows/testarch/automate/steps-c/step-03c-aggregate.md +38 -22
  127. package/templates/bmad/tea/workflows/testarch/automate/validation-report-20260127-095021.md +1 -1
  128. package/templates/bmad/tea/workflows/testarch/automate/validation-report-20260127-102401.md +3 -3
  129. package/templates/bmad/tea/workflows/testarch/automate/workflow.yaml +2 -2
  130. package/templates/bmad/tea/workflows/testarch/ci/steps-c/step-02-generate-pipeline.md +124 -1
  131. package/templates/bmad/tea/workflows/testarch/ci/steps-c/step-03-configure-quality-gates.md +7 -0
  132. package/templates/bmad/tea/workflows/testarch/ci/validation-report-20260127-095021.md +1 -1
  133. package/templates/bmad/tea/workflows/testarch/ci/validation-report-20260127-102401.md +3 -3
  134. package/templates/bmad/tea/workflows/testarch/ci/workflow.yaml +2 -2
  135. package/templates/bmad/tea/workflows/testarch/framework/steps-c/step-03-scaffold-framework.md +126 -3
  136. package/templates/bmad/tea/workflows/testarch/framework/validation-report-20260127-095021.md +1 -1
  137. package/templates/bmad/tea/workflows/testarch/framework/validation-report-20260127-102401.md +3 -3
  138. package/templates/bmad/tea/workflows/testarch/framework/workflow.yaml +2 -2
  139. package/templates/bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04-evaluate-and-score.md +150 -36
  140. package/templates/bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04a-subagent-security.md +138 -0
  141. package/templates/bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04b-subagent-performance.md +84 -0
  142. package/templates/bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04c-subagent-reliability.md +85 -0
  143. package/templates/bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04d-subagent-scalability.md +88 -0
  144. package/templates/bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04e-aggregate-nfr.md +27 -10
  145. package/templates/bmad/tea/workflows/testarch/nfr-assess/validation-report-20260127-095021.md +1 -1
  146. package/templates/bmad/tea/workflows/testarch/nfr-assess/validation-report-20260127-102401.md +3 -3
  147. package/templates/bmad/tea/workflows/testarch/nfr-assess/workflow.yaml +2 -2
  148. package/templates/bmad/tea/workflows/testarch/teach-me-testing/data/tea-resources-index.yaml +3 -3
  149. package/templates/bmad/tea/workflows/testarch/teach-me-testing/workflow-plan-teach-me-testing.md +6 -6
  150. package/templates/bmad/tea/workflows/testarch/teach-me-testing/workflow.md +1 -1
  151. package/templates/bmad/tea/workflows/testarch/test-design/steps-c/step-02-load-context.md +30 -0
  152. package/templates/bmad/tea/workflows/testarch/test-design/steps-c/step-05-generate-output.md +72 -1
  153. package/templates/bmad/tea/workflows/testarch/test-design/validation-report-20260127-095021.md +1 -1
  154. package/templates/bmad/tea/workflows/testarch/test-design/validation-report-20260127-102401.md +3 -3
  155. package/templates/bmad/tea/workflows/testarch/test-design/workflow.yaml +2 -2
  156. package/templates/bmad/tea/workflows/testarch/test-review/steps-c/step-01-load-context.md +29 -1
  157. package/templates/bmad/tea/workflows/testarch/test-review/steps-c/step-03-quality-evaluation.md +147 -46
  158. package/templates/bmad/tea/workflows/testarch/test-review/steps-c/step-03a-subagent-determinism.md +214 -0
  159. package/templates/bmad/tea/workflows/testarch/test-review/steps-c/step-03b-subagent-isolation.md +125 -0
  160. package/templates/bmad/tea/workflows/testarch/test-review/steps-c/step-03c-subagent-maintainability.md +102 -0
  161. package/templates/bmad/tea/workflows/testarch/test-review/steps-c/step-03e-subagent-performance.md +117 -0
  162. package/templates/bmad/tea/workflows/testarch/test-review/steps-c/step-03f-aggregate-scores.md +10 -10
  163. package/templates/bmad/tea/workflows/testarch/test-review/validation-report-20260127-095021.md +1 -1
  164. package/templates/bmad/tea/workflows/testarch/test-review/validation-report-20260127-102401.md +3 -3
  165. package/templates/bmad/tea/workflows/testarch/test-review/workflow.yaml +2 -2
  166. package/templates/bmad/tea/workflows/testarch/trace/steps-c/step-04-analyze-gaps.md +92 -1
  167. package/templates/bmad/tea/workflows/testarch/trace/validation-report-20260127-095021.md +1 -1
  168. package/templates/bmad/tea/workflows/testarch/trace/validation-report-20260127-102401.md +3 -3
  169. package/templates/bmad/tea/workflows/testarch/trace/workflow.yaml +2 -2
  170. package/templates/ecc/agents/chief-of-staff.md +151 -0
  171. package/templates/ecc/commands/claw.md +79 -0
  172. package/templates/ecc/rules/README.md +23 -2
  173. package/templates/ecc/rules/common/development-workflow.md +37 -0
  174. package/templates/ecc/rules/common/git-workflow.md +2 -23
  175. package/templates/ecc/rules/swift/coding-style.md +47 -0
  176. package/templates/ecc/rules/swift/hooks.md +20 -0
  177. package/templates/ecc/rules/swift/patterns.md +66 -0
  178. package/templates/ecc/rules/swift/security.md +33 -0
  179. package/templates/ecc/rules/swift/testing.md +45 -0
  180. package/templates/ecc/skills/api-design/SKILL.md +1 -0
  181. package/templates/ecc/skills/article-writing/SKILL.md +85 -0
  182. package/templates/ecc/skills/backend-patterns/SKILL.md +1 -0
  183. package/templates/ecc/skills/clickhouse-io/SKILL.md +1 -0
  184. package/templates/ecc/skills/coding-standards/SKILL.md +1 -0
  185. package/templates/ecc/skills/configure-ecc/SKILL.md +32 -4
  186. package/templates/ecc/skills/content-engine/SKILL.md +88 -0
  187. package/templates/ecc/skills/content-hash-cache-pattern/SKILL.md +1 -0
  188. package/templates/ecc/skills/continuous-learning/SKILL.md +2 -1
  189. package/templates/ecc/skills/continuous-learning-v2/SKILL.md +4 -1
  190. package/templates/ecc/skills/continuous-learning-v2/hooks/observe.sh +14 -7
  191. package/templates/ecc/skills/cost-aware-llm-pipeline/SKILL.md +1 -0
  192. package/templates/ecc/skills/cpp-coding-standards/SKILL.md +1 -0
  193. package/templates/ecc/skills/cpp-testing/SKILL.md +1 -0
  194. package/templates/ecc/skills/database-migrations/SKILL.md +1 -0
  195. package/templates/ecc/skills/deployment-patterns/SKILL.md +1 -0
  196. package/templates/ecc/skills/django-patterns/SKILL.md +1 -0
  197. package/templates/ecc/skills/django-security/SKILL.md +1 -0
  198. package/templates/ecc/skills/django-tdd/SKILL.md +1 -0
  199. package/templates/ecc/skills/django-verification/SKILL.md +1 -0
  200. package/templates/ecc/skills/docker-patterns/SKILL.md +1 -0
  201. package/templates/ecc/skills/e2e-testing/SKILL.md +1 -0
  202. package/templates/ecc/skills/eval-harness/SKILL.md +1 -0
  203. package/templates/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
  204. package/templates/ecc/skills/frontend-patterns/SKILL.md +1 -0
  205. package/templates/ecc/skills/frontend-slides/SKILL.md +184 -0
  206. package/templates/ecc/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  207. package/templates/ecc/skills/golang-patterns/SKILL.md +1 -0
  208. package/templates/ecc/skills/golang-testing/SKILL.md +1 -0
  209. package/templates/ecc/skills/investor-materials/SKILL.md +96 -0
  210. package/templates/ecc/skills/investor-outreach/SKILL.md +76 -0
  211. package/templates/ecc/skills/iterative-retrieval/SKILL.md +1 -0
  212. package/templates/ecc/skills/java-coding-standards/SKILL.md +1 -0
  213. package/templates/ecc/skills/jpa-patterns/SKILL.md +1 -0
  214. package/templates/ecc/skills/liquid-glass-design/SKILL.md +279 -0
  215. package/templates/ecc/skills/market-research/SKILL.md +75 -0
  216. package/templates/ecc/skills/nutrient-document-processing/SKILL.md +1 -1
  217. package/templates/ecc/skills/postgres-patterns/SKILL.md +1 -0
  218. package/templates/ecc/skills/project-guidelines-example/SKILL.md +1 -0
  219. package/templates/ecc/skills/python-patterns/SKILL.md +1 -0
  220. package/templates/ecc/skills/python-testing/SKILL.md +1 -0
  221. package/templates/ecc/skills/regex-vs-llm-structured-text/SKILL.md +1 -0
  222. package/templates/ecc/skills/search-first/SKILL.md +3 -1
  223. package/templates/ecc/skills/security-review/SKILL.md +1 -0
  224. package/templates/ecc/skills/security-scan/SKILL.md +1 -0
  225. package/templates/ecc/skills/skill-stocktake/SKILL.md +176 -0
  226. package/templates/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  227. package/templates/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
  228. package/templates/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
  229. package/templates/ecc/skills/springboot-patterns/SKILL.md +1 -0
  230. package/templates/ecc/skills/springboot-security/SKILL.md +1 -0
  231. package/templates/ecc/skills/springboot-tdd/SKILL.md +1 -0
  232. package/templates/ecc/skills/springboot-verification/SKILL.md +1 -0
  233. package/templates/ecc/skills/strategic-compact/SKILL.md +1 -0
  234. package/templates/ecc/skills/swift-actor-persistence/SKILL.md +1 -0
  235. package/templates/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
  236. package/templates/ecc/skills/swift-protocol-di-testing/SKILL.md +1 -0
  237. package/templates/ecc/skills/swiftui-patterns/SKILL.md +259 -0
  238. package/templates/ecc/skills/tdd-workflow/SKILL.md +1 -0
  239. package/templates/ecc/skills/verification-loop/SKILL.md +1 -0
  240. package/templates/ecc/skills/visa-doc-translate/README.md +86 -0
  241. package/templates/ecc/skills/visa-doc-translate/SKILL.md +117 -0
  242. package/templates/ext-skills/pinchtab/SKILL.md +89 -486
  243. package/templates/ext-skills/pinchtab/TRUST.md +69 -0
  244. package/templates/ext-skills/pinchtab/references/api.md +297 -0
  245. package/templates/ext-skills/pinchtab/references/env.md +45 -0
  246. package/templates/ext-skills/pinchtab/references/profiles.md +107 -0
  247. package/templates/plugins/claude-code-setup/.claude-plugin/plugin.json +9 -0
  248. package/templates/plugins/claude-code-setup/LICENSE +202 -0
  249. package/templates/plugins/claude-code-setup/README.md +29 -0
  250. package/templates/plugins/claude-code-setup/automation-recommender-example.png +0 -0
  251. package/templates/plugins/claude-code-setup/skills/claude-automation-recommender/SKILL.md +288 -0
  252. package/templates/plugins/claude-code-setup/skills/claude-automation-recommender/references/hooks-patterns.md +226 -0
  253. package/templates/plugins/claude-code-setup/skills/claude-automation-recommender/references/mcp-servers.md +263 -0
  254. package/templates/plugins/claude-code-setup/skills/claude-automation-recommender/references/plugins-reference.md +98 -0
  255. package/templates/plugins/claude-code-setup/skills/claude-automation-recommender/references/skills-reference.md +408 -0
  256. package/templates/plugins/claude-code-setup/skills/claude-automation-recommender/references/subagent-templates.md +181 -0
  257. package/templates/plugins/claude-md-management/.claude-plugin/plugin.json +9 -0
  258. package/templates/plugins/claude-md-management/LICENSE +202 -0
  259. package/templates/plugins/claude-md-management/README.md +40 -0
  260. package/templates/plugins/claude-md-management/claude-md-improver-example.png +0 -0
  261. package/templates/plugins/claude-md-management/commands/revise-claude-md.md +54 -0
  262. package/templates/plugins/claude-md-management/revise-claude-md-example.png +0 -0
  263. package/templates/plugins/claude-md-management/skills/claude-md-improver/SKILL.md +179 -0
  264. package/templates/plugins/claude-md-management/skills/claude-md-improver/references/quality-criteria.md +109 -0
  265. package/templates/plugins/claude-md-management/skills/claude-md-improver/references/templates.md +253 -0
  266. package/templates/plugins/claude-md-management/skills/claude-md-improver/references/update-guidelines.md +150 -0
  267. package/templates/plugins/code-simplifier/.claude-plugin/plugin.json +9 -0
  268. package/templates/plugins/code-simplifier/LICENSE +202 -0
  269. package/templates/plugins/code-simplifier/agents/code-simplifier.md +52 -0
  270. package/templates/plugins/commit-commands/.claude-plugin/plugin.json +9 -0
  271. package/templates/plugins/commit-commands/LICENSE +202 -0
  272. package/templates/plugins/commit-commands/README.md +225 -0
  273. package/templates/plugins/commit-commands/commands/clean_gone.md +53 -0
  274. package/templates/plugins/commit-commands/commands/commit-push-pr.md +20 -0
  275. package/templates/plugins/commit-commands/commands/commit.md +17 -0
  276. package/templates/trae-bmad/rules/bmad-bmm-check-implementation-readiness.md +2 -2
  277. package/templates/trae-bmad/rules/bmad-bmm-code-review.md +4 -4
  278. package/templates/trae-bmad/rules/bmad-bmm-correct-course.md +4 -4
  279. package/templates/trae-bmad/rules/bmad-bmm-create-architecture.md +2 -2
  280. package/templates/trae-bmad/rules/bmad-bmm-create-epics-and-stories.md +2 -2
  281. package/templates/trae-bmad/rules/bmad-bmm-create-prd.md +2 -2
  282. package/templates/trae-bmad/rules/bmad-bmm-create-product-brief.md +2 -2
  283. package/templates/trae-bmad/rules/bmad-bmm-create-story.md +4 -4
  284. package/templates/trae-bmad/rules/bmad-bmm-create-ux-design.md +2 -2
  285. package/templates/trae-bmad/rules/bmad-bmm-dev-story.md +4 -4
  286. package/templates/trae-bmad/rules/bmad-bmm-document-project.md +4 -4
  287. package/templates/trae-bmad/rules/bmad-bmm-domain-research.md +2 -2
  288. package/templates/trae-bmad/rules/bmad-bmm-edit-prd.md +2 -2
  289. package/templates/trae-bmad/rules/bmad-bmm-generate-project-context.md +2 -2
  290. package/templates/trae-bmad/rules/bmad-bmm-market-research.md +2 -2
  291. package/templates/trae-bmad/rules/bmad-bmm-qa-generate-e2e-tests.md +4 -4
  292. package/templates/trae-bmad/rules/bmad-bmm-quick-dev.md +2 -2
  293. package/templates/trae-bmad/rules/bmad-bmm-quick-spec.md +2 -2
  294. package/templates/trae-bmad/rules/bmad-bmm-retrospective.md +4 -4
  295. package/templates/trae-bmad/rules/bmad-bmm-sprint-planning.md +4 -4
  296. package/templates/trae-bmad/rules/bmad-bmm-sprint-status.md +4 -4
  297. package/templates/trae-bmad/rules/bmad-bmm-technical-research.md +2 -2
  298. package/templates/trae-bmad/rules/bmad-bmm-validate-prd.md +2 -2
  299. package/templates/trae-bmad/rules/bmad-brainstorming.md +2 -2
  300. package/templates/trae-bmad/rules/bmad-editorial-review-prose.md +1 -1
  301. package/templates/trae-bmad/rules/bmad-editorial-review-structure.md +1 -1
  302. package/templates/trae-bmad/rules/bmad-help.md +1 -1
  303. package/templates/trae-bmad/rules/bmad-index-docs.md +1 -1
  304. package/templates/trae-bmad/rules/bmad-party-mode.md +2 -2
  305. package/templates/trae-bmad/rules/bmad-review-adversarial-general.md +1 -1
  306. package/templates/trae-bmad/rules/bmad-review-edge-case-hunter.md +10 -0
  307. package/templates/trae-bmad/rules/bmad-shard-doc.md +1 -1
  308. package/templates/trae-bmad/rules/bmad-tea-teach-me-testing.md +2 -2
  309. package/templates/trae-bmad/rules/bmad-tea-testarch-atdd.md +4 -4
  310. package/templates/trae-bmad/rules/bmad-tea-testarch-automate.md +4 -4
  311. package/templates/trae-bmad/rules/bmad-tea-testarch-ci.md +4 -4
  312. package/templates/trae-bmad/rules/bmad-tea-testarch-framework.md +4 -4
  313. package/templates/trae-bmad/rules/bmad-tea-testarch-nfr.md +4 -4
  314. package/templates/trae-bmad/rules/bmad-tea-testarch-test-design.md +4 -4
  315. package/templates/trae-bmad/rules/bmad-tea-testarch-test-review.md +4 -4
  316. package/templates/trae-bmad/rules/bmad-tea-testarch-trace.md +4 -4
@@ -0,0 +1,211 @@
1
+ # Pact.js Utils Consumer Helpers
2
+
3
+ ## Principle
4
+
5
+ Use `createProviderState` and `toJsonMap` from `@seontechnologies/pactjs-utils` to build type-safe provider state tuples for consumer contract tests. These helpers eliminate manual `JsonMap` casting and ensure consistent parameter serialization across all consumer pact interactions.
6
+
7
+ ## Rationale
8
+
9
+ ### Problems with raw provider state 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
+
16
+ ### Solutions
17
+
18
+ - **`createProviderState`**: Returns a `[string, JsonMap]` tuple that spreads directly into `.given()` — one function handles name and params
19
+ - **`toJsonMap`**: Explicit coercion rules documented and tested — Date→ISO string, null→"null" string, nested objects→JSON string
20
+
21
+ ## Pattern Examples
22
+
23
+ ### Example 1: Basic Provider State Creation
24
+
25
+ ```typescript
26
+ import { PactV3, MatchersV3 } from '@pact-foundation/pact';
27
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
28
+
29
+ const provider = new PactV3({
30
+ consumer: 'movie-web',
31
+ provider: 'SampleMoviesAPI',
32
+ dir: './pacts',
33
+ });
34
+
35
+ describe('Movie API Contract', () => {
36
+ it('should return movie by id', async () => {
37
+ // createProviderState returns [stateName, JsonMap] tuple
38
+ const providerState = createProviderState({
39
+ name: 'movie with id 1 exists',
40
+ params: { id: 1, name: 'Inception', year: 2010 },
41
+ });
42
+
43
+ await provider
44
+ .given(...providerState) // Spread tuple into .given(name, params)
45
+ .uponReceiving('a request for movie 1')
46
+ .withRequest({ method: 'GET', path: '/movies/1' })
47
+ .willRespondWith({
48
+ status: 200,
49
+ body: MatchersV3.like({ id: 1, name: 'Inception', year: 2010 }),
50
+ })
51
+ .executeTest(async (mockServer) => {
52
+ const res = await fetch(`${mockServer.url}/movies/1`);
53
+ const movie = await res.json();
54
+ expect(movie.name).toBe('Inception');
55
+ });
56
+ });
57
+ });
58
+ ```
59
+
60
+ **Key Points**:
61
+
62
+ - `createProviderState` accepts `{ name: string, params: Record<string, unknown> }`
63
+ - Both `name` and `params` are required (pass `params: {}` for states without parameters)
64
+ - Returns `[string, JsonMap]` — spread with `...` into `.given()`
65
+ - `params` values are automatically converted to JsonMap-compatible types
66
+ - Works identically with HTTP (`PactV3`) and message (`MessageConsumerPact`) pacts
67
+
68
+ ### Example 2: Complex Parameters with toJsonMap
69
+
70
+ ```typescript
71
+ import { toJsonMap } from '@seontechnologies/pactjs-utils';
72
+
73
+ // toJsonMap conversion rules:
74
+ // - string, number, boolean → passed through
75
+ // - null → "null" (string)
76
+ // - undefined → "null" (string, same as null)
77
+ // - Date → ISO string (e.g., "2025-01-15T10:00:00.000Z")
78
+ // - nested object → JSON string
79
+ // - array → comma-separated string via String() (e.g., [1,2,3] → "1,2,3")
80
+
81
+ const params = toJsonMap({
82
+ id: 42,
83
+ name: 'John Doe',
84
+ active: true,
85
+ score: null,
86
+ createdAt: new Date('2025-01-15T10:00:00Z'),
87
+ metadata: { role: 'admin', permissions: ['read', 'write'] },
88
+ });
89
+
90
+ // Result:
91
+ // {
92
+ // id: 42,
93
+ // name: "John Doe",
94
+ // active: true,
95
+ // score: "null",
96
+ // createdAt: "2025-01-15T10:00:00.000Z",
97
+ // metadata: '{"role":"admin","permissions":["read","write"]}'
98
+ // }
99
+ ```
100
+
101
+ **Key Points**:
102
+
103
+ - `toJsonMap` is called internally by `createProviderState` — you rarely need it directly
104
+ - Use it when you need explicit control over parameter conversion outside of provider states
105
+ - Conversion rules are deterministic: same input always produces same output
106
+
107
+ ### Example 3: Provider State Without Parameters
108
+
109
+ ```typescript
110
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
111
+
112
+ // State without params — second tuple element is empty object
113
+ const emptyState = createProviderState({ name: 'no movies exist', params: {} });
114
+ // Returns: ['no movies exist', {}]
115
+
116
+ await provider
117
+ .given(...emptyState)
118
+ .uponReceiving('a request when no movies exist')
119
+ .withRequest({ method: 'GET', path: '/movies' })
120
+ .willRespondWith({ status: 200, body: [] })
121
+ .executeTest(async (mockServer) => {
122
+ const res = await fetch(`${mockServer.url}/movies`);
123
+ const movies = await res.json();
124
+ expect(movies).toEqual([]);
125
+ });
126
+ ```
127
+
128
+ ### Example 4: Multiple Provider States
129
+
130
+ ```typescript
131
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
132
+
133
+ // Some interactions require multiple provider states
134
+ // Call .given() multiple times with different states
135
+ await provider
136
+ .given(...createProviderState({ name: 'user is authenticated', params: { userId: 1 } }))
137
+ .given(...createProviderState({ name: 'movie with id 5 exists', params: { id: 5 } }))
138
+ .uponReceiving('an authenticated request for movie 5')
139
+ .withRequest({
140
+ method: 'GET',
141
+ path: '/movies/5',
142
+ headers: { Authorization: MatchersV3.like('Bearer token') },
143
+ })
144
+ .willRespondWith({ status: 200, body: MatchersV3.like({ id: 5 }) })
145
+ .executeTest(async (mockServer) => {
146
+ // test implementation
147
+ });
148
+ ```
149
+
150
+ ## Key Points
151
+
152
+ - **Spread pattern**: Always use `...createProviderState()` — the tuple spreads into `.given(stateName, params)`
153
+ - **Type safety**: TypeScript enforces `{ name: string, params: Record<string, unknown> }` input (both fields required)
154
+ - **Null handling**: `null` becomes `"null"` string in JsonMap (Pact requirement)
155
+ - **Date handling**: Date objects become ISO 8601 strings
156
+ - **No nested objects in JsonMap**: Nested objects are JSON-stringified — provider state handlers must parse them
157
+ - **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
158
+ - **Message pacts**: Works identically with `MessageConsumerPact` — same `.given()` API
159
+
160
+ ## Related Fragments
161
+
162
+ - `pactjs-utils-overview.md` — installation, decision tree, design philosophy
163
+ - `pactjs-utils-provider-verifier.md` — provider-side state handler implementation
164
+ - `contract-testing.md` — foundational patterns with raw Pact.js
165
+
166
+ ## Anti-Patterns
167
+
168
+ ### Wrong: Manual JsonMap assembly
169
+
170
+ ```typescript
171
+ // ❌ Manual casting — verbose, error-prone, no type safety
172
+ provider.given('user exists', {
173
+ id: 1 as unknown as string,
174
+ createdAt: new Date().toISOString(),
175
+ metadata: JSON.stringify({ role: 'admin' }),
176
+ } as JsonMap);
177
+ ```
178
+
179
+ ### Right: Use createProviderState
180
+
181
+ ```typescript
182
+ // ✅ Automatic conversion with type safety
183
+ provider.given(
184
+ ...createProviderState({
185
+ name: 'user exists',
186
+ params: { id: 1, createdAt: new Date(), metadata: { role: 'admin' } },
187
+ }),
188
+ );
189
+ ```
190
+
191
+ ### Wrong: Inline state names without helper
192
+
193
+ ```typescript
194
+ // ❌ Duplicated state names between consumer and provider — easy to mismatch
195
+ provider.given('a user with id 1 exists', { id: '1' });
196
+ // Later in provider: 'user with id 1 exists' — different string!
197
+ ```
198
+
199
+ ### Right: Share state constants
200
+
201
+ ```typescript
202
+ // ✅ Define state names as constants shared between consumer and provider
203
+ const STATES = {
204
+ USER_EXISTS: 'user with id exists',
205
+ NO_USERS: 'no users exist',
206
+ } as const;
207
+
208
+ provider.given(...createProviderState({ name: STATES.USER_EXISTS, params: { id: 1 } }));
209
+ ```
210
+
211
+ _Source: @seontechnologies/pactjs-utils consumer-helpers module, pactjs-utils sample-app consumer tests_
@@ -0,0 +1,210 @@
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, 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
+ - **Verifier configuration sprawl**: `VerifierOptions` requires 30+ lines of scattered configuration (broker URL, selectors, state handlers, request filters, version tags)
13
+ - **Environment variable juggling**: Different env vars for local vs remote flows, breaking change coordination, payload URL matching
14
+ - **Express middleware types**: Request filter requires Express types that aren't re-exported from Pact
15
+ - **Bearer prefix bugs**: Easy to double-prefix tokens as `Bearer Bearer ...` in request filters
16
+ - **CI version tagging**: Manual logic to extract branch/tag info from CI environment
17
+
18
+ ### Solutions from pactjs-utils
19
+
20
+ - **`createProviderState`**: One-call tuple builder for `.given()` — handles all JsonMap conversion automatically
21
+ - **`toJsonMap`**: Explicit type coercion (null→"null", Date→ISO string, nested objects flattened)
22
+ - **`buildVerifierOptions`**: Single function assembles complete VerifierOptions from minimal inputs — handles local/remote/BDCT flows
23
+ - **`buildMessageVerifierOptions`**: Same as above but for message/Kafka provider verification
24
+ - **`handlePactBrokerUrlAndSelectors`**: Resolves broker URL and consumer version selectors from env vars with breaking change awareness
25
+ - **`getProviderVersionTags`**: CI-aware version tagging (extracts branch/tag from GitHub Actions, GitLab CI, etc.)
26
+ - **`createRequestFilter`**: Pluggable token generator pattern — prevents double-Bearer bugs by contract
27
+ - **`noOpRequestFilter`**: Pass-through for providers that don't require auth injection
28
+
29
+ ## Installation
30
+
31
+ ```bash
32
+ npm install -D @seontechnologies/pactjs-utils
33
+
34
+ # Peer dependency
35
+ npm install -D @pact-foundation/pact
36
+ ```
37
+
38
+ **Requirements**: `@pact-foundation/pact` >= 16.2.0, Node.js >= 18
39
+
40
+ ## Available Utilities
41
+
42
+ | Category | Function | Description | Use Case |
43
+ | ----------------- | --------------------------------- | ---------------------------------------------------- | ---------------------------------------------------------------- |
44
+ | Consumer Helpers | `createProviderState` | Builds `[stateName, JsonMap]` tuple from typed input | Consumer tests: `.given(...createProviderState(input))` |
45
+ | Consumer Helpers | `toJsonMap` | Converts any object to Pact-compatible `JsonMap` | Explicit type coercion for provider state params |
46
+ | Provider Verifier | `buildVerifierOptions` | Assembles complete HTTP `VerifierOptions` | Provider verification: `new Verifier(buildVerifierOptions(...))` |
47
+ | Provider Verifier | `buildMessageVerifierOptions` | Assembles message `VerifierOptions` | Kafka/async provider verification |
48
+ | Provider Verifier | `handlePactBrokerUrlAndSelectors` | Resolves broker URL + selectors from env vars | Env-aware broker configuration |
49
+ | Provider Verifier | `getProviderVersionTags` | CI-aware version tag extraction | Provider version tagging in CI |
50
+ | Request Filter | `createRequestFilter` | Express middleware with pluggable token generator | Auth injection for provider verification |
51
+ | Request Filter | `noOpRequestFilter` | Pass-through filter (no-op) | Providers without auth requirements |
52
+
53
+ ## Decision Tree: Which Flow?
54
+
55
+ ```
56
+ Is this a monorepo (consumer + provider in same repo)?
57
+ ├── YES → Local Flow
58
+ │ - Consumer generates pact files to ./pacts/
59
+ │ - Provider reads pact files from ./pacts/ (no broker needed)
60
+ │ - Use buildVerifierOptions with pactUrls option
61
+
62
+ └── NO → Do you have a Pact Broker / PactFlow?
63
+ ├── YES → Remote (CDCT) Flow
64
+ │ - Consumer publishes pacts to broker
65
+ │ - Provider verifies from broker
66
+ │ - Use buildVerifierOptions with broker config
67
+ │ - Set PACT_BROKER_BASE_URL + PACT_BROKER_TOKEN
68
+
69
+ └── Do you have an OpenAPI spec?
70
+ ├── YES → BDCT Flow (PactFlow only)
71
+ │ - Provider publishes OpenAPI spec to PactFlow
72
+ │ - PactFlow cross-validates consumer pacts against spec
73
+ │ - No provider verification test needed
74
+
75
+ └── NO → Start with Local Flow, migrate to Remote later
76
+ ```
77
+
78
+ ## Design Philosophy
79
+
80
+ 1. **One-call setup**: Each utility does one thing completely — no multi-step assembly required
81
+ 2. **Environment-aware**: Utilities read env vars for CI/CD integration without manual wiring
82
+ 3. **Type-safe**: Full TypeScript types for all inputs and outputs, exported for consumer use
83
+ 4. **Fail-safe defaults**: Sensible defaults that work locally; env vars override for CI
84
+ 5. **Composable**: Utilities work independently — use only what you need
85
+
86
+ ## Pattern Examples
87
+
88
+ ### Example 1: Minimal Consumer Test
89
+
90
+ ```typescript
91
+ import { PactV3 } from '@pact-foundation/pact';
92
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
93
+
94
+ const provider = new PactV3({
95
+ consumer: 'my-frontend',
96
+ provider: 'my-api',
97
+ dir: './pacts',
98
+ });
99
+
100
+ it('should get user by id', async () => {
101
+ await provider
102
+ .given(...createProviderState({ name: 'user exists', params: { id: 1 } }))
103
+ .uponReceiving('a request for user 1')
104
+ .withRequest({ method: 'GET', path: '/users/1' })
105
+ .willRespondWith({ status: 200, body: { id: 1, name: 'John' } })
106
+ .executeTest(async (mockServer) => {
107
+ const res = await fetch(`${mockServer.url}/users/1`);
108
+ expect(res.status).toBe(200);
109
+ });
110
+ });
111
+ ```
112
+
113
+ ### Example 2: Minimal Provider Verification
114
+
115
+ ```typescript
116
+ import { Verifier } from '@pact-foundation/pact';
117
+ import { buildVerifierOptions, createRequestFilter } from '@seontechnologies/pactjs-utils';
118
+
119
+ const opts = buildVerifierOptions({
120
+ provider: 'my-api',
121
+ port: '3001',
122
+ includeMainAndDeployed: true,
123
+ stateHandlers: {
124
+ 'user exists': async (params) => {
125
+ await db.seed({ users: [{ id: params?.id }] });
126
+ },
127
+ },
128
+ requestFilter: createRequestFilter({
129
+ tokenGenerator: () => 'test-token-123',
130
+ }),
131
+ });
132
+
133
+ await new Verifier(opts).verifyProvider();
134
+ ```
135
+
136
+ ## Key Points
137
+
138
+ - **Import path**: Always use `@seontechnologies/pactjs-utils` (no subpath exports)
139
+ - **Peer dependency**: `@pact-foundation/pact` must be installed separately
140
+ - **Local flow**: No broker needed — set `pactUrls` in verifier options pointing to local pact files
141
+ - **Remote flow**: Set `PACT_BROKER_BASE_URL` and `PACT_BROKER_TOKEN` env vars
142
+ - **Breaking changes**: Set `includeMainAndDeployed: false` when coordinating breaking changes (verifies only matchingBranch)
143
+ - **Type exports**: Library exports `StateHandlers`, `RequestFilter`, `JsonMap`, `ConsumerVersionSelector` types
144
+
145
+ ## Related Fragments
146
+
147
+ - `pactjs-utils-consumer-helpers.md` — detailed createProviderState and toJsonMap usage
148
+ - `pactjs-utils-provider-verifier.md` — detailed buildVerifierOptions and broker configuration
149
+ - `pactjs-utils-request-filter.md` — detailed createRequestFilter and auth patterns
150
+ - `contract-testing.md` — foundational contract testing patterns (raw Pact.js approach)
151
+ - `test-levels-framework.md` — where contract tests fit in the testing pyramid
152
+
153
+ ## Anti-Patterns
154
+
155
+ ### Wrong: Manual VerifierOptions assembly when pactjs-utils is available
156
+
157
+ ```typescript
158
+ // ❌ Don't assemble VerifierOptions manually
159
+ const opts: VerifierOptions = {
160
+ provider: 'my-api',
161
+ providerBaseUrl: 'http://localhost:3001',
162
+ pactBrokerUrl: process.env.PACT_BROKER_BASE_URL,
163
+ pactBrokerToken: process.env.PACT_BROKER_TOKEN,
164
+ publishVerificationResult: process.env.CI === 'true',
165
+ providerVersion: process.env.GIT_SHA || 'dev',
166
+ consumerVersionSelectors: [{ mainBranch: true }, { deployedOrReleased: true }],
167
+ stateHandlers: {
168
+ /* ... */
169
+ },
170
+ requestFilter: (req, res, next) => {
171
+ /* ... */
172
+ },
173
+ // ... 20 more lines
174
+ };
175
+ ```
176
+
177
+ ### Right: Use buildVerifierOptions
178
+
179
+ ```typescript
180
+ // ✅ Single call handles all configuration
181
+ const opts = buildVerifierOptions({
182
+ provider: 'my-api',
183
+ port: '3001',
184
+ includeMainAndDeployed: true,
185
+ stateHandlers: {
186
+ /* ... */
187
+ },
188
+ requestFilter: createRequestFilter({ tokenGenerator: () => 'token' }),
189
+ });
190
+ ```
191
+
192
+ ### Wrong: Importing raw Pact types for JsonMap conversion
193
+
194
+ ```typescript
195
+ // ❌ Manual JsonMap casting
196
+ import type { JsonMap } from '@pact-foundation/pact';
197
+
198
+ provider.given('user exists', { id: 1 as unknown as JsonMap['id'] });
199
+ ```
200
+
201
+ ### Right: Use createProviderState
202
+
203
+ ```typescript
204
+ // ✅ Automatic type conversion
205
+ import { createProviderState } from '@seontechnologies/pactjs-utils';
206
+
207
+ provider.given(...createProviderState({ name: 'user exists', params: { id: 1 } }));
208
+ ```
209
+
210
+ _Source: @seontechnologies/pactjs-utils library, pactjs-utils README, pact-js-example-provider workflows_