create-byan-agent 2.0.1 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (974) hide show
  1. package/.github/agents/bmad-agent-bmad-master.md +40 -0
  2. package/.github/agents/bmad-agent-byan-v2.md +44 -0
  3. package/.github/agents/bmad-agent-byan.md +251 -0
  4. package/.github/agents/bmad-agent-drawio.md +44 -0
  5. package/.github/agents/bmad-agent-marc.md +98 -0
  6. package/README.MD +225 -0
  7. package/__tests__/byan-v2/context/copilot-context.test.js +327 -0
  8. package/__tests__/byan-v2/context/session-state.test.js +322 -0
  9. package/__tests__/byan-v2/dispatcher/complexity-scorer.test.js +358 -0
  10. package/__tests__/byan-v2/dispatcher/five-whys-analyzer.test.js +473 -0
  11. package/__tests__/byan-v2/dispatcher/local-executor.test.js +496 -0
  12. package/__tests__/byan-v2/dispatcher/task-router.test.js +265 -0
  13. package/__tests__/byan-v2/dispatcher/task-tool-interface.test.js +328 -0
  14. package/__tests__/byan-v2/generation/agent-profile-validator.test.js +386 -0
  15. package/__tests__/byan-v2/generation/mantra-validator.test.js +640 -0
  16. package/__tests__/byan-v2/generation/profile-template.test.js +338 -0
  17. package/__tests__/byan-v2/integration/active-listening-flow.test.js +577 -0
  18. package/__tests__/byan-v2/integration/five-whys-flow.test.js +559 -0
  19. package/__tests__/byan-v2/integration/full-bmad-workflow.test.js +903 -0
  20. package/__tests__/byan-v2/integration/full-bmad-workflow.test.js.backup +889 -0
  21. package/__tests__/byan-v2/integration/glossary-flow.test.js +479 -0
  22. package/__tests__/byan-v2/integration/system-integration.test.js +306 -0
  23. package/__tests__/byan-v2/integration/voice-integration.test.js +157 -0
  24. package/__tests__/byan-v2/observability/error-tracker.test.js +461 -0
  25. package/__tests__/byan-v2/observability/logger.test.js +419 -0
  26. package/__tests__/byan-v2/observability/metrics-collector.test.js +346 -0
  27. package/__tests__/byan-v2/orchestrator/active-listener.test.js +694 -0
  28. package/__tests__/byan-v2/orchestrator/analysis-state.test.js +493 -0
  29. package/__tests__/byan-v2/orchestrator/generation-state.test.js +518 -0
  30. package/__tests__/byan-v2/orchestrator/glossary-builder.test.js +464 -0
  31. package/__tests__/byan-v2/orchestrator/interview-state.test.js +470 -0
  32. package/__tests__/byan-v2/orchestrator/state-machine.test.js +495 -0
  33. package/__tests__/cache.test.js +241 -0
  34. package/__tests__/context.test.js +135 -0
  35. package/__tests__/dashboard.test.js +444 -0
  36. package/__tests__/dispatcher.test.js +245 -0
  37. package/__tests__/integration.test.js +163 -0
  38. package/__tests__/metrics-collector.test.js +433 -0
  39. package/__tests__/structured-logger.test.js +358 -0
  40. package/__tests__/worker-pool.test.js +343 -0
  41. package/__tests__/workflow-executor.test.js +356 -0
  42. package/_bmad/_config/agent-manifest.csv +25 -0
  43. package/_bmad/_config/agents/bmb-agent-builder.customize.yaml +41 -0
  44. package/_bmad/_config/agents/bmb-module-builder.customize.yaml +41 -0
  45. package/_bmad/_config/agents/bmb-workflow-builder.customize.yaml +41 -0
  46. package/_bmad/_config/agents/bmm-analyst.customize.yaml +41 -0
  47. package/_bmad/_config/agents/bmm-architect.customize.yaml +41 -0
  48. package/_bmad/_config/agents/bmm-dev.customize.yaml +41 -0
  49. package/_bmad/_config/agents/bmm-pm.customize.yaml +41 -0
  50. package/_bmad/_config/agents/bmm-quick-flow-solo-dev.customize.yaml +41 -0
  51. package/_bmad/_config/agents/bmm-quinn.customize.yaml +41 -0
  52. package/_bmad/_config/agents/bmm-sm.customize.yaml +41 -0
  53. package/_bmad/_config/agents/bmm-tech-writer.customize.yaml +41 -0
  54. package/_bmad/_config/agents/bmm-ux-designer.customize.yaml +41 -0
  55. package/_bmad/_config/agents/byan.customize.yaml +29 -0
  56. package/_bmad/_config/agents/cis-brainstorming-coach.customize.yaml +41 -0
  57. package/_bmad/_config/agents/cis-creative-problem-solver.customize.yaml +41 -0
  58. package/_bmad/_config/agents/cis-design-thinking-coach.customize.yaml +41 -0
  59. package/_bmad/_config/agents/cis-innovation-strategist.customize.yaml +41 -0
  60. package/_bmad/_config/agents/cis-presentation-master.customize.yaml +41 -0
  61. package/_bmad/_config/agents/cis-storyteller.customize.yaml +41 -0
  62. package/_bmad/_config/agents/core-bmad-master.customize.yaml +41 -0
  63. package/_bmad/_config/agents/tea-tea.customize.yaml +41 -0
  64. package/_bmad/_config/bmad-help.csv +72 -0
  65. package/_bmad/_config/files-manifest.csv +607 -0
  66. package/_bmad/_config/ides/codex.yaml +5 -0
  67. package/_bmad/_config/manifest.yaml +43 -0
  68. package/_bmad/_config/task-manifest.csv +9 -0
  69. package/_bmad/_config/tool-manifest.csv +1 -0
  70. package/_bmad/_config/workflow-manifest.csv +46 -0
  71. package/_bmad/_memory/config.yaml +11 -0
  72. package/_bmad/_memory/storyteller-sidecar/stories-told.md +7 -0
  73. package/_bmad/_memory/storyteller-sidecar/story-preferences.md +7 -0
  74. package/_bmad/_memory/tech-writer-sidecar/documentation-standards.md +224 -0
  75. package/_bmad/bmb/agents/byan.md +215 -0
  76. package/_bmad/bmb/agents/byan.optimized-v2.md +116 -0
  77. package/_bmad/bmb/agents/byan.optimized.md +189 -0
  78. package/_bmad/bmb/agents/drawio.md +359 -0
  79. package/_bmad/bmb/agents/marc.md +351 -0
  80. package/_bmad/bmb/agents/turbo-whisper-integration.md +312 -0
  81. package/_bmad/bmb/config.yaml +12 -0
  82. package/_bmad/bmb/module-help.csv +13 -0
  83. package/_bmad/bmb/workflows/agent/data/agent-compilation.md +273 -0
  84. package/_bmad/bmb/workflows/agent/data/agent-menu-patterns.md +233 -0
  85. package/_bmad/bmb/workflows/agent/data/agent-metadata.md +208 -0
  86. package/_bmad/bmb/workflows/agent/data/brainstorm-context.md +146 -0
  87. package/_bmad/bmb/workflows/agent/data/communication-presets.csv +61 -0
  88. package/_bmad/bmb/workflows/agent/data/critical-actions.md +120 -0
  89. package/_bmad/bmb/workflows/agent/data/expert-agent-architecture.md +236 -0
  90. package/_bmad/bmb/workflows/agent/data/expert-agent-validation.md +174 -0
  91. package/_bmad/bmb/workflows/agent/data/module-agent-validation.md +126 -0
  92. package/_bmad/bmb/workflows/agent/data/persona-properties.md +266 -0
  93. package/_bmad/bmb/workflows/agent/data/principles-crafting.md +292 -0
  94. package/_bmad/bmb/workflows/agent/data/reference/module-examples/architect.md +68 -0
  95. package/_bmad/bmb/workflows/agent/data/simple-agent-architecture.md +204 -0
  96. package/_bmad/bmb/workflows/agent/data/simple-agent-validation.md +133 -0
  97. package/_bmad/bmb/workflows/agent/data/understanding-agent-types.md +222 -0
  98. package/_bmad/bmb/workflows/agent/steps-c/step-01-brainstorm.md +128 -0
  99. package/_bmad/bmb/workflows/agent/steps-c/step-02-discovery.md +170 -0
  100. package/_bmad/bmb/workflows/agent/steps-c/step-03-type-metadata.md +296 -0
  101. package/_bmad/bmb/workflows/agent/steps-c/step-04-persona.md +212 -0
  102. package/_bmad/bmb/workflows/agent/steps-c/step-05-commands-menu.md +178 -0
  103. package/_bmad/bmb/workflows/agent/steps-c/step-06-activation.md +279 -0
  104. package/_bmad/bmb/workflows/agent/steps-c/step-07a-build-simple.md +187 -0
  105. package/_bmad/bmb/workflows/agent/steps-c/step-07b-build-expert.md +201 -0
  106. package/_bmad/bmb/workflows/agent/steps-c/step-07c-build-module.md +258 -0
  107. package/_bmad/bmb/workflows/agent/steps-c/step-08-celebrate.md +249 -0
  108. package/_bmad/bmb/workflows/agent/steps-e/e-01-load-existing.md +221 -0
  109. package/_bmad/bmb/workflows/agent/steps-e/e-02-discover-edits.md +193 -0
  110. package/_bmad/bmb/workflows/agent/steps-e/e-03-placeholder.md +1 -0
  111. package/_bmad/bmb/workflows/agent/steps-e/e-04-type-metadata.md +124 -0
  112. package/_bmad/bmb/workflows/agent/steps-e/e-05-persona.md +134 -0
  113. package/_bmad/bmb/workflows/agent/steps-e/e-06-commands-menu.md +122 -0
  114. package/_bmad/bmb/workflows/agent/steps-e/e-07-activation.md +125 -0
  115. package/_bmad/bmb/workflows/agent/steps-e/e-08a-edit-simple.md +137 -0
  116. package/_bmad/bmb/workflows/agent/steps-e/e-08b-edit-expert.md +119 -0
  117. package/_bmad/bmb/workflows/agent/steps-e/e-08c-edit-module.md +123 -0
  118. package/_bmad/bmb/workflows/agent/steps-e/e-09-celebrate.md +155 -0
  119. package/_bmad/bmb/workflows/agent/steps-v/v-01-load-review.md +136 -0
  120. package/_bmad/bmb/workflows/agent/steps-v/v-02a-validate-metadata.md +116 -0
  121. package/_bmad/bmb/workflows/agent/steps-v/v-02b-validate-persona.md +124 -0
  122. package/_bmad/bmb/workflows/agent/steps-v/v-02c-validate-menu.md +145 -0
  123. package/_bmad/bmb/workflows/agent/steps-v/v-02d-validate-structure.md +136 -0
  124. package/_bmad/bmb/workflows/agent/steps-v/v-02e-validate-sidecar.md +136 -0
  125. package/_bmad/bmb/workflows/agent/steps-v/v-03-summary.md +104 -0
  126. package/_bmad/bmb/workflows/agent/templates/agent-plan.template.md +5 -0
  127. package/_bmad/bmb/workflows/agent/templates/expert-agent-template/expert-agent.template.md +77 -0
  128. package/_bmad/bmb/workflows/agent/templates/simple-agent.template.md +72 -0
  129. package/_bmad/bmb/workflows/agent/workflow.md +123 -0
  130. package/_bmad/bmb/workflows/module/data/agent-architecture.md +179 -0
  131. package/_bmad/bmb/workflows/module/data/agent-spec-template.md +79 -0
  132. package/_bmad/bmb/workflows/module/data/module-installer-standards.md +348 -0
  133. package/_bmad/bmb/workflows/module/data/module-standards.md +280 -0
  134. package/_bmad/bmb/workflows/module/data/module-yaml-conventions.md +392 -0
  135. package/_bmad/bmb/workflows/module/steps-b/step-01-welcome.md +147 -0
  136. package/_bmad/bmb/workflows/module/steps-b/step-02-spark.md +140 -0
  137. package/_bmad/bmb/workflows/module/steps-b/step-03-module-type.md +148 -0
  138. package/_bmad/bmb/workflows/module/steps-b/step-04-vision.md +82 -0
  139. package/_bmad/bmb/workflows/module/steps-b/step-05-identity.md +96 -0
  140. package/_bmad/bmb/workflows/module/steps-b/step-06-users.md +85 -0
  141. package/_bmad/bmb/workflows/module/steps-b/step-07-value.md +75 -0
  142. package/_bmad/bmb/workflows/module/steps-b/step-08-agents.md +96 -0
  143. package/_bmad/bmb/workflows/module/steps-b/step-09-workflows.md +82 -0
  144. package/_bmad/bmb/workflows/module/steps-b/step-10-tools.md +90 -0
  145. package/_bmad/bmb/workflows/module/steps-b/step-11-scenarios.md +83 -0
  146. package/_bmad/bmb/workflows/module/steps-b/step-12-creative.md +94 -0
  147. package/_bmad/bmb/workflows/module/steps-b/step-13-review.md +104 -0
  148. package/_bmad/bmb/workflows/module/steps-b/step-14-finalize.md +117 -0
  149. package/_bmad/bmb/workflows/module/steps-c/step-01-load-brief.md +178 -0
  150. package/_bmad/bmb/workflows/module/steps-c/step-01b-continue.md +83 -0
  151. package/_bmad/bmb/workflows/module/steps-c/step-02-structure.md +109 -0
  152. package/_bmad/bmb/workflows/module/steps-c/step-03-config.md +118 -0
  153. package/_bmad/bmb/workflows/module/steps-c/step-04-installer.md +160 -0
  154. package/_bmad/bmb/workflows/module/steps-c/step-05-agents.md +167 -0
  155. package/_bmad/bmb/workflows/module/steps-c/step-06-workflows.md +183 -0
  156. package/_bmad/bmb/workflows/module/steps-c/step-07-docs.md +402 -0
  157. package/_bmad/bmb/workflows/module/steps-c/step-08-complete.md +123 -0
  158. package/_bmad/bmb/workflows/module/steps-e/step-01-load-target.md +81 -0
  159. package/_bmad/bmb/workflows/module/steps-e/step-02-select-edit.md +77 -0
  160. package/_bmad/bmb/workflows/module/steps-e/step-03-apply-edit.md +77 -0
  161. package/_bmad/bmb/workflows/module/steps-e/step-04-review.md +80 -0
  162. package/_bmad/bmb/workflows/module/steps-e/step-05-confirm.md +75 -0
  163. package/_bmad/bmb/workflows/module/steps-v/step-01-load-target.md +96 -0
  164. package/_bmad/bmb/workflows/module/steps-v/step-02-file-structure.md +94 -0
  165. package/_bmad/bmb/workflows/module/steps-v/step-03-module-yaml.md +99 -0
  166. package/_bmad/bmb/workflows/module/steps-v/step-04-agent-specs.md +152 -0
  167. package/_bmad/bmb/workflows/module/steps-v/step-05-workflow-specs.md +152 -0
  168. package/_bmad/bmb/workflows/module/steps-v/step-06-documentation.md +143 -0
  169. package/_bmad/bmb/workflows/module/steps-v/step-07-installation.md +113 -0
  170. package/_bmad/bmb/workflows/module/steps-v/step-08-report.md +197 -0
  171. package/_bmad/bmb/workflows/module/templates/brief-template.md +154 -0
  172. package/_bmad/bmb/workflows/module/templates/workflow-spec-template.md +96 -0
  173. package/_bmad/bmb/workflows/module/workflow.md +100 -0
  174. package/_bmad/bmb/workflows/turbo-whisper/configure-workflow.md +488 -0
  175. package/_bmad/bmb/workflows/turbo-whisper/docker-setup-workflow.md +478 -0
  176. package/_bmad/bmb/workflows/turbo-whisper/install-workflow.md +426 -0
  177. package/_bmad/bmb/workflows/turbo-whisper/integrate-workflow.md +510 -0
  178. package/_bmad/bmb/workflows/workflow/data/architecture.md +152 -0
  179. package/_bmad/bmb/workflows/workflow/data/common-workflow-tools.csv +19 -0
  180. package/_bmad/bmb/workflows/workflow/data/csv-data-file-standards.md +81 -0
  181. package/_bmad/bmb/workflows/workflow/data/frontmatter-standards.md +225 -0
  182. package/_bmad/bmb/workflows/workflow/data/input-discovery-standards.md +269 -0
  183. package/_bmad/bmb/workflows/workflow/data/intent-vs-prescriptive-spectrum.md +50 -0
  184. package/_bmad/bmb/workflows/workflow/data/menu-handling-standards.md +167 -0
  185. package/_bmad/bmb/workflows/workflow/data/output-format-standards.md +188 -0
  186. package/_bmad/bmb/workflows/workflow/data/step-file-rules.md +235 -0
  187. package/_bmad/bmb/workflows/workflow/data/step-type-patterns.md +311 -0
  188. package/_bmad/bmb/workflows/workflow/data/subprocess-optimization-patterns.md +386 -0
  189. package/_bmad/bmb/workflows/workflow/data/trimodal-workflow-structure.md +209 -0
  190. package/_bmad/bmb/workflows/workflow/data/workflow-chaining-standards.md +271 -0
  191. package/_bmad/bmb/workflows/workflow/data/workflow-examples.md +276 -0
  192. package/_bmad/bmb/workflows/workflow/data/workflow-type-criteria.md +172 -0
  193. package/_bmad/bmb/workflows/workflow/steps-c/step-00-conversion.md +262 -0
  194. package/_bmad/bmb/workflows/workflow/steps-c/step-01-discovery.md +194 -0
  195. package/_bmad/bmb/workflows/workflow/steps-c/step-01b-continuation.md +3 -0
  196. package/_bmad/bmb/workflows/workflow/steps-c/step-02-classification.md +269 -0
  197. package/_bmad/bmb/workflows/workflow/steps-c/step-03-requirements.md +282 -0
  198. package/_bmad/bmb/workflows/workflow/steps-c/step-04-tools.md +281 -0
  199. package/_bmad/bmb/workflows/workflow/steps-c/step-05-plan-review.md +242 -0
  200. package/_bmad/bmb/workflows/workflow/steps-c/step-06-design.md +329 -0
  201. package/_bmad/bmb/workflows/workflow/steps-c/step-07-foundation.md +238 -0
  202. package/_bmad/bmb/workflows/workflow/steps-c/step-08-build-step-01.md +377 -0
  203. package/_bmad/bmb/workflows/workflow/steps-c/step-09-build-next-step.md +350 -0
  204. package/_bmad/bmb/workflows/workflow/steps-c/step-10-confirmation.md +320 -0
  205. package/_bmad/bmb/workflows/workflow/steps-c/step-11-completion.md +191 -0
  206. package/_bmad/bmb/workflows/workflow/steps-e/step-e-01-assess-workflow.md +237 -0
  207. package/_bmad/bmb/workflows/workflow/steps-e/step-e-02-discover-edits.md +248 -0
  208. package/_bmad/bmb/workflows/workflow/steps-e/step-e-03-fix-validation.md +252 -0
  209. package/_bmad/bmb/workflows/workflow/steps-e/step-e-04-direct-edit.md +275 -0
  210. package/_bmad/bmb/workflows/workflow/steps-e/step-e-05-apply-edit.md +154 -0
  211. package/_bmad/bmb/workflows/workflow/steps-e/step-e-06-validate-after.md +190 -0
  212. package/_bmad/bmb/workflows/workflow/steps-e/step-e-07-complete.md +206 -0
  213. package/_bmad/bmb/workflows/workflow/steps-v/step-01-validate-max-mode.md +109 -0
  214. package/_bmad/bmb/workflows/workflow/steps-v/step-01-validate.md +221 -0
  215. package/_bmad/bmb/workflows/workflow/steps-v/step-01b-structure.md +152 -0
  216. package/_bmad/bmb/workflows/workflow/steps-v/step-02-frontmatter-validation.md +199 -0
  217. package/_bmad/bmb/workflows/workflow/steps-v/step-02b-path-violations.md +265 -0
  218. package/_bmad/bmb/workflows/workflow/steps-v/step-03-menu-validation.md +164 -0
  219. package/_bmad/bmb/workflows/workflow/steps-v/step-04-step-type-validation.md +211 -0
  220. package/_bmad/bmb/workflows/workflow/steps-v/step-05-output-format-validation.md +200 -0
  221. package/_bmad/bmb/workflows/workflow/steps-v/step-06-validation-design-check.md +195 -0
  222. package/_bmad/bmb/workflows/workflow/steps-v/step-07-instruction-style-check.md +209 -0
  223. package/_bmad/bmb/workflows/workflow/steps-v/step-08-collaborative-experience-check.md +199 -0
  224. package/_bmad/bmb/workflows/workflow/steps-v/step-08b-subprocess-optimization.md +179 -0
  225. package/_bmad/bmb/workflows/workflow/steps-v/step-09-cohesive-review.md +186 -0
  226. package/_bmad/bmb/workflows/workflow/steps-v/step-10-report-complete.md +154 -0
  227. package/_bmad/bmb/workflows/workflow/steps-v/step-11-plan-validation.md +237 -0
  228. package/_bmad/bmb/workflows/workflow/templates/minimal-output-template.md +11 -0
  229. package/_bmad/bmb/workflows/workflow/templates/step-01-init-continuable-template.md +241 -0
  230. package/_bmad/bmb/workflows/workflow/templates/step-1b-template.md +223 -0
  231. package/_bmad/bmb/workflows/workflow/templates/step-template.md +290 -0
  232. package/_bmad/bmb/workflows/workflow/templates/workflow-template.md +102 -0
  233. package/_bmad/bmb/workflows/workflow/workflow.md +109 -0
  234. package/_bmad/bmm/agents/analyst.md +76 -0
  235. package/_bmad/bmm/agents/architect.md +58 -0
  236. package/_bmad/bmm/agents/dev.md +69 -0
  237. package/_bmad/bmm/agents/expert-merise-agile.md +177 -0
  238. package/_bmad/bmm/agents/pm.md +72 -0
  239. package/_bmad/bmm/agents/quick-flow-solo-dev.md +69 -0
  240. package/_bmad/bmm/agents/quinn.md +92 -0
  241. package/_bmad/bmm/agents/sm.md +70 -0
  242. package/_bmad/bmm/agents/tech-writer/tech-writer.md +70 -0
  243. package/_bmad/bmm/agents/ux-designer.md +57 -0
  244. package/_bmad/bmm/config.yaml +16 -0
  245. package/_bmad/bmm/data/project-context-template.md +26 -0
  246. package/_bmad/bmm/module-help.csv +38 -0
  247. package/_bmad/bmm/teams/default-party.csv +20 -0
  248. package/_bmad/bmm/teams/team-fullstack.yaml +12 -0
  249. package/_bmad/bmm/workflows/1-analysis/create-product-brief/product-brief.template.md +10 -0
  250. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-01-init.md +177 -0
  251. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-01b-continue.md +161 -0
  252. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-02-vision.md +199 -0
  253. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-03-users.md +202 -0
  254. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-04-metrics.md +205 -0
  255. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-05-scope.md +219 -0
  256. package/_bmad/bmm/workflows/1-analysis/create-product-brief/steps/step-06-complete.md +162 -0
  257. package/_bmad/bmm/workflows/1-analysis/create-product-brief/workflow.md +58 -0
  258. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-01-init.md +137 -0
  259. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-02-domain-analysis.md +229 -0
  260. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-03-competitive-landscape.md +238 -0
  261. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-04-regulatory-focus.md +206 -0
  262. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-05-technical-trends.md +234 -0
  263. package/_bmad/bmm/workflows/1-analysis/research/domain-steps/step-06-research-synthesis.md +443 -0
  264. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-01-init.md +182 -0
  265. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-02-customer-behavior.md +237 -0
  266. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-03-customer-pain-points.md +249 -0
  267. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-04-customer-decisions.md +259 -0
  268. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-05-competitive-analysis.md +177 -0
  269. package/_bmad/bmm/workflows/1-analysis/research/market-steps/step-06-research-completion.md +475 -0
  270. package/_bmad/bmm/workflows/1-analysis/research/research.template.md +29 -0
  271. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-01-init.md +137 -0
  272. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-02-technical-overview.md +239 -0
  273. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-03-integration-patterns.md +248 -0
  274. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-04-architectural-patterns.md +202 -0
  275. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-05-implementation-research.md +239 -0
  276. package/_bmad/bmm/workflows/1-analysis/research/technical-steps/step-06-research-synthesis.md +486 -0
  277. package/_bmad/bmm/workflows/1-analysis/research/workflow.md +173 -0
  278. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/domain-complexity.csv +13 -0
  279. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/prd-purpose.md +197 -0
  280. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/data/project-types.csv +11 -0
  281. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01-init.md +191 -0
  282. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-01b-continue.md +153 -0
  283. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-02-discovery.md +224 -0
  284. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-03-success.md +226 -0
  285. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-04-journeys.md +213 -0
  286. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-05-domain.md +207 -0
  287. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-06-innovation.md +226 -0
  288. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-07-project-type.md +237 -0
  289. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-08-scoping.md +228 -0
  290. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-09-functional.md +231 -0
  291. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-10-nonfunctional.md +242 -0
  292. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-11-polish.md +217 -0
  293. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-c/step-12-complete.md +124 -0
  294. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01-discovery.md +247 -0
  295. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-01b-legacy-conversion.md +208 -0
  296. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-02-review.md +249 -0
  297. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-03-edit.md +253 -0
  298. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-e/step-e-04-complete.md +168 -0
  299. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-01-discovery.md +218 -0
  300. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02-format-detection.md +191 -0
  301. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-02b-parity-check.md +209 -0
  302. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-03-density-validation.md +174 -0
  303. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-04-brief-coverage-validation.md +214 -0
  304. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-05-measurability-validation.md +228 -0
  305. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-06-traceability-validation.md +217 -0
  306. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-07-implementation-leakage-validation.md +205 -0
  307. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-08-domain-compliance-validation.md +243 -0
  308. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-09-project-type-validation.md +263 -0
  309. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-10-smart-validation.md +209 -0
  310. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-11-holistic-quality-validation.md +264 -0
  311. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-12-completeness-validation.md +242 -0
  312. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/steps-v/step-v-13-report-complete.md +231 -0
  313. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/templates/prd-template.md +10 -0
  314. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/validation-report-prd-workflow.md +433 -0
  315. package/_bmad/bmm/workflows/2-plan-workflows/create-prd/workflow.md +150 -0
  316. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01-init.md +135 -0
  317. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-01b-continue.md +127 -0
  318. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-02-discovery.md +190 -0
  319. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-03-core-experience.md +216 -0
  320. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-04-emotional-response.md +219 -0
  321. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-05-inspiration.md +234 -0
  322. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-06-design-system.md +252 -0
  323. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-07-defining-experience.md +254 -0
  324. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-08-visual-foundation.md +224 -0
  325. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-09-design-directions.md +224 -0
  326. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-10-user-journeys.md +241 -0
  327. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-11-component-strategy.md +248 -0
  328. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-12-ux-patterns.md +237 -0
  329. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-13-responsive-accessibility.md +264 -0
  330. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/steps/step-14-complete.md +171 -0
  331. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/ux-design-template.md +13 -0
  332. package/_bmad/bmm/workflows/2-plan-workflows/create-ux-design/workflow.md +43 -0
  333. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-01-document-discovery.md +190 -0
  334. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-02-prd-analysis.md +178 -0
  335. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-03-epic-coverage-validation.md +179 -0
  336. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-04-ux-alignment.md +139 -0
  337. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-05-epic-quality-review.md +252 -0
  338. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/steps/step-06-final-assessment.md +135 -0
  339. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/templates/readiness-report-template.md +4 -0
  340. package/_bmad/bmm/workflows/3-solutioning/check-implementation-readiness/workflow.md +55 -0
  341. package/_bmad/bmm/workflows/3-solutioning/create-architecture/architecture-decision-template.md +12 -0
  342. package/_bmad/bmm/workflows/3-solutioning/create-architecture/data/domain-complexity.csv +11 -0
  343. package/_bmad/bmm/workflows/3-solutioning/create-architecture/data/project-types.csv +7 -0
  344. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-01-init.md +153 -0
  345. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-01b-continue.md +164 -0
  346. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-02-context.md +224 -0
  347. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-03-starter.md +331 -0
  348. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-04-decisions.md +318 -0
  349. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-05-patterns.md +359 -0
  350. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-06-structure.md +379 -0
  351. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-07-validation.md +359 -0
  352. package/_bmad/bmm/workflows/3-solutioning/create-architecture/steps/step-08-complete.md +76 -0
  353. package/_bmad/bmm/workflows/3-solutioning/create-architecture/workflow.md +50 -0
  354. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-01-validate-prerequisites.md +259 -0
  355. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-02-design-epics.md +233 -0
  356. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-03-create-stories.md +272 -0
  357. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/steps/step-04-final-validation.md +149 -0
  358. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/templates/epics-template.md +57 -0
  359. package/_bmad/bmm/workflows/3-solutioning/create-epics-and-stories/workflow.md +59 -0
  360. package/_bmad/bmm/workflows/4-implementation/code-review/checklist.md +23 -0
  361. package/_bmad/bmm/workflows/4-implementation/code-review/instructions.xml +227 -0
  362. package/_bmad/bmm/workflows/4-implementation/code-review/workflow.yaml +50 -0
  363. package/_bmad/bmm/workflows/4-implementation/correct-course/checklist.md +288 -0
  364. package/_bmad/bmm/workflows/4-implementation/correct-course/instructions.md +206 -0
  365. package/_bmad/bmm/workflows/4-implementation/correct-course/workflow.yaml +58 -0
  366. package/_bmad/bmm/workflows/4-implementation/create-story/checklist.md +358 -0
  367. package/_bmad/bmm/workflows/4-implementation/create-story/instructions.xml +345 -0
  368. package/_bmad/bmm/workflows/4-implementation/create-story/template.md +49 -0
  369. package/_bmad/bmm/workflows/4-implementation/create-story/workflow.yaml +59 -0
  370. package/_bmad/bmm/workflows/4-implementation/dev-story/checklist.md +80 -0
  371. package/_bmad/bmm/workflows/4-implementation/dev-story/instructions.xml +410 -0
  372. package/_bmad/bmm/workflows/4-implementation/dev-story/workflow.yaml +25 -0
  373. package/_bmad/bmm/workflows/4-implementation/retrospective/instructions.md +1443 -0
  374. package/_bmad/bmm/workflows/4-implementation/retrospective/workflow.yaml +57 -0
  375. package/_bmad/bmm/workflows/4-implementation/sprint-planning/checklist.md +33 -0
  376. package/_bmad/bmm/workflows/4-implementation/sprint-planning/instructions.md +225 -0
  377. package/_bmad/bmm/workflows/4-implementation/sprint-planning/sprint-status-template.yaml +55 -0
  378. package/_bmad/bmm/workflows/4-implementation/sprint-planning/workflow.yaml +53 -0
  379. package/_bmad/bmm/workflows/4-implementation/sprint-status/instructions.md +229 -0
  380. package/_bmad/bmm/workflows/4-implementation/sprint-status/workflow.yaml +35 -0
  381. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-01-mode-detection.md +176 -0
  382. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-02-context-gathering.md +120 -0
  383. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-03-execute.md +113 -0
  384. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-04-self-check.md +113 -0
  385. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-05-adversarial-review.md +106 -0
  386. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/steps/step-06-resolve-findings.md +149 -0
  387. package/_bmad/bmm/workflows/bmad-quick-flow/quick-dev/workflow.md +50 -0
  388. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-01-understand.md +192 -0
  389. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-02-investigate.md +145 -0
  390. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-03-generate.md +128 -0
  391. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/steps/step-04-review.md +201 -0
  392. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/tech-spec-template.md +74 -0
  393. package/_bmad/bmm/workflows/bmad-quick-flow/quick-spec/workflow.md +79 -0
  394. package/_bmad/bmm/workflows/document-project/checklist.md +245 -0
  395. package/_bmad/bmm/workflows/document-project/documentation-requirements.csv +12 -0
  396. package/_bmad/bmm/workflows/document-project/instructions.md +221 -0
  397. package/_bmad/bmm/workflows/document-project/templates/deep-dive-template.md +345 -0
  398. package/_bmad/bmm/workflows/document-project/templates/index-template.md +169 -0
  399. package/_bmad/bmm/workflows/document-project/templates/project-overview-template.md +103 -0
  400. package/_bmad/bmm/workflows/document-project/templates/project-scan-report-schema.json +160 -0
  401. package/_bmad/bmm/workflows/document-project/templates/source-tree-template.md +135 -0
  402. package/_bmad/bmm/workflows/document-project/workflow.yaml +28 -0
  403. package/_bmad/bmm/workflows/document-project/workflows/deep-dive-instructions.md +298 -0
  404. package/_bmad/bmm/workflows/document-project/workflows/deep-dive.yaml +31 -0
  405. package/_bmad/bmm/workflows/document-project/workflows/full-scan-instructions.md +1106 -0
  406. package/_bmad/bmm/workflows/document-project/workflows/full-scan.yaml +31 -0
  407. package/_bmad/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-library.json +90 -0
  408. package/_bmad/bmm/workflows/excalidraw-diagrams/_shared/excalidraw-templates.yaml +127 -0
  409. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/checklist.md +39 -0
  410. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/instructions.md +130 -0
  411. package/_bmad/bmm/workflows/excalidraw-diagrams/create-dataflow/workflow.yaml +26 -0
  412. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/checklist.md +43 -0
  413. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/instructions.md +141 -0
  414. package/_bmad/bmm/workflows/excalidraw-diagrams/create-diagram/workflow.yaml +26 -0
  415. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/checklist.md +49 -0
  416. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/instructions.md +241 -0
  417. package/_bmad/bmm/workflows/excalidraw-diagrams/create-flowchart/workflow.yaml +26 -0
  418. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/checklist.md +38 -0
  419. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/instructions.md +133 -0
  420. package/_bmad/bmm/workflows/excalidraw-diagrams/create-wireframe/workflow.yaml +26 -0
  421. package/_bmad/bmm/workflows/generate-project-context/project-context-template.md +21 -0
  422. package/_bmad/bmm/workflows/generate-project-context/steps/step-01-discover.md +184 -0
  423. package/_bmad/bmm/workflows/generate-project-context/steps/step-02-generate.md +318 -0
  424. package/_bmad/bmm/workflows/generate-project-context/steps/step-03-complete.md +278 -0
  425. package/_bmad/bmm/workflows/generate-project-context/workflow.md +49 -0
  426. package/_bmad/bmm/workflows/qa/automate/checklist.md +33 -0
  427. package/_bmad/bmm/workflows/qa/automate/instructions.md +110 -0
  428. package/_bmad/bmm/workflows/qa/automate/workflow.yaml +47 -0
  429. package/_bmad/cis/agents/brainstorming-coach.md +61 -0
  430. package/_bmad/cis/agents/creative-problem-solver.md +61 -0
  431. package/_bmad/cis/agents/design-thinking-coach.md +61 -0
  432. package/_bmad/cis/agents/innovation-strategist.md +61 -0
  433. package/_bmad/cis/agents/presentation-master.md +67 -0
  434. package/_bmad/cis/agents/storyteller/storyteller.md +58 -0
  435. package/_bmad/cis/config.yaml +12 -0
  436. package/_bmad/cis/module-help.csv +6 -0
  437. package/_bmad/cis/teams/creative-squad.yaml +7 -0
  438. package/_bmad/cis/teams/default-party.csv +12 -0
  439. package/_bmad/cis/workflows/README.md +139 -0
  440. package/_bmad/cis/workflows/design-thinking/README.md +56 -0
  441. package/_bmad/cis/workflows/design-thinking/design-methods.csv +31 -0
  442. package/_bmad/cis/workflows/design-thinking/instructions.md +202 -0
  443. package/_bmad/cis/workflows/design-thinking/template.md +111 -0
  444. package/_bmad/cis/workflows/design-thinking/workflow.yaml +27 -0
  445. package/_bmad/cis/workflows/innovation-strategy/README.md +56 -0
  446. package/_bmad/cis/workflows/innovation-strategy/innovation-frameworks.csv +31 -0
  447. package/_bmad/cis/workflows/innovation-strategy/instructions.md +276 -0
  448. package/_bmad/cis/workflows/innovation-strategy/template.md +189 -0
  449. package/_bmad/cis/workflows/innovation-strategy/workflow.yaml +27 -0
  450. package/_bmad/cis/workflows/problem-solving/README.md +56 -0
  451. package/_bmad/cis/workflows/problem-solving/instructions.md +252 -0
  452. package/_bmad/cis/workflows/problem-solving/solving-methods.csv +31 -0
  453. package/_bmad/cis/workflows/problem-solving/template.md +165 -0
  454. package/_bmad/cis/workflows/problem-solving/workflow.yaml +27 -0
  455. package/_bmad/cis/workflows/storytelling/README.md +58 -0
  456. package/_bmad/cis/workflows/storytelling/instructions.md +293 -0
  457. package/_bmad/cis/workflows/storytelling/story-types.csv +26 -0
  458. package/_bmad/cis/workflows/storytelling/template.md +113 -0
  459. package/_bmad/cis/workflows/storytelling/workflow.yaml +27 -0
  460. package/_bmad/core/agents/bmad-master.md +56 -0
  461. package/_bmad/core/agents/test-dynamic.md +40 -0
  462. package/_bmad/core/base/bmad-base-agent.md +42 -0
  463. package/_bmad/core/config.yaml +9 -0
  464. package/_bmad/core/module-help.csv +9 -0
  465. package/_bmad/core/resources/excalidraw/README.md +160 -0
  466. package/_bmad/core/resources/excalidraw/excalidraw-helpers.md +127 -0
  467. package/_bmad/core/resources/excalidraw/library-loader.md +50 -0
  468. package/_bmad/core/resources/excalidraw/validate-json-instructions.md +79 -0
  469. package/_bmad/core/tasks/editorial-review-prose.xml +100 -0
  470. package/_bmad/core/tasks/editorial-review-structure.xml +209 -0
  471. package/_bmad/core/tasks/help.md +62 -0
  472. package/_bmad/core/tasks/index-docs.xml +65 -0
  473. package/_bmad/core/tasks/review-adversarial-general.xml +48 -0
  474. package/_bmad/core/tasks/shard-doc.xml +109 -0
  475. package/_bmad/core/tasks/workflow.xml +235 -0
  476. package/_bmad/core/workflows/advanced-elicitation/methods.csv +51 -0
  477. package/_bmad/core/workflows/advanced-elicitation/workflow.xml +117 -0
  478. package/_bmad/core/workflows/brainstorming/brain-methods.csv +62 -0
  479. package/_bmad/core/workflows/brainstorming/steps/step-01-session-setup.md +197 -0
  480. package/_bmad/core/workflows/brainstorming/steps/step-01b-continue.md +122 -0
  481. package/_bmad/core/workflows/brainstorming/steps/step-02a-user-selected.md +225 -0
  482. package/_bmad/core/workflows/brainstorming/steps/step-02b-ai-recommended.md +237 -0
  483. package/_bmad/core/workflows/brainstorming/steps/step-02c-random-selection.md +209 -0
  484. package/_bmad/core/workflows/brainstorming/steps/step-02d-progressive-flow.md +264 -0
  485. package/_bmad/core/workflows/brainstorming/steps/step-03-technique-execution.md +399 -0
  486. package/_bmad/core/workflows/brainstorming/steps/step-04-idea-organization.md +303 -0
  487. package/_bmad/core/workflows/brainstorming/template.md +15 -0
  488. package/_bmad/core/workflows/brainstorming/workflow.md +58 -0
  489. package/_bmad/core/workflows/party-mode/steps/step-01-agent-loading.md +138 -0
  490. package/_bmad/core/workflows/party-mode/steps/step-02-discussion-orchestration.md +187 -0
  491. package/_bmad/core/workflows/party-mode/steps/step-03-graceful-exit.md +157 -0
  492. package/_bmad/core/workflows/party-mode/workflow.md +194 -0
  493. package/_bmad/tea/agents/tea.md +71 -0
  494. package/_bmad/tea/config.yaml +19 -0
  495. package/_bmad/tea/module-help.csv +10 -0
  496. package/_bmad/tea/teams/default-party.csv +2 -0
  497. package/_bmad/tea/testarch/knowledge/adr-quality-readiness-checklist.md +377 -0
  498. package/_bmad/tea/testarch/knowledge/api-request.md +442 -0
  499. package/_bmad/tea/testarch/knowledge/api-testing-patterns.md +851 -0
  500. package/_bmad/tea/testarch/knowledge/auth-session.md +548 -0
  501. package/_bmad/tea/testarch/knowledge/burn-in.md +273 -0
  502. package/_bmad/tea/testarch/knowledge/ci-burn-in.md +675 -0
  503. package/_bmad/tea/testarch/knowledge/component-tdd.md +486 -0
  504. package/_bmad/tea/testarch/knowledge/contract-testing.md +957 -0
  505. package/_bmad/tea/testarch/knowledge/data-factories.md +500 -0
  506. package/_bmad/tea/testarch/knowledge/email-auth.md +721 -0
  507. package/_bmad/tea/testarch/knowledge/error-handling.md +725 -0
  508. package/_bmad/tea/testarch/knowledge/feature-flags.md +750 -0
  509. package/_bmad/tea/testarch/knowledge/file-utils.md +456 -0
  510. package/_bmad/tea/testarch/knowledge/fixture-architecture.md +401 -0
  511. package/_bmad/tea/testarch/knowledge/fixtures-composition.md +382 -0
  512. package/_bmad/tea/testarch/knowledge/intercept-network-call.md +426 -0
  513. package/_bmad/tea/testarch/knowledge/log.md +426 -0
  514. package/_bmad/tea/testarch/knowledge/network-error-monitor.md +401 -0
  515. package/_bmad/tea/testarch/knowledge/network-first.md +486 -0
  516. package/_bmad/tea/testarch/knowledge/network-recorder.md +527 -0
  517. package/_bmad/tea/testarch/knowledge/nfr-criteria.md +670 -0
  518. package/_bmad/tea/testarch/knowledge/overview.md +286 -0
  519. package/_bmad/tea/testarch/knowledge/playwright-config.md +730 -0
  520. package/_bmad/tea/testarch/knowledge/probability-impact.md +601 -0
  521. package/_bmad/tea/testarch/knowledge/recurse.md +421 -0
  522. package/_bmad/tea/testarch/knowledge/risk-governance.md +615 -0
  523. package/_bmad/tea/testarch/knowledge/selective-testing.md +732 -0
  524. package/_bmad/tea/testarch/knowledge/selector-resilience.md +527 -0
  525. package/_bmad/tea/testarch/knowledge/test-healing-patterns.md +644 -0
  526. package/_bmad/tea/testarch/knowledge/test-levels-framework.md +473 -0
  527. package/_bmad/tea/testarch/knowledge/test-priorities-matrix.md +373 -0
  528. package/_bmad/tea/testarch/knowledge/test-quality.md +664 -0
  529. package/_bmad/tea/testarch/knowledge/timing-debugging.md +372 -0
  530. package/_bmad/tea/testarch/knowledge/visual-debugging.md +524 -0
  531. package/_bmad/tea/testarch/tea-index.csv +35 -0
  532. package/_bmad/tea/workflows/testarch/README.md +74 -0
  533. package/_bmad/tea/workflows/testarch/atdd/atdd-checklist-template.md +363 -0
  534. package/_bmad/tea/workflows/testarch/atdd/checklist.md +374 -0
  535. package/_bmad/tea/workflows/testarch/atdd/instructions.md +38 -0
  536. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-01-preflight-and-context.md +110 -0
  537. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-02-generation-mode.md +79 -0
  538. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-03-test-strategy.md +76 -0
  539. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04-generate-tests.md +228 -0
  540. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04a-subprocess-api-failing.md +215 -0
  541. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04b-subprocess-e2e-failing.md +212 -0
  542. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-04c-aggregate.md +329 -0
  543. package/_bmad/tea/workflows/testarch/atdd/steps-c/step-05-validate-and-complete.md +68 -0
  544. package/_bmad/tea/workflows/testarch/atdd/steps-e/step-01-assess.md +65 -0
  545. package/_bmad/tea/workflows/testarch/atdd/steps-e/step-02-apply-edit.md +60 -0
  546. package/_bmad/tea/workflows/testarch/atdd/steps-v/step-01-validate.md +67 -0
  547. package/_bmad/tea/workflows/testarch/atdd/validation-report-20260127-095021.md +73 -0
  548. package/_bmad/tea/workflows/testarch/atdd/validation-report-20260127-102401.md +116 -0
  549. package/_bmad/tea/workflows/testarch/atdd/workflow-plan.md +21 -0
  550. package/_bmad/tea/workflows/testarch/atdd/workflow.md +39 -0
  551. package/_bmad/tea/workflows/testarch/atdd/workflow.yaml +45 -0
  552. package/_bmad/tea/workflows/testarch/automate/checklist.md +582 -0
  553. package/_bmad/tea/workflows/testarch/automate/instructions.md +43 -0
  554. package/_bmad/tea/workflows/testarch/automate/steps-c/step-01-preflight-and-context.md +127 -0
  555. package/_bmad/tea/workflows/testarch/automate/steps-c/step-02-identify-targets.md +95 -0
  556. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03-generate-tests.md +199 -0
  557. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03a-subprocess-api.md +183 -0
  558. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03b-subprocess-e2e.md +181 -0
  559. package/_bmad/tea/workflows/testarch/automate/steps-c/step-03c-aggregate.md +300 -0
  560. package/_bmad/tea/workflows/testarch/automate/steps-c/step-04-validate-and-summarize.md +69 -0
  561. package/_bmad/tea/workflows/testarch/automate/steps-e/step-01-assess.md +65 -0
  562. package/_bmad/tea/workflows/testarch/automate/steps-e/step-02-apply-edit.md +60 -0
  563. package/_bmad/tea/workflows/testarch/automate/steps-v/step-01-validate.md +67 -0
  564. package/_bmad/tea/workflows/testarch/automate/validation-report-20260127-095021.md +72 -0
  565. package/_bmad/tea/workflows/testarch/automate/validation-report-20260127-102401.md +114 -0
  566. package/_bmad/tea/workflows/testarch/automate/workflow-plan.md +20 -0
  567. package/_bmad/tea/workflows/testarch/automate/workflow.md +39 -0
  568. package/_bmad/tea/workflows/testarch/automate/workflow.yaml +52 -0
  569. package/_bmad/tea/workflows/testarch/ci/checklist.md +247 -0
  570. package/_bmad/tea/workflows/testarch/ci/github-actions-template.yaml +198 -0
  571. package/_bmad/tea/workflows/testarch/ci/gitlab-ci-template.yaml +149 -0
  572. package/_bmad/tea/workflows/testarch/ci/instructions.md +38 -0
  573. package/_bmad/tea/workflows/testarch/ci/steps-c/step-01-preflight.md +92 -0
  574. package/_bmad/tea/workflows/testarch/ci/steps-c/step-02-generate-pipeline.md +82 -0
  575. package/_bmad/tea/workflows/testarch/ci/steps-c/step-03-configure-quality-gates.md +75 -0
  576. package/_bmad/tea/workflows/testarch/ci/steps-c/step-04-validate-and-summary.md +67 -0
  577. package/_bmad/tea/workflows/testarch/ci/steps-e/step-01-assess.md +65 -0
  578. package/_bmad/tea/workflows/testarch/ci/steps-e/step-02-apply-edit.md +60 -0
  579. package/_bmad/tea/workflows/testarch/ci/steps-v/step-01-validate.md +67 -0
  580. package/_bmad/tea/workflows/testarch/ci/validation-report-20260127-095021.md +72 -0
  581. package/_bmad/tea/workflows/testarch/ci/validation-report-20260127-102401.md +114 -0
  582. package/_bmad/tea/workflows/testarch/ci/workflow-plan.md +20 -0
  583. package/_bmad/tea/workflows/testarch/ci/workflow.md +39 -0
  584. package/_bmad/tea/workflows/testarch/ci/workflow.yaml +45 -0
  585. package/_bmad/tea/workflows/testarch/framework/checklist.md +320 -0
  586. package/_bmad/tea/workflows/testarch/framework/instructions.md +38 -0
  587. package/_bmad/tea/workflows/testarch/framework/steps-c/step-01-preflight.md +75 -0
  588. package/_bmad/tea/workflows/testarch/framework/steps-c/step-02-select-framework.md +73 -0
  589. package/_bmad/tea/workflows/testarch/framework/steps-c/step-03-scaffold-framework.md +120 -0
  590. package/_bmad/tea/workflows/testarch/framework/steps-c/step-04-docs-and-scripts.md +70 -0
  591. package/_bmad/tea/workflows/testarch/framework/steps-c/step-05-validate-and-summary.md +68 -0
  592. package/_bmad/tea/workflows/testarch/framework/steps-e/step-01-assess.md +65 -0
  593. package/_bmad/tea/workflows/testarch/framework/steps-e/step-02-apply-edit.md +60 -0
  594. package/_bmad/tea/workflows/testarch/framework/steps-v/step-01-validate.md +67 -0
  595. package/_bmad/tea/workflows/testarch/framework/validation-report-20260127-095021.md +73 -0
  596. package/_bmad/tea/workflows/testarch/framework/validation-report-20260127-102401.md +116 -0
  597. package/_bmad/tea/workflows/testarch/framework/workflow-plan.md +22 -0
  598. package/_bmad/tea/workflows/testarch/framework/workflow.md +39 -0
  599. package/_bmad/tea/workflows/testarch/framework/workflow.yaml +47 -0
  600. package/_bmad/tea/workflows/testarch/nfr-assess/checklist.md +407 -0
  601. package/_bmad/tea/workflows/testarch/nfr-assess/instructions.md +36 -0
  602. package/_bmad/tea/workflows/testarch/nfr-assess/nfr-report-template.md +462 -0
  603. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-01-load-context.md +85 -0
  604. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-02-define-thresholds.md +82 -0
  605. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-03-gather-evidence.md +64 -0
  606. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04-evaluate-and-score.md +140 -0
  607. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04a-subprocess-security.md +138 -0
  608. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04b-subprocess-performance.md +84 -0
  609. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04c-subprocess-reliability.md +85 -0
  610. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04d-subprocess-scalability.md +88 -0
  611. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-04e-aggregate-nfr.md +219 -0
  612. package/_bmad/tea/workflows/testarch/nfr-assess/steps-c/step-05-generate-report.md +71 -0
  613. package/_bmad/tea/workflows/testarch/nfr-assess/steps-e/step-01-assess.md +65 -0
  614. package/_bmad/tea/workflows/testarch/nfr-assess/steps-e/step-02-apply-edit.md +60 -0
  615. package/_bmad/tea/workflows/testarch/nfr-assess/steps-v/step-01-validate.md +67 -0
  616. package/_bmad/tea/workflows/testarch/nfr-assess/validation-report-20260127-095021.md +73 -0
  617. package/_bmad/tea/workflows/testarch/nfr-assess/validation-report-20260127-102401.md +116 -0
  618. package/_bmad/tea/workflows/testarch/nfr-assess/workflow-plan.md +19 -0
  619. package/_bmad/tea/workflows/testarch/nfr-assess/workflow.md +39 -0
  620. package/_bmad/tea/workflows/testarch/nfr-assess/workflow.yaml +47 -0
  621. package/_bmad/tea/workflows/testarch/teach-me-testing/checklist.md +197 -0
  622. package/_bmad/tea/workflows/testarch/teach-me-testing/data/curriculum.yaml +129 -0
  623. package/_bmad/tea/workflows/testarch/teach-me-testing/data/quiz-questions.yaml +206 -0
  624. package/_bmad/tea/workflows/testarch/teach-me-testing/data/role-paths.yaml +136 -0
  625. package/_bmad/tea/workflows/testarch/teach-me-testing/data/session-content-map.yaml +204 -0
  626. package/_bmad/tea/workflows/testarch/teach-me-testing/data/tea-resources-index.yaml +359 -0
  627. package/_bmad/tea/workflows/testarch/teach-me-testing/instructions.md +130 -0
  628. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-01-init.md +235 -0
  629. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-01b-continue.md +147 -0
  630. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-02-assess.md +258 -0
  631. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-03-session-menu.md +219 -0
  632. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-01.md +460 -0
  633. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-02.md +465 -0
  634. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-03.md +301 -0
  635. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-04.md +234 -0
  636. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-05.md +234 -0
  637. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-06.md +209 -0
  638. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-04-session-07.md +212 -0
  639. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-c/step-05-completion.md +339 -0
  640. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-e/step-e-01-assess-workflow.md +141 -0
  641. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-e/step-e-02-apply-edits.md +122 -0
  642. package/_bmad/tea/workflows/testarch/teach-me-testing/steps-v/step-v-01-validate.md +263 -0
  643. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/certificate-template.md +86 -0
  644. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/progress-template.yaml +95 -0
  645. package/_bmad/tea/workflows/testarch/teach-me-testing/templates/session-notes-template.md +83 -0
  646. package/_bmad/tea/workflows/testarch/teach-me-testing/workflow-plan-teach-me-testing.md +950 -0
  647. package/_bmad/tea/workflows/testarch/teach-me-testing/workflow.md +90 -0
  648. package/_bmad/tea/workflows/testarch/test-design/checklist.md +410 -0
  649. package/_bmad/tea/workflows/testarch/test-design/instructions.md +52 -0
  650. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-01-detect-mode.md +109 -0
  651. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-02-load-context.md +127 -0
  652. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-03-risk-and-testability.md +85 -0
  653. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-04-coverage-plan.md +98 -0
  654. package/_bmad/tea/workflows/testarch/test-design/steps-c/step-05-generate-output.md +97 -0
  655. package/_bmad/tea/workflows/testarch/test-design/steps-e/step-01-assess.md +65 -0
  656. package/_bmad/tea/workflows/testarch/test-design/steps-e/step-02-apply-edit.md +60 -0
  657. package/_bmad/tea/workflows/testarch/test-design/steps-v/step-01-validate.md +67 -0
  658. package/_bmad/tea/workflows/testarch/test-design/test-design-architecture-template.md +222 -0
  659. package/_bmad/tea/workflows/testarch/test-design/test-design-qa-template.md +296 -0
  660. package/_bmad/tea/workflows/testarch/test-design/test-design-template.md +294 -0
  661. package/_bmad/tea/workflows/testarch/test-design/validation-report-20260127-095021.md +73 -0
  662. package/_bmad/tea/workflows/testarch/test-design/validation-report-20260127-102401.md +116 -0
  663. package/_bmad/tea/workflows/testarch/test-design/workflow-plan.md +22 -0
  664. package/_bmad/tea/workflows/testarch/test-design/workflow.md +39 -0
  665. package/_bmad/tea/workflows/testarch/test-design/workflow.yaml +69 -0
  666. package/_bmad/tea/workflows/testarch/test-review/checklist.md +472 -0
  667. package/_bmad/tea/workflows/testarch/test-review/instructions.md +36 -0
  668. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-01-load-context.md +101 -0
  669. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-02-discover-tests.md +69 -0
  670. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03-quality-evaluation.md +184 -0
  671. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03a-subprocess-determinism.md +214 -0
  672. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03b-subprocess-isolation.md +125 -0
  673. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03c-subprocess-maintainability.md +102 -0
  674. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03d-subprocess-coverage.md +111 -0
  675. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03e-subprocess-performance.md +117 -0
  676. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-03f-aggregate-scores.md +246 -0
  677. package/_bmad/tea/workflows/testarch/test-review/steps-c/step-04-generate-report.md +72 -0
  678. package/_bmad/tea/workflows/testarch/test-review/steps-e/step-01-assess.md +65 -0
  679. package/_bmad/tea/workflows/testarch/test-review/steps-e/step-02-apply-edit.md +60 -0
  680. package/_bmad/tea/workflows/testarch/test-review/steps-v/step-01-validate.md +67 -0
  681. package/_bmad/tea/workflows/testarch/test-review/test-review-template.md +390 -0
  682. package/_bmad/tea/workflows/testarch/test-review/validation-report-20260127-095021.md +72 -0
  683. package/_bmad/tea/workflows/testarch/test-review/validation-report-20260127-102401.md +114 -0
  684. package/_bmad/tea/workflows/testarch/test-review/workflow-plan.md +18 -0
  685. package/_bmad/tea/workflows/testarch/test-review/workflow.md +39 -0
  686. package/_bmad/tea/workflows/testarch/test-review/workflow.yaml +46 -0
  687. package/_bmad/tea/workflows/testarch/trace/checklist.md +642 -0
  688. package/_bmad/tea/workflows/testarch/trace/instructions.md +36 -0
  689. package/_bmad/tea/workflows/testarch/trace/steps-c/step-01-load-context.md +80 -0
  690. package/_bmad/tea/workflows/testarch/trace/steps-c/step-02-discover-tests.md +69 -0
  691. package/_bmad/tea/workflows/testarch/trace/steps-c/step-03-map-criteria.md +65 -0
  692. package/_bmad/tea/workflows/testarch/trace/steps-c/step-04-analyze-gaps.md +244 -0
  693. package/_bmad/tea/workflows/testarch/trace/steps-c/step-05-gate-decision.md +232 -0
  694. package/_bmad/tea/workflows/testarch/trace/steps-e/step-01-assess.md +65 -0
  695. package/_bmad/tea/workflows/testarch/trace/steps-e/step-02-apply-edit.md +60 -0
  696. package/_bmad/tea/workflows/testarch/trace/steps-v/step-01-validate.md +67 -0
  697. package/_bmad/tea/workflows/testarch/trace/trace-template.md +675 -0
  698. package/_bmad/tea/workflows/testarch/trace/validation-report-20260127-095021.md +73 -0
  699. package/_bmad/tea/workflows/testarch/trace/validation-report-20260127-102401.md +116 -0
  700. package/_bmad/tea/workflows/testarch/trace/workflow-plan.md +21 -0
  701. package/_bmad/tea/workflows/testarch/trace/workflow.md +39 -0
  702. package/_bmad/tea/workflows/testarch/trace/workflow.yaml +55 -0
  703. package/install/.eslintrc.js +20 -0
  704. package/install/.prettierrc +7 -0
  705. package/install/BUGFIX-CHALK.md +173 -0
  706. package/install/BUGFIX-DOCUMENTATION-INDEX.md +299 -0
  707. package/install/BUGFIX-PATH-RESOLUTION.md +293 -0
  708. package/install/BUGFIX-QUICKSTART.md +184 -0
  709. package/install/BUGFIX-SUMMARY.txt +91 -0
  710. package/install/BUGFIX-VISUAL-SUMMARY.md +253 -0
  711. package/install/DEPLOYMENT-GUIDE-V2.md +431 -0
  712. package/install/DOCS-INDEX.md +261 -0
  713. package/install/GUIDE-INSTALLATION-BYAN-SIMPLE.md +1083 -0
  714. package/install/INSTALLER-V2-CHANGES.md +472 -0
  715. package/install/PUBLICATION-CHECKLIST.md +265 -0
  716. package/install/PUBLISH-GUIDE.md +190 -0
  717. package/install/QUICKSTART.md +311 -0
  718. package/install/README-NPM-SHORT.md +298 -0
  719. package/install/README-NPM.md +433 -0
  720. package/install/README-RACHID.md +302 -0
  721. package/install/README-V2-INDEX.md +306 -0
  722. package/install/README.md +298 -0
  723. package/install/RESUME-EXECUTIF-YAN.md +408 -0
  724. package/install/UPDATE-SUMMARY.md +205 -0
  725. package/install/__tests__/integration/detection-flow.test.js +154 -0
  726. package/install/__tests__/platforms/claude-code.test.js +175 -0
  727. package/install/__tests__/platforms/codex.test.js +80 -0
  728. package/install/__tests__/platforms/copilot-cli.test.js +118 -0
  729. package/install/__tests__/platforms/vscode.test.js +67 -0
  730. package/install/__tests__/utils/file-utils.test.js +87 -0
  731. package/install/__tests__/utils/git-detector.test.js +80 -0
  732. package/install/__tests__/utils/logger.test.js +83 -0
  733. package/install/__tests__/utils/node-detector.test.js +71 -0
  734. package/install/__tests__/utils/os-detector.test.js +63 -0
  735. package/install/__tests__/utils/yaml-utils.test.js +85 -0
  736. package/install/__tests__/yanstaller/detector.test.js +210 -0
  737. package/install/coverage/clover.xml +219 -0
  738. package/install/coverage/coverage-final.json +13 -0
  739. package/install/coverage/lcov-report/base.css +224 -0
  740. package/install/coverage/lcov-report/block-navigation.js +87 -0
  741. package/install/coverage/lcov-report/favicon.png +0 -0
  742. package/install/coverage/lcov-report/index.html +146 -0
  743. package/install/coverage/lcov-report/lib/errors.js.html +268 -0
  744. package/install/coverage/lcov-report/lib/exit-codes.js.html +247 -0
  745. package/install/coverage/lcov-report/lib/index.html +131 -0
  746. package/install/coverage/lcov-report/lib/platforms/claude-code.js.html +343 -0
  747. package/install/coverage/lcov-report/lib/platforms/codex.js.html +361 -0
  748. package/install/coverage/lcov-report/lib/platforms/copilot-cli.js.html +454 -0
  749. package/install/coverage/lcov-report/lib/platforms/index.html +176 -0
  750. package/install/coverage/lcov-report/lib/platforms/index.js.html +127 -0
  751. package/install/coverage/lcov-report/lib/platforms/vscode.js.html +238 -0
  752. package/install/coverage/lcov-report/lib/utils/config-loader.js.html +322 -0
  753. package/install/coverage/lcov-report/lib/utils/file-utils.js.html +397 -0
  754. package/install/coverage/lcov-report/lib/utils/git-detector.js.html +190 -0
  755. package/install/coverage/lcov-report/lib/utils/index.html +206 -0
  756. package/install/coverage/lcov-report/lib/utils/logger.js.html +277 -0
  757. package/install/coverage/lcov-report/lib/utils/node-detector.js.html +259 -0
  758. package/install/coverage/lcov-report/lib/utils/os-detector.js.html +307 -0
  759. package/install/coverage/lcov-report/lib/utils/yaml-utils.js.html +346 -0
  760. package/install/coverage/lcov-report/lib/yanstaller/backuper.js.html +409 -0
  761. package/install/coverage/lcov-report/lib/yanstaller/detector.js.html +508 -0
  762. package/install/coverage/lcov-report/lib/yanstaller/index.html +236 -0
  763. package/install/coverage/lcov-report/lib/yanstaller/index.js.html +364 -0
  764. package/install/coverage/lcov-report/lib/yanstaller/installer.js.html +505 -0
  765. package/install/coverage/lcov-report/lib/yanstaller/interviewer.js.html +349 -0
  766. package/install/coverage/lcov-report/lib/yanstaller/recommender.js.html +379 -0
  767. package/install/coverage/lcov-report/lib/yanstaller/troubleshooter.js.html +352 -0
  768. package/install/coverage/lcov-report/lib/yanstaller/validator.js.html +679 -0
  769. package/install/coverage/lcov-report/lib/yanstaller/wizard.js.html +412 -0
  770. package/install/coverage/lcov-report/platforms/claude-code.js.html +343 -0
  771. package/install/coverage/lcov-report/platforms/codex.js.html +361 -0
  772. package/install/coverage/lcov-report/platforms/copilot-cli.js.html +454 -0
  773. package/install/coverage/lcov-report/platforms/index.html +176 -0
  774. package/install/coverage/lcov-report/platforms/index.js.html +127 -0
  775. package/install/coverage/lcov-report/platforms/vscode.js.html +238 -0
  776. package/install/coverage/lcov-report/prettify.css +1 -0
  777. package/install/coverage/lcov-report/prettify.js +2 -0
  778. package/install/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  779. package/install/coverage/lcov-report/sorter.js +210 -0
  780. package/install/coverage/lcov-report/utils/file-utils.js.html +397 -0
  781. package/install/coverage/lcov-report/utils/git-detector.js.html +190 -0
  782. package/install/coverage/lcov-report/utils/index.html +191 -0
  783. package/install/coverage/lcov-report/utils/logger.js.html +277 -0
  784. package/install/coverage/lcov-report/utils/node-detector.js.html +259 -0
  785. package/install/coverage/lcov-report/utils/os-detector.js.html +307 -0
  786. package/install/coverage/lcov-report/utils/yaml-utils.js.html +346 -0
  787. package/install/coverage/lcov-report/yanstaller/detector.js.html +508 -0
  788. package/install/coverage/lcov-report/yanstaller/index.html +116 -0
  789. package/install/coverage/lcov.info +414 -0
  790. package/install/install.sh +239 -0
  791. package/install/jest.config.js +33 -0
  792. package/install/lib/errors.js +61 -0
  793. package/install/lib/exit-codes.js +54 -0
  794. package/install/lib/platforms/claude-code.js +86 -0
  795. package/install/lib/platforms/codex.js +92 -0
  796. package/install/lib/platforms/copilot-cli.js +123 -0
  797. package/install/lib/platforms/index.js +14 -0
  798. package/install/lib/platforms/vscode.js +51 -0
  799. package/install/lib/utils/config-loader.js +79 -0
  800. package/install/lib/utils/file-utils.js +104 -0
  801. package/install/lib/utils/git-detector.js +35 -0
  802. package/install/lib/utils/logger.js +64 -0
  803. package/install/lib/utils/node-detector.js +58 -0
  804. package/install/lib/utils/os-detector.js +74 -0
  805. package/install/lib/utils/yaml-utils.js +87 -0
  806. package/install/lib/yanstaller/backuper.js +108 -0
  807. package/install/lib/yanstaller/detector.js +141 -0
  808. package/install/lib/yanstaller/index.js +93 -0
  809. package/install/lib/yanstaller/installer.js +140 -0
  810. package/install/lib/yanstaller/interviewer.js +88 -0
  811. package/install/lib/yanstaller/recommender.js +98 -0
  812. package/install/lib/yanstaller/troubleshooter.js +89 -0
  813. package/install/lib/yanstaller/validator.js +198 -0
  814. package/install/lib/yanstaller/wizard.js +109 -0
  815. package/install/package-npm.json +55 -0
  816. package/install/package.json +63 -0
  817. package/install/src/byan-v2/context/copilot-context.js +79 -0
  818. package/install/src/byan-v2/context/session-state.js +98 -0
  819. package/install/src/byan-v2/dispatcher/complexity-scorer.js +232 -0
  820. package/install/src/byan-v2/dispatcher/local-executor.js +221 -0
  821. package/install/src/byan-v2/dispatcher/task-router.js +122 -0
  822. package/install/src/byan-v2/dispatcher/task-tool-interface-mock.js +134 -0
  823. package/install/src/byan-v2/dispatcher/task-tool-interface.js +123 -0
  824. package/install/src/byan-v2/generation/agent-profile-validator.js +113 -0
  825. package/install/src/byan-v2/generation/profile-template.js +113 -0
  826. package/install/src/byan-v2/generation/templates/default-agent.md +49 -0
  827. package/install/src/byan-v2/generation/templates/test-template.md +1 -0
  828. package/install/src/byan-v2/index.js +199 -0
  829. package/install/src/byan-v2/observability/error-tracker.js +105 -0
  830. package/install/src/byan-v2/observability/logger.js +154 -0
  831. package/install/src/byan-v2/observability/metrics-collector.js +194 -0
  832. package/install/src/byan-v2/orchestrator/analysis-state.js +268 -0
  833. package/install/src/byan-v2/orchestrator/generation-state.js +340 -0
  834. package/install/src/byan-v2/orchestrator/interview-state.js +271 -0
  835. package/install/src/byan-v2/orchestrator/state-machine.js +204 -0
  836. package/install/src/core/cache/cache.js +126 -0
  837. package/install/src/core/context/context.js +86 -0
  838. package/install/src/core/dispatcher/dispatcher.js +135 -0
  839. package/install/src/core/worker-pool/worker-pool.js +194 -0
  840. package/install/src/core/workflow/workflow-executor.js +220 -0
  841. package/install/src/index.js +139 -0
  842. package/install/src/observability/dashboard/dashboard.js +191 -0
  843. package/install/src/observability/logger/structured-logger.js +254 -0
  844. package/install/src/observability/metrics/metrics-collector.js +325 -0
  845. package/install/switch-to-v2.sh +126 -0
  846. package/install/templates/.github/agents/bmad-agent-bmb-agent-builder.md +15 -0
  847. package/install/templates/.github/agents/bmad-agent-bmb-module-builder.md +15 -0
  848. package/install/templates/.github/agents/bmad-agent-bmb-workflow-builder.md +15 -0
  849. package/install/templates/.github/agents/bmad-agent-bmm-analyst.md +15 -0
  850. package/install/templates/.github/agents/bmad-agent-bmm-architect.md +15 -0
  851. package/install/templates/.github/agents/bmad-agent-bmm-dev.md +15 -0
  852. package/install/templates/.github/agents/bmad-agent-bmm-pm.md +15 -0
  853. package/install/templates/.github/agents/bmad-agent-bmm-quick-flow-solo-dev.md +15 -0
  854. package/install/templates/.github/agents/bmad-agent-bmm-quinn.md +15 -0
  855. package/install/templates/.github/agents/bmad-agent-bmm-sm.md +15 -0
  856. package/install/templates/.github/agents/bmad-agent-bmm-tech-writer.md +15 -0
  857. package/install/templates/.github/agents/bmad-agent-bmm-ux-designer.md +15 -0
  858. package/install/templates/.github/agents/bmad-agent-byan-test.md +32 -0
  859. package/install/templates/.github/agents/bmad-agent-carmack.md +18 -0
  860. package/install/templates/.github/agents/bmad-agent-cis-brainstorming-coach.md +15 -0
  861. package/install/templates/.github/agents/bmad-agent-cis-creative-problem-solver.md +15 -0
  862. package/install/templates/.github/agents/bmad-agent-cis-design-thinking-coach.md +15 -0
  863. package/install/templates/.github/agents/bmad-agent-cis-innovation-strategist.md +15 -0
  864. package/install/templates/.github/agents/bmad-agent-cis-presentation-master.md +15 -0
  865. package/install/templates/.github/agents/bmad-agent-cis-storyteller.md +15 -0
  866. package/install/templates/.github/agents/bmad-agent-patnote.md +48 -0
  867. package/install/templates/.github/agents/bmad-agent-rachid.md +47 -0
  868. package/install/templates/.github/agents/bmad-agent-tea-tea.md +15 -0
  869. package/install/templates/_bmad/bmb/agents/agent-builder.md +59 -0
  870. package/install/templates/_bmad/bmb/agents/byan-test.md +116 -0
  871. package/install/templates/_bmad/bmb/agents/byan.md +215 -0
  872. package/install/templates/_bmad/bmb/agents/module-builder.md +60 -0
  873. package/install/templates/_bmad/bmb/agents/patnote.md +495 -0
  874. package/install/templates/_bmad/bmb/agents/rachid.md +184 -0
  875. package/install/templates/_bmad/bmb/agents/workflow-builder.md +61 -0
  876. package/install/templates/_bmad/bmb/workflows/byan/data/mantras.yaml +272 -0
  877. package/install/templates/_bmad/bmb/workflows/byan/data/templates.yaml +59 -0
  878. package/install/templates/_bmad/bmb/workflows/byan/delete-agent-workflow.md +657 -0
  879. package/install/templates/_bmad/bmb/workflows/byan/edit-agent-workflow.md +688 -0
  880. package/install/templates/_bmad/bmb/workflows/byan/interview-workflow.md +753 -0
  881. package/install/templates/_bmad/bmb/workflows/byan/quick-create-workflow.md +450 -0
  882. package/install/templates/_bmad/bmb/workflows/byan/templates/base-agent-template.md +79 -0
  883. package/install/templates/_bmad/bmb/workflows/byan/validate-agent-workflow.md +676 -0
  884. package/install/templates/_bmad/core/agents/carmack.md +238 -0
  885. package/install/test-chalk-fix.sh +210 -0
  886. package/install/test-installer-v2.sh +204 -0
  887. package/install/test-path-resolution.sh +200 -0
  888. package/package.json +51 -33
  889. package/src/byan-v2/context/copilot-context.js +79 -0
  890. package/src/byan-v2/context/session-state.js +98 -0
  891. package/src/byan-v2/data/mantras.json +852 -0
  892. package/src/byan-v2/dispatcher/complexity-scorer.js +232 -0
  893. package/src/byan-v2/dispatcher/five-whys-analyzer.js +310 -0
  894. package/src/byan-v2/dispatcher/local-executor.js +221 -0
  895. package/src/byan-v2/dispatcher/task-router.js +122 -0
  896. package/src/byan-v2/dispatcher/task-tool-interface-mock.js +134 -0
  897. package/src/byan-v2/dispatcher/task-tool-interface.js +123 -0
  898. package/src/byan-v2/generation/agent-profile-validator.js +113 -0
  899. package/src/byan-v2/generation/mantra-validator.js +416 -0
  900. package/src/byan-v2/generation/profile-template.js +113 -0
  901. package/src/byan-v2/generation/templates/default-agent.md +49 -0
  902. package/src/byan-v2/generation/templates/test-template.md +1 -0
  903. package/src/byan-v2/index.js +652 -0
  904. package/src/byan-v2/integration/voice-integration.js +295 -0
  905. package/src/byan-v2/observability/error-tracker.js +105 -0
  906. package/src/byan-v2/observability/logger.js +154 -0
  907. package/src/byan-v2/observability/metrics-collector.js +194 -0
  908. package/src/byan-v2/orchestrator/active-listener.js +541 -0
  909. package/src/byan-v2/orchestrator/analysis-state.js +268 -0
  910. package/src/byan-v2/orchestrator/generation-state.js +340 -0
  911. package/src/byan-v2/orchestrator/glossary-builder.js +431 -0
  912. package/src/byan-v2/orchestrator/interview-state.js +353 -0
  913. package/src/byan-v2/orchestrator/state-machine.js +253 -0
  914. package/src/core/cache/cache.js +126 -0
  915. package/src/core/context/context.js +86 -0
  916. package/src/core/dispatcher/dispatcher.js +135 -0
  917. package/src/core/worker-pool/worker-pool.js +194 -0
  918. package/src/core/workflow/workflow-executor.js +220 -0
  919. package/src/index.js +139 -0
  920. package/src/observability/dashboard/dashboard.js +191 -0
  921. package/src/observability/logger/structured-logger.js +254 -0
  922. package/src/observability/metrics/metrics-collector.js +325 -0
  923. /package/{templates/.github → .github}/agents/bmad-agent-bmb-agent-builder.md +0 -0
  924. /package/{templates/.github → .github}/agents/bmad-agent-bmb-module-builder.md +0 -0
  925. /package/{templates/.github → .github}/agents/bmad-agent-bmb-workflow-builder.md +0 -0
  926. /package/{templates/.github → .github}/agents/bmad-agent-bmm-analyst.md +0 -0
  927. /package/{templates/.github → .github}/agents/bmad-agent-bmm-architect.md +0 -0
  928. /package/{templates/.github → .github}/agents/bmad-agent-bmm-dev.md +0 -0
  929. /package/{templates/.github → .github}/agents/bmad-agent-bmm-pm.md +0 -0
  930. /package/{templates/.github → .github}/agents/bmad-agent-bmm-quick-flow-solo-dev.md +0 -0
  931. /package/{templates/.github → .github}/agents/bmad-agent-bmm-quinn.md +0 -0
  932. /package/{templates/.github → .github}/agents/bmad-agent-bmm-sm.md +0 -0
  933. /package/{templates/.github → .github}/agents/bmad-agent-bmm-tech-writer.md +0 -0
  934. /package/{templates/.github → .github}/agents/bmad-agent-bmm-ux-designer.md +0 -0
  935. /package/{templates/.github → .github}/agents/bmad-agent-byan-test.md +0 -0
  936. /package/{templates/.github → .github}/agents/bmad-agent-carmack.md +0 -0
  937. /package/{templates/.github → .github}/agents/bmad-agent-cis-brainstorming-coach.md +0 -0
  938. /package/{templates/.github → .github}/agents/bmad-agent-cis-creative-problem-solver.md +0 -0
  939. /package/{templates/.github → .github}/agents/bmad-agent-cis-design-thinking-coach.md +0 -0
  940. /package/{templates/.github → .github}/agents/bmad-agent-cis-innovation-strategist.md +0 -0
  941. /package/{templates/.github → .github}/agents/bmad-agent-cis-presentation-master.md +0 -0
  942. /package/{templates/.github → .github}/agents/bmad-agent-cis-storyteller.md +0 -0
  943. /package/{templates/.github → .github}/agents/bmad-agent-patnote.md +0 -0
  944. /package/{templates/.github → .github}/agents/bmad-agent-rachid.md +0 -0
  945. /package/{templates/.github → .github}/agents/bmad-agent-tea-tea.md +0 -0
  946. /package/{templates/.github → .github}/agents/bmad-agent-test-dynamic.md +0 -0
  947. /package/{templates/.github → .github}/agents/franck.md +0 -0
  948. /package/{templates/_bmad → _bmad}/bmb/agents/agent-builder.md +0 -0
  949. /package/{templates/_bmad → _bmad}/bmb/agents/byan-test.md +0 -0
  950. /package/{templates/_bmad/bmb/agents/byan.md → _bmad/bmb/agents/byan.backup.20260202_212559.md} +0 -0
  951. /package/{templates/_bmad → _bmad}/bmb/agents/module-builder.md +0 -0
  952. /package/{templates/_bmad → _bmad}/bmb/agents/patnote.md +0 -0
  953. /package/{templates/_bmad → _bmad}/bmb/agents/rachid.md +0 -0
  954. /package/{templates/_bmad → _bmad}/bmb/agents/workflow-builder.md +0 -0
  955. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/data/mantras.yaml +0 -0
  956. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/data/templates.yaml +0 -0
  957. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/delete-agent-workflow.md +0 -0
  958. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/edit-agent-workflow.md +0 -0
  959. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/interview-workflow.md +0 -0
  960. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/quick-create-workflow.md +0 -0
  961. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/templates/base-agent-template.md +0 -0
  962. /package/{templates/_bmad → _bmad}/bmb/workflows/byan/validate-agent-workflow.md +0 -0
  963. /package/{templates/_bmad → _bmad}/core/agents/carmack.md +0 -0
  964. /package/{CHANGELOG.md → install/CHANGELOG.md} +0 -0
  965. /package/{LICENSE → install/LICENSE} +0 -0
  966. /package/{README.md → install/README-NPM-PUBLISH.md} +0 -0
  967. /package/{bin → install/bin}/create-byan-agent-backup.js +0 -0
  968. /package/{bin → install/bin}/create-byan-agent-fixed.js +0 -0
  969. /package/{bin → install/bin}/create-byan-agent-v2.js +0 -0
  970. /package/{bin → install/bin}/create-byan-agent.js +0 -0
  971. /package/{templates → install/templates}/.github/agents/bmad-agent-bmad-master.md +0 -0
  972. /package/{templates → install/templates}/.github/agents/bmad-agent-byan.md +0 -0
  973. /package/{templates → install/templates}/.github/agents/bmad-agent-marc.md +0 -0
  974. /package/{templates → install/templates}/_bmad/bmb/agents/marc.md +0 -0
@@ -0,0 +1,851 @@
1
+ # API Testing Patterns
2
+
3
+ ## Principle
4
+
5
+ Test APIs and backend services directly without browser overhead. Use Playwright's `request` context for HTTP operations, `apiRequest` utility for enhanced features, and `recurse` for async operations. Pure API tests run faster, are more stable, and provide better coverage for service-layer logic.
6
+
7
+ ## Rationale
8
+
9
+ Many teams over-rely on E2E/browser tests when API tests would be more appropriate:
10
+
11
+ - **Slower feedback**: Browser tests take seconds, API tests take milliseconds
12
+ - **More brittle**: UI changes break tests even when API works correctly
13
+ - **Wrong abstraction**: Testing business logic through UI layers adds noise
14
+ - **Resource heavy**: Browsers consume memory and CPU
15
+
16
+ API-first testing provides:
17
+
18
+ - **Fast execution**: No browser startup, no rendering, no JavaScript execution
19
+ - **Direct validation**: Test exactly what the service returns
20
+ - **Better isolation**: Test service logic independent of UI
21
+ - **Easier debugging**: Clear request/response without DOM noise
22
+ - **Contract validation**: Verify API contracts explicitly
23
+
24
+ ## When to Use API Tests vs E2E Tests
25
+
26
+ | Scenario | API Test | E2E Test |
27
+ | ------------------------- | ------------- | ------------- |
28
+ | CRUD operations | ✅ Primary | ❌ Overkill |
29
+ | Business logic validation | ✅ Primary | ❌ Overkill |
30
+ | Error handling (4xx, 5xx) | ✅ Primary | ⚠️ Supplement |
31
+ | Authentication flows | ✅ Primary | ⚠️ Supplement |
32
+ | Data transformation | ✅ Primary | ❌ Overkill |
33
+ | User journeys | ❌ Can't test | ✅ Primary |
34
+ | Visual regression | ❌ Can't test | ✅ Primary |
35
+ | Cross-browser issues | ❌ Can't test | ✅ Primary |
36
+
37
+ **Rule of thumb**: If you're testing what the server returns (not how it looks), use API tests.
38
+
39
+ ## Pattern Examples
40
+
41
+ ### Example 1: Pure API Test (No Browser)
42
+
43
+ **Context**: Test REST API endpoints directly without any browser context.
44
+
45
+ **Implementation**:
46
+
47
+ ```typescript
48
+ // tests/api/users.spec.ts
49
+ import { test, expect } from '@playwright/test';
50
+
51
+ // No page, no browser - just API
52
+ test.describe('Users API', () => {
53
+ test('should create user', async ({ request }) => {
54
+ const response = await request.post('/api/users', {
55
+ data: {
56
+ name: 'John Doe',
57
+ email: 'john@example.com',
58
+ role: 'user',
59
+ },
60
+ });
61
+
62
+ expect(response.status()).toBe(201);
63
+
64
+ const user = await response.json();
65
+ expect(user.id).toBeDefined();
66
+ expect(user.name).toBe('John Doe');
67
+ expect(user.email).toBe('john@example.com');
68
+ });
69
+
70
+ test('should get user by ID', async ({ request }) => {
71
+ // Create user first
72
+ const createResponse = await request.post('/api/users', {
73
+ data: { name: 'Jane Doe', email: 'jane@example.com' },
74
+ });
75
+ const { id } = await createResponse.json();
76
+
77
+ // Get user
78
+ const getResponse = await request.get(`/api/users/${id}`);
79
+ expect(getResponse.status()).toBe(200);
80
+
81
+ const user = await getResponse.json();
82
+ expect(user.id).toBe(id);
83
+ expect(user.name).toBe('Jane Doe');
84
+ });
85
+
86
+ test('should return 404 for non-existent user', async ({ request }) => {
87
+ const response = await request.get('/api/users/non-existent-id');
88
+ expect(response.status()).toBe(404);
89
+
90
+ const error = await response.json();
91
+ expect(error.code).toBe('USER_NOT_FOUND');
92
+ });
93
+
94
+ test('should validate required fields', async ({ request }) => {
95
+ const response = await request.post('/api/users', {
96
+ data: { name: 'Missing Email' }, // email is required
97
+ });
98
+
99
+ expect(response.status()).toBe(400);
100
+
101
+ const error = await response.json();
102
+ expect(error.code).toBe('VALIDATION_ERROR');
103
+ expect(error.details).toContainEqual(expect.objectContaining({ field: 'email', message: expect.any(String) }));
104
+ });
105
+ });
106
+ ```
107
+
108
+ **Key Points**:
109
+
110
+ - No `page` fixture needed - only `request`
111
+ - Tests run without browser overhead
112
+ - Direct HTTP assertions
113
+ - Clear error handling tests
114
+
115
+ ### Example 2: API Test with apiRequest Utility
116
+
117
+ **Context**: Use enhanced apiRequest for schema validation, retry, and type safety.
118
+
119
+ **Implementation**:
120
+
121
+ ```typescript
122
+ // tests/api/orders.spec.ts
123
+ import { test, expect } from '@seontechnologies/playwright-utils/api-request/fixtures';
124
+ import { z } from 'zod';
125
+
126
+ // Define schema for type safety and validation
127
+ const OrderSchema = z.object({
128
+ id: z.string().uuid(),
129
+ userId: z.string(),
130
+ items: z.array(
131
+ z.object({
132
+ productId: z.string(),
133
+ quantity: z.number().positive(),
134
+ price: z.number().positive(),
135
+ }),
136
+ ),
137
+ total: z.number().positive(),
138
+ status: z.enum(['pending', 'processing', 'shipped', 'delivered']),
139
+ createdAt: z.string().datetime(),
140
+ });
141
+
142
+ type Order = z.infer<typeof OrderSchema>;
143
+
144
+ test.describe('Orders API', () => {
145
+ test('should create order with schema validation', async ({ apiRequest }) => {
146
+ const { status, body } = await apiRequest<Order>({
147
+ method: 'POST',
148
+ path: '/api/orders',
149
+ body: {
150
+ userId: 'user-123',
151
+ items: [
152
+ { productId: 'prod-1', quantity: 2, price: 29.99 },
153
+ { productId: 'prod-2', quantity: 1, price: 49.99 },
154
+ ],
155
+ },
156
+ validateSchema: OrderSchema, // Validates response matches schema
157
+ });
158
+
159
+ expect(status).toBe(201);
160
+ expect(body.id).toBeDefined();
161
+ expect(body.status).toBe('pending');
162
+ expect(body.total).toBe(109.97); // 2*29.99 + 49.99
163
+ });
164
+
165
+ test('should handle server errors with retry', async ({ apiRequest }) => {
166
+ // apiRequest retries 5xx errors by default
167
+ const { status, body } = await apiRequest({
168
+ method: 'GET',
169
+ path: '/api/orders/order-123',
170
+ retryConfig: {
171
+ maxRetries: 3,
172
+ retryDelay: 1000,
173
+ },
174
+ });
175
+
176
+ expect(status).toBe(200);
177
+ });
178
+
179
+ test('should list orders with pagination', async ({ apiRequest }) => {
180
+ const { status, body } = await apiRequest<{ orders: Order[]; total: number; page: number }>({
181
+ method: 'GET',
182
+ path: '/api/orders',
183
+ params: { page: 1, limit: 10, status: 'pending' },
184
+ });
185
+
186
+ expect(status).toBe(200);
187
+ expect(body.orders).toHaveLength(10);
188
+ expect(body.total).toBeGreaterThan(10);
189
+ expect(body.page).toBe(1);
190
+ });
191
+ });
192
+ ```
193
+
194
+ **Key Points**:
195
+
196
+ - Zod schema for runtime validation AND TypeScript types
197
+ - `validateSchema` throws if response doesn't match
198
+ - Built-in retry for transient failures
199
+ - Type-safe `body` access
200
+
201
+ ### Example 3: Microservice-to-Microservice Testing
202
+
203
+ **Context**: Test service interactions without browser - validate API contracts between services.
204
+
205
+ **Implementation**:
206
+
207
+ ```typescript
208
+ // tests/api/service-integration.spec.ts
209
+ import { test, expect } from '@seontechnologies/playwright-utils/fixtures';
210
+
211
+ test.describe('Service Integration', () => {
212
+ const USER_SERVICE_URL = process.env.USER_SERVICE_URL || 'http://localhost:3001';
213
+ const ORDER_SERVICE_URL = process.env.ORDER_SERVICE_URL || 'http://localhost:3002';
214
+ const INVENTORY_SERVICE_URL = process.env.INVENTORY_SERVICE_URL || 'http://localhost:3003';
215
+
216
+ test('order service should validate user exists', async ({ apiRequest }) => {
217
+ // Create user in user-service
218
+ const { body: user } = await apiRequest({
219
+ method: 'POST',
220
+ path: '/api/users',
221
+ baseUrl: USER_SERVICE_URL,
222
+ body: { name: 'Test User', email: 'test@example.com' },
223
+ });
224
+
225
+ // Create order in order-service (should validate user via user-service)
226
+ const { status, body: order } = await apiRequest({
227
+ method: 'POST',
228
+ path: '/api/orders',
229
+ baseUrl: ORDER_SERVICE_URL,
230
+ body: {
231
+ userId: user.id,
232
+ items: [{ productId: 'prod-1', quantity: 1 }],
233
+ },
234
+ });
235
+
236
+ expect(status).toBe(201);
237
+ expect(order.userId).toBe(user.id);
238
+ });
239
+
240
+ test('order service should reject invalid user', async ({ apiRequest }) => {
241
+ const { status, body } = await apiRequest({
242
+ method: 'POST',
243
+ path: '/api/orders',
244
+ baseUrl: ORDER_SERVICE_URL,
245
+ body: {
246
+ userId: 'non-existent-user',
247
+ items: [{ productId: 'prod-1', quantity: 1 }],
248
+ },
249
+ });
250
+
251
+ expect(status).toBe(400);
252
+ expect(body.code).toBe('INVALID_USER');
253
+ });
254
+
255
+ test('order should decrease inventory', async ({ apiRequest, recurse }) => {
256
+ // Get initial inventory
257
+ const { body: initialInventory } = await apiRequest({
258
+ method: 'GET',
259
+ path: '/api/inventory/prod-1',
260
+ baseUrl: INVENTORY_SERVICE_URL,
261
+ });
262
+
263
+ // Create order
264
+ await apiRequest({
265
+ method: 'POST',
266
+ path: '/api/orders',
267
+ baseUrl: ORDER_SERVICE_URL,
268
+ body: {
269
+ userId: 'user-123',
270
+ items: [{ productId: 'prod-1', quantity: 2 }],
271
+ },
272
+ });
273
+
274
+ // Poll for inventory update (eventual consistency)
275
+ const { body: updatedInventory } = await recurse(
276
+ () =>
277
+ apiRequest({
278
+ method: 'GET',
279
+ path: '/api/inventory/prod-1',
280
+ baseUrl: INVENTORY_SERVICE_URL,
281
+ }),
282
+ (response) => response.body.quantity === initialInventory.quantity - 2,
283
+ { timeout: 10000, interval: 500 },
284
+ );
285
+
286
+ expect(updatedInventory.quantity).toBe(initialInventory.quantity - 2);
287
+ });
288
+ });
289
+ ```
290
+
291
+ **Key Points**:
292
+
293
+ - Multiple service URLs for microservice testing
294
+ - Tests service-to-service communication
295
+ - Uses `recurse` for eventual consistency
296
+ - No browser needed for full integration testing
297
+
298
+ ### Example 4: GraphQL API Testing
299
+
300
+ **Context**: Test GraphQL endpoints with queries and mutations.
301
+
302
+ **Implementation**:
303
+
304
+ ```typescript
305
+ // tests/api/graphql.spec.ts
306
+ import { test, expect } from '@seontechnologies/playwright-utils/api-request/fixtures';
307
+
308
+ const GRAPHQL_ENDPOINT = '/graphql';
309
+
310
+ test.describe('GraphQL API', () => {
311
+ test('should query users', async ({ apiRequest }) => {
312
+ const query = `
313
+ query GetUsers($limit: Int) {
314
+ users(limit: $limit) {
315
+ id
316
+ name
317
+ email
318
+ role
319
+ }
320
+ }
321
+ `;
322
+
323
+ const { status, body } = await apiRequest({
324
+ method: 'POST',
325
+ path: GRAPHQL_ENDPOINT,
326
+ body: {
327
+ query,
328
+ variables: { limit: 10 },
329
+ },
330
+ });
331
+
332
+ expect(status).toBe(200);
333
+ expect(body.errors).toBeUndefined();
334
+ expect(body.data.users).toHaveLength(10);
335
+ expect(body.data.users[0]).toHaveProperty('id');
336
+ expect(body.data.users[0]).toHaveProperty('name');
337
+ });
338
+
339
+ test('should create user via mutation', async ({ apiRequest }) => {
340
+ const mutation = `
341
+ mutation CreateUser($input: CreateUserInput!) {
342
+ createUser(input: $input) {
343
+ id
344
+ name
345
+ email
346
+ }
347
+ }
348
+ `;
349
+
350
+ const { status, body } = await apiRequest({
351
+ method: 'POST',
352
+ path: GRAPHQL_ENDPOINT,
353
+ body: {
354
+ query: mutation,
355
+ variables: {
356
+ input: {
357
+ name: 'GraphQL User',
358
+ email: 'graphql@example.com',
359
+ },
360
+ },
361
+ },
362
+ });
363
+
364
+ expect(status).toBe(200);
365
+ expect(body.errors).toBeUndefined();
366
+ expect(body.data.createUser.id).toBeDefined();
367
+ expect(body.data.createUser.name).toBe('GraphQL User');
368
+ });
369
+
370
+ test('should handle GraphQL errors', async ({ apiRequest }) => {
371
+ const query = `
372
+ query GetUser($id: ID!) {
373
+ user(id: $id) {
374
+ id
375
+ name
376
+ }
377
+ }
378
+ `;
379
+
380
+ const { status, body } = await apiRequest({
381
+ method: 'POST',
382
+ path: GRAPHQL_ENDPOINT,
383
+ body: {
384
+ query,
385
+ variables: { id: 'non-existent' },
386
+ },
387
+ });
388
+
389
+ expect(status).toBe(200); // GraphQL returns 200 even for errors
390
+ expect(body.errors).toBeDefined();
391
+ expect(body.errors[0].message).toContain('not found');
392
+ expect(body.data.user).toBeNull();
393
+ });
394
+
395
+ test('should handle validation errors', async ({ apiRequest }) => {
396
+ const mutation = `
397
+ mutation CreateUser($input: CreateUserInput!) {
398
+ createUser(input: $input) {
399
+ id
400
+ }
401
+ }
402
+ `;
403
+
404
+ const { status, body } = await apiRequest({
405
+ method: 'POST',
406
+ path: GRAPHQL_ENDPOINT,
407
+ body: {
408
+ query: mutation,
409
+ variables: {
410
+ input: {
411
+ name: '', // Invalid: empty name
412
+ email: 'invalid-email', // Invalid: bad format
413
+ },
414
+ },
415
+ },
416
+ });
417
+
418
+ expect(status).toBe(200);
419
+ expect(body.errors).toBeDefined();
420
+ expect(body.errors[0].extensions.code).toBe('BAD_USER_INPUT');
421
+ });
422
+ });
423
+ ```
424
+
425
+ **Key Points**:
426
+
427
+ - GraphQL queries and mutations via POST
428
+ - Variables passed in request body
429
+ - GraphQL returns 200 even for errors (check `body.errors`)
430
+ - Test validation and business logic errors
431
+
432
+ ### Example 5: Database Seeding and Cleanup via API
433
+
434
+ **Context**: Use API calls to set up and tear down test data without direct database access.
435
+
436
+ **Implementation**:
437
+
438
+ ```typescript
439
+ // tests/api/with-data-setup.spec.ts
440
+ import { test, expect } from '@seontechnologies/playwright-utils/fixtures';
441
+
442
+ test.describe('Orders with Data Setup', () => {
443
+ let testUser: { id: string; email: string };
444
+ let testProducts: Array<{ id: string; name: string; price: number }>;
445
+
446
+ test.beforeAll(async ({ request }) => {
447
+ // Seed user via API
448
+ const userResponse = await request.post('/api/users', {
449
+ data: {
450
+ name: 'Test User',
451
+ email: `test-${Date.now()}@example.com`,
452
+ },
453
+ });
454
+ testUser = await userResponse.json();
455
+
456
+ // Seed products via API
457
+ testProducts = [];
458
+ for (const product of [
459
+ { name: 'Widget A', price: 29.99 },
460
+ { name: 'Widget B', price: 49.99 },
461
+ { name: 'Widget C', price: 99.99 },
462
+ ]) {
463
+ const productResponse = await request.post('/api/products', {
464
+ data: product,
465
+ });
466
+ testProducts.push(await productResponse.json());
467
+ }
468
+ });
469
+
470
+ test.afterAll(async ({ request }) => {
471
+ // Cleanup via API
472
+ if (testUser?.id) {
473
+ await request.delete(`/api/users/${testUser.id}`);
474
+ }
475
+ for (const product of testProducts) {
476
+ await request.delete(`/api/products/${product.id}`);
477
+ }
478
+ });
479
+
480
+ test('should create order with seeded data', async ({ apiRequest }) => {
481
+ const { status, body } = await apiRequest({
482
+ method: 'POST',
483
+ path: '/api/orders',
484
+ body: {
485
+ userId: testUser.id,
486
+ items: [
487
+ { productId: testProducts[0].id, quantity: 2 },
488
+ { productId: testProducts[1].id, quantity: 1 },
489
+ ],
490
+ },
491
+ });
492
+
493
+ expect(status).toBe(201);
494
+ expect(body.userId).toBe(testUser.id);
495
+ expect(body.items).toHaveLength(2);
496
+ expect(body.total).toBe(2 * 29.99 + 49.99);
497
+ });
498
+
499
+ test('should list user orders', async ({ apiRequest }) => {
500
+ // Create an order first
501
+ await apiRequest({
502
+ method: 'POST',
503
+ path: '/api/orders',
504
+ body: {
505
+ userId: testUser.id,
506
+ items: [{ productId: testProducts[2].id, quantity: 1 }],
507
+ },
508
+ });
509
+
510
+ // List orders for user
511
+ const { status, body } = await apiRequest({
512
+ method: 'GET',
513
+ path: '/api/orders',
514
+ params: { userId: testUser.id },
515
+ });
516
+
517
+ expect(status).toBe(200);
518
+ expect(body.orders.length).toBeGreaterThanOrEqual(1);
519
+ expect(body.orders.every((o: any) => o.userId === testUser.id)).toBe(true);
520
+ });
521
+ });
522
+ ```
523
+
524
+ **Key Points**:
525
+
526
+ - `beforeAll`/`afterAll` for test data setup/cleanup
527
+ - API-based seeding (no direct DB access needed)
528
+ - Unique emails to prevent conflicts in parallel runs
529
+ - Cleanup after all tests complete
530
+
531
+ ### Example 6: Background Job Testing with Recurse
532
+
533
+ **Context**: Test async operations like background jobs, webhooks, and eventual consistency.
534
+
535
+ **Implementation**:
536
+
537
+ ```typescript
538
+ // tests/api/background-jobs.spec.ts
539
+ import { test, expect } from '@seontechnologies/playwright-utils/fixtures';
540
+
541
+ test.describe('Background Jobs', () => {
542
+ test('should process export job', async ({ apiRequest, recurse }) => {
543
+ // Trigger export job
544
+ const { body: job } = await apiRequest({
545
+ method: 'POST',
546
+ path: '/api/exports',
547
+ body: {
548
+ type: 'users',
549
+ format: 'csv',
550
+ filters: { createdAfter: '2024-01-01' },
551
+ },
552
+ });
553
+
554
+ expect(job.id).toBeDefined();
555
+ expect(job.status).toBe('pending');
556
+
557
+ // Poll until job completes
558
+ const { body: completedJob } = await recurse(
559
+ () => apiRequest({ method: 'GET', path: `/api/exports/${job.id}` }),
560
+ (response) => response.body.status === 'completed',
561
+ {
562
+ timeout: 60000,
563
+ interval: 2000,
564
+ log: `Waiting for export job ${job.id} to complete`,
565
+ },
566
+ );
567
+
568
+ expect(completedJob.status).toBe('completed');
569
+ expect(completedJob.downloadUrl).toBeDefined();
570
+ expect(completedJob.recordCount).toBeGreaterThan(0);
571
+ });
572
+
573
+ test('should handle job failure gracefully', async ({ apiRequest, recurse }) => {
574
+ // Trigger job that will fail
575
+ const { body: job } = await apiRequest({
576
+ method: 'POST',
577
+ path: '/api/exports',
578
+ body: {
579
+ type: 'invalid-type', // This will cause failure
580
+ format: 'csv',
581
+ },
582
+ });
583
+
584
+ // Poll until job fails
585
+ const { body: failedJob } = await recurse(
586
+ () => apiRequest({ method: 'GET', path: `/api/exports/${job.id}` }),
587
+ (response) => ['completed', 'failed'].includes(response.body.status),
588
+ { timeout: 30000 },
589
+ );
590
+
591
+ expect(failedJob.status).toBe('failed');
592
+ expect(failedJob.error).toBeDefined();
593
+ expect(failedJob.error.code).toBe('INVALID_EXPORT_TYPE');
594
+ });
595
+
596
+ test('should process webhook delivery', async ({ apiRequest, recurse }) => {
597
+ // Trigger action that sends webhook
598
+ const { body: order } = await apiRequest({
599
+ method: 'POST',
600
+ path: '/api/orders',
601
+ body: {
602
+ userId: 'user-123',
603
+ items: [{ productId: 'prod-1', quantity: 1 }],
604
+ webhookUrl: 'https://webhook.site/test-endpoint',
605
+ },
606
+ });
607
+
608
+ // Poll for webhook delivery status
609
+ const { body: webhookStatus } = await recurse(
610
+ () => apiRequest({ method: 'GET', path: `/api/webhooks/order/${order.id}` }),
611
+ (response) => response.body.delivered === true,
612
+ { timeout: 30000, interval: 1000 },
613
+ );
614
+
615
+ expect(webhookStatus.delivered).toBe(true);
616
+ expect(webhookStatus.deliveredAt).toBeDefined();
617
+ expect(webhookStatus.responseStatus).toBe(200);
618
+ });
619
+ });
620
+ ```
621
+
622
+ **Key Points**:
623
+
624
+ - `recurse` for polling async operations
625
+ - Test both success and failure scenarios
626
+ - Configurable timeout and interval
627
+ - Log messages for debugging
628
+
629
+ ### Example 7: Service Authentication (No Browser)
630
+
631
+ **Context**: Test authenticated API endpoints using tokens directly - no browser login needed.
632
+
633
+ **Implementation**:
634
+
635
+ ```typescript
636
+ // tests/api/authenticated.spec.ts
637
+ import { test, expect } from '@seontechnologies/playwright-utils/fixtures';
638
+
639
+ test.describe('Authenticated API Tests', () => {
640
+ let authToken: string;
641
+
642
+ test.beforeAll(async ({ request }) => {
643
+ // Get token via API (no browser!)
644
+ const response = await request.post('/api/auth/login', {
645
+ data: {
646
+ email: process.env.TEST_USER_EMAIL,
647
+ password: process.env.TEST_USER_PASSWORD,
648
+ },
649
+ });
650
+
651
+ const { token } = await response.json();
652
+ authToken = token;
653
+ });
654
+
655
+ test('should access protected endpoint with token', async ({ apiRequest }) => {
656
+ const { status, body } = await apiRequest({
657
+ method: 'GET',
658
+ path: '/api/me',
659
+ headers: {
660
+ Authorization: `Bearer ${authToken}`,
661
+ },
662
+ });
663
+
664
+ expect(status).toBe(200);
665
+ expect(body.email).toBe(process.env.TEST_USER_EMAIL);
666
+ });
667
+
668
+ test('should reject request without token', async ({ apiRequest }) => {
669
+ const { status, body } = await apiRequest({
670
+ method: 'GET',
671
+ path: '/api/me',
672
+ // No Authorization header
673
+ });
674
+
675
+ expect(status).toBe(401);
676
+ expect(body.code).toBe('UNAUTHORIZED');
677
+ });
678
+
679
+ test('should reject expired token', async ({ apiRequest }) => {
680
+ const expiredToken = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...'; // Expired token
681
+
682
+ const { status, body } = await apiRequest({
683
+ method: 'GET',
684
+ path: '/api/me',
685
+ headers: {
686
+ Authorization: `Bearer ${expiredToken}`,
687
+ },
688
+ });
689
+
690
+ expect(status).toBe(401);
691
+ expect(body.code).toBe('TOKEN_EXPIRED');
692
+ });
693
+
694
+ test('should handle role-based access', async ({ apiRequest }) => {
695
+ // User token (non-admin)
696
+ const { status } = await apiRequest({
697
+ method: 'GET',
698
+ path: '/api/admin/users',
699
+ headers: {
700
+ Authorization: `Bearer ${authToken}`,
701
+ },
702
+ });
703
+
704
+ expect(status).toBe(403); // Forbidden for non-admin
705
+ });
706
+ });
707
+ ```
708
+
709
+ **Key Points**:
710
+
711
+ - Token obtained via API login (no browser)
712
+ - Token reused across all tests in describe block
713
+ - Test auth, expired tokens, and RBAC
714
+ - Pure API testing without UI
715
+
716
+ ## API Test Configuration
717
+
718
+ ### Playwright Config for API-Only Tests
719
+
720
+ ```typescript
721
+ // playwright.config.ts
722
+ import { defineConfig } from '@playwright/test';
723
+
724
+ export default defineConfig({
725
+ testDir: './tests/api',
726
+
727
+ // No browser needed for API tests
728
+ use: {
729
+ baseURL: process.env.API_URL || 'http://localhost:3000',
730
+ extraHTTPHeaders: {
731
+ Accept: 'application/json',
732
+ 'Content-Type': 'application/json',
733
+ },
734
+ },
735
+
736
+ // Faster without browser overhead
737
+ timeout: 30000,
738
+
739
+ // Run API tests in parallel
740
+ workers: 4,
741
+ fullyParallel: true,
742
+
743
+ // No screenshots/traces needed for API tests
744
+ reporter: [['html'], ['json', { outputFile: 'api-test-results.json' }]],
745
+ });
746
+ ```
747
+
748
+ ### Separate API Test Project
749
+
750
+ ```typescript
751
+ // playwright.config.ts
752
+ export default defineConfig({
753
+ projects: [
754
+ {
755
+ name: 'api',
756
+ testDir: './tests/api',
757
+ use: {
758
+ baseURL: process.env.API_URL,
759
+ },
760
+ },
761
+ {
762
+ name: 'e2e',
763
+ testDir: './tests/e2e',
764
+ use: {
765
+ baseURL: process.env.APP_URL,
766
+ ...devices['Desktop Chrome'],
767
+ },
768
+ },
769
+ ],
770
+ });
771
+ ```
772
+
773
+ ## Comparison: API Tests vs E2E Tests
774
+
775
+ | Aspect | API Test | E2E Test |
776
+ | ------------------- | ---------------------- | --------------------------- |
777
+ | **Speed** | ~50-100ms per test | ~2-10s per test |
778
+ | **Stability** | Very stable | More flaky (UI timing) |
779
+ | **Setup** | Minimal | Browser, context, page |
780
+ | **Debugging** | Clear request/response | DOM, screenshots, traces |
781
+ | **Coverage** | Service logic | User experience |
782
+ | **Parallelization** | Easy (stateless) | Complex (browser resources) |
783
+ | **CI Cost** | Low (no browser) | High (browser containers) |
784
+
785
+ ## Related Fragments
786
+
787
+ - `api-request.md` - apiRequest utility details
788
+ - `recurse.md` - Polling patterns for async operations
789
+ - `auth-session.md` - Token management
790
+ - `contract-testing.md` - Pact contract testing
791
+ - `test-levels-framework.md` - When to use which test level
792
+ - `data-factories.md` - Test data setup patterns
793
+
794
+ ## Anti-Patterns
795
+
796
+ **DON'T use E2E for API validation:**
797
+
798
+ ```typescript
799
+ // Bad: Testing API through UI
800
+ test('validate user creation', async ({ page }) => {
801
+ await page.goto('/admin/users');
802
+ await page.fill('#name', 'John');
803
+ await page.click('#submit');
804
+ await expect(page.getByText('User created')).toBeVisible();
805
+ });
806
+ ```
807
+
808
+ **DO test APIs directly:**
809
+
810
+ ```typescript
811
+ // Good: Direct API test
812
+ test('validate user creation', async ({ apiRequest }) => {
813
+ const { status, body } = await apiRequest({
814
+ method: 'POST',
815
+ path: '/api/users',
816
+ body: { name: 'John' },
817
+ });
818
+ expect(status).toBe(201);
819
+ expect(body.id).toBeDefined();
820
+ });
821
+ ```
822
+
823
+ **DON'T ignore API tests because "E2E covers it":**
824
+
825
+ ```typescript
826
+ // Bad thinking: "Our E2E tests create users, so API is tested"
827
+ // Reality: E2E tests one happy path; API tests cover edge cases
828
+ ```
829
+
830
+ **DO have dedicated API test coverage:**
831
+
832
+ ```typescript
833
+ // Good: Explicit API test suite
834
+ test.describe('Users API', () => {
835
+ test('creates user', async ({ apiRequest }) => {
836
+ /* ... */
837
+ });
838
+ test('handles duplicate email', async ({ apiRequest }) => {
839
+ /* ... */
840
+ });
841
+ test('validates required fields', async ({ apiRequest }) => {
842
+ /* ... */
843
+ });
844
+ test('handles malformed JSON', async ({ apiRequest }) => {
845
+ /* ... */
846
+ });
847
+ test('rate limits requests', async ({ apiRequest }) => {
848
+ /* ... */
849
+ });
850
+ });
851
+ ```