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,421 @@
1
+ # Recurse (Polling) Utility
2
+
3
+ ## Principle
4
+
5
+ Use Cypress-style polling with Playwright's `expect.poll` to wait for asynchronous conditions. Provides configurable timeout, interval, logging, and post-polling callbacks with enhanced error categorization. **Ideal for backend testing**: polling API endpoints for job completion, database eventual consistency, message queue processing, and cache propagation.
6
+
7
+ ## Rationale
8
+
9
+ Testing async operations (background jobs, eventual consistency, webhook processing) requires polling:
10
+
11
+ - Vanilla `expect.poll` is verbose
12
+ - No built-in logging for debugging
13
+ - Generic timeout errors
14
+ - No post-poll hooks
15
+
16
+ The `recurse` utility provides:
17
+
18
+ - **Clean syntax**: Inspired by cypress-recurse
19
+ - **Enhanced errors**: Timeout vs command failure vs predicate errors
20
+ - **Built-in logging**: Track polling progress
21
+ - **Post-poll callbacks**: Process results after success
22
+ - **Type-safe**: Full TypeScript generic support
23
+
24
+ ## Quick Start
25
+
26
+ ```typescript
27
+ import { test } from '@seontechnologies/playwright-utils/recurse/fixtures';
28
+
29
+ test('wait for job completion', async ({ recurse, apiRequest }) => {
30
+ const { body } = await apiRequest({
31
+ method: 'POST',
32
+ path: '/api/jobs',
33
+ body: { type: 'export' },
34
+ });
35
+
36
+ // Poll until job completes
37
+ const result = await recurse(
38
+ () => apiRequest({ method: 'GET', path: `/api/jobs/${body.id}` }),
39
+ (response) => response.body.status === 'completed',
40
+ { timeout: 60000 },
41
+ );
42
+
43
+ expect(result.body.downloadUrl).toBeDefined();
44
+ });
45
+ ```
46
+
47
+ ## Pattern Examples
48
+
49
+ ### Example 1: Basic Polling
50
+
51
+ **Context**: Wait for async operation to complete with custom timeout and interval.
52
+
53
+ **Implementation**:
54
+
55
+ ```typescript
56
+ import { test } from '@seontechnologies/playwright-utils/recurse/fixtures';
57
+
58
+ test('should wait for job completion', async ({ recurse, apiRequest }) => {
59
+ // Start job
60
+ const { body } = await apiRequest({
61
+ method: 'POST',
62
+ path: '/api/jobs',
63
+ body: { type: 'export' },
64
+ });
65
+
66
+ // Poll until ready
67
+ const result = await recurse(
68
+ () => apiRequest({ method: 'GET', path: `/api/jobs/${body.id}` }),
69
+ (response) => response.body.status === 'completed',
70
+ {
71
+ timeout: 60000, // 60 seconds max
72
+ interval: 2000, // Check every 2 seconds
73
+ log: 'Waiting for export job to complete',
74
+ },
75
+ );
76
+
77
+ expect(result.body.downloadUrl).toBeDefined();
78
+ });
79
+ ```
80
+
81
+ **Key Points**:
82
+
83
+ - First arg: command function (what to execute)
84
+ - Second arg: predicate function (when to stop)
85
+ - Options: timeout, interval, log message
86
+ - Returns the value when predicate returns true
87
+
88
+ ### Example 2: Working with Assertions
89
+
90
+ **Context**: Use assertions directly in predicate for more expressive tests.
91
+
92
+ **Implementation**:
93
+
94
+ ```typescript
95
+ test('should poll with assertions', async ({ recurse, apiRequest }) => {
96
+ await apiRequest({
97
+ method: 'POST',
98
+ path: '/api/events',
99
+ body: { type: 'user-created', userId: '123' },
100
+ });
101
+
102
+ // Poll with assertions in predicate - no return true needed!
103
+ await recurse(
104
+ async () => {
105
+ const { body } = await apiRequest({ method: 'GET', path: '/api/events/123' });
106
+ return body;
107
+ },
108
+ (event) => {
109
+ // If all assertions pass, predicate succeeds
110
+ expect(event.processed).toBe(true);
111
+ expect(event.timestamp).toBeDefined();
112
+ // No need to return true - just let assertions pass
113
+ },
114
+ { timeout: 30000 },
115
+ );
116
+ });
117
+ ```
118
+
119
+ **Why no `return true` needed?**
120
+
121
+ The predicate checks for "truthiness" of the return value. But there's a catch - in JavaScript, an empty `return` (or no return) returns `undefined`, which is falsy!
122
+
123
+ The utility handles this by checking if:
124
+
125
+ 1. The predicate didn't throw (assertions passed)
126
+ 2. The return value was either `undefined` (implicit return) or truthy
127
+
128
+ So you can:
129
+
130
+ ```typescript
131
+ // Option 1: Use assertions only (recommended)
132
+ (event) => {
133
+ expect(event.processed).toBe(true);
134
+ };
135
+
136
+ // Option 2: Return boolean (also works)
137
+ (event) => event.processed === true;
138
+
139
+ // Option 3: Mixed (assertions + explicit return)
140
+ (event) => {
141
+ expect(event.processed).toBe(true);
142
+ return true;
143
+ };
144
+ ```
145
+
146
+ ### Example 3: Error Handling
147
+
148
+ **Context**: Understanding the different error types.
149
+
150
+ **Error Types:**
151
+
152
+ ```typescript
153
+ // RecurseTimeoutError - Predicate never returned true within timeout
154
+ // Contains last command value and predicate error
155
+ try {
156
+ await recurse(/* ... */);
157
+ } catch (error) {
158
+ if (error instanceof RecurseTimeoutError) {
159
+ console.log('Timed out. Last value:', error.lastCommandValue);
160
+ console.log('Last predicate error:', error.lastPredicateError);
161
+ }
162
+ }
163
+
164
+ // RecurseCommandError - Command function threw an error
165
+ // The command itself failed (e.g., network error, API error)
166
+
167
+ // RecursePredicateError - Predicate function threw (not from assertions failing)
168
+ // Logic error in your predicate code
169
+ ```
170
+
171
+ **Custom Error Messages:**
172
+
173
+ ```typescript
174
+ test('custom error on timeout', async ({ recurse, apiRequest }) => {
175
+ try {
176
+ await recurse(
177
+ () => apiRequest({ method: 'GET', path: '/api/status' }),
178
+ (res) => res.body.ready === true,
179
+ {
180
+ timeout: 10000,
181
+ error: 'System failed to become ready within 10 seconds - check background workers',
182
+ },
183
+ );
184
+ } catch (error) {
185
+ // Error message includes custom context
186
+ expect(error.message).toContain('check background workers');
187
+ throw error;
188
+ }
189
+ });
190
+ ```
191
+
192
+ ### Example 4: Post-Polling Callback
193
+
194
+ **Context**: Process or log results after successful polling.
195
+
196
+ **Implementation**:
197
+
198
+ ```typescript
199
+ test('post-poll processing', async ({ recurse, apiRequest }) => {
200
+ const finalResult = await recurse(
201
+ () => apiRequest({ method: 'GET', path: '/api/batch-job/123' }),
202
+ (res) => res.body.status === 'completed',
203
+ {
204
+ timeout: 60000,
205
+ post: (result) => {
206
+ // Runs after successful polling
207
+ console.log(`Job completed in ${result.body.duration}ms`);
208
+ console.log(`Processed ${result.body.itemsProcessed} items`);
209
+ return result.body;
210
+ },
211
+ },
212
+ );
213
+
214
+ expect(finalResult.itemsProcessed).toBeGreaterThan(0);
215
+ });
216
+ ```
217
+
218
+ **Key Points**:
219
+
220
+ - `post` callback runs after predicate succeeds
221
+ - Receives the final result
222
+ - Can transform or log results
223
+ - Return value becomes final `recurse` result
224
+
225
+ ### Example 5: UI Testing Scenarios
226
+
227
+ **Context**: Wait for UI elements to reach a specific state through polling.
228
+
229
+ **Implementation**:
230
+
231
+ ```typescript
232
+ test('table data loads', async ({ page, recurse }) => {
233
+ await page.goto('/reports');
234
+
235
+ // Poll for table rows to appear
236
+ await recurse(
237
+ async () => page.locator('table tbody tr').count(),
238
+ (count) => count >= 10, // Wait for at least 10 rows
239
+ {
240
+ timeout: 15000,
241
+ interval: 500,
242
+ log: 'Waiting for table data to load',
243
+ },
244
+ );
245
+
246
+ // Now safe to interact with table
247
+ await page.locator('table tbody tr').first().click();
248
+ });
249
+ ```
250
+
251
+ ### Example 6: Event-Based Systems (Kafka/Message Queues)
252
+
253
+ **Context**: Testing eventual consistency with message queue processing.
254
+
255
+ **Implementation**:
256
+
257
+ ```typescript
258
+ test('kafka event processed', async ({ recurse, apiRequest }) => {
259
+ // Trigger action that publishes Kafka event
260
+ await apiRequest({
261
+ method: 'POST',
262
+ path: '/api/orders',
263
+ body: { productId: 'ABC123', quantity: 2 },
264
+ });
265
+
266
+ // Poll for downstream effect of Kafka consumer processing
267
+ const inventoryResult = await recurse(
268
+ () => apiRequest({ method: 'GET', path: '/api/inventory/ABC123' }),
269
+ (res) => {
270
+ // Assumes test fixture seeds inventory at 100; in production tests,
271
+ // fetch baseline first and assert: expect(res.body.available).toBe(baseline - 2)
272
+ expect(res.body.available).toBeLessThanOrEqual(98);
273
+ },
274
+ {
275
+ timeout: 30000, // Kafka processing may take time
276
+ interval: 1000,
277
+ log: 'Waiting for Kafka event to be processed',
278
+ },
279
+ );
280
+
281
+ expect(inventoryResult.body.lastOrderId).toBeDefined();
282
+ });
283
+ ```
284
+
285
+ ### Example 7: Integration with API Request (Common Pattern)
286
+
287
+ **Context**: Most common use case - polling API endpoints for state changes.
288
+
289
+ **Implementation**:
290
+
291
+ ```typescript
292
+ import { test } from '@seontechnologies/playwright-utils/fixtures';
293
+
294
+ test('end-to-end polling', async ({ apiRequest, recurse }) => {
295
+ // Trigger async operation
296
+ const { body: createResp } = await apiRequest({
297
+ method: 'POST',
298
+ path: '/api/data-import',
299
+ body: { source: 's3://bucket/data.csv' },
300
+ });
301
+
302
+ // Poll until import completes
303
+ const importResult = await recurse(
304
+ () => apiRequest({ method: 'GET', path: `/api/data-import/${createResp.importId}` }),
305
+ (response) => {
306
+ const { status, rowsImported } = response.body;
307
+ return status === 'completed' && rowsImported > 0;
308
+ },
309
+ {
310
+ timeout: 120000, // 2 minutes for large imports
311
+ interval: 5000, // Check every 5 seconds
312
+ log: `Polling import ${createResp.importId}`,
313
+ },
314
+ );
315
+
316
+ expect(importResult.body.rowsImported).toBeGreaterThan(1000);
317
+ expect(importResult.body.errors).toHaveLength(0);
318
+ });
319
+ ```
320
+
321
+ **Key Points**:
322
+
323
+ - Combine `apiRequest` + `recurse` for API polling
324
+ - Both from `@seontechnologies/playwright-utils/fixtures`
325
+ - Complex predicates with multiple conditions
326
+ - Logging shows polling progress in test reports
327
+
328
+ ## API Reference
329
+
330
+ ### RecurseOptions
331
+
332
+ | Option | Type | Default | Description |
333
+ | ---------- | ------------------ | ----------- | ------------------------------------ |
334
+ | `timeout` | `number` | `30000` | Maximum time to wait (ms) |
335
+ | `interval` | `number` | `1000` | Time between polls (ms) |
336
+ | `log` | `string` | `undefined` | Message logged on each poll |
337
+ | `error` | `string` | `undefined` | Custom error message for timeout |
338
+ | `post` | `(result: T) => R` | `undefined` | Callback after successful poll |
339
+ | `delay` | `number` | `0` | Initial delay before first poll (ms) |
340
+
341
+ ### Error Types
342
+
343
+ | Error Type | When Thrown | Properties |
344
+ | ----------------------- | --------------------------------------- | ---------------------------------------- |
345
+ | `RecurseTimeoutError` | Predicate never passed within timeout | `lastCommandValue`, `lastPredicateError` |
346
+ | `RecurseCommandError` | Command function threw an error | `cause` (original error) |
347
+ | `RecursePredicateError` | Predicate threw (not assertion failure) | `cause` (original error) |
348
+
349
+ ## Comparison with Vanilla Playwright
350
+
351
+ | Vanilla Playwright | recurse Utility |
352
+ | ----------------------------------------------------------------- | ------------------------------------------------------------------------- |
353
+ | `await expect.poll(() => { ... }, { timeout: 30000 }).toBe(true)` | `await recurse(() => { ... }, (val) => val === true, { timeout: 30000 })` |
354
+ | No logging | Built-in log option |
355
+ | Generic timeout errors | Categorized errors (timeout/command/predicate) |
356
+ | No post-poll hooks | `post` callback support |
357
+
358
+ ## When to Use
359
+
360
+ **Use recurse for:**
361
+
362
+ - Background job completion
363
+ - Webhook/event processing
364
+ - Database eventual consistency
365
+ - Cache propagation
366
+ - State machine transitions
367
+
368
+ **Stick with vanilla expect.poll for:**
369
+
370
+ - Simple UI element visibility (use `expect(locator).toBeVisible()`)
371
+ - Single-property checks
372
+ - Cases where logging isn't needed
373
+
374
+ ## Related Fragments
375
+
376
+ - `api-testing-patterns.md` - Comprehensive pure API testing patterns
377
+ - `api-request.md` - Combine for API endpoint polling
378
+ - `overview.md` - Fixture composition patterns
379
+ - `fixtures-composition.md` - Using with mergeTests
380
+ - `contract-testing.md` - Contract testing with async verification
381
+
382
+ ## Anti-Patterns
383
+
384
+ **DON'T use hard waits instead of polling:**
385
+
386
+ ```typescript
387
+ await page.click('#export');
388
+ await page.waitForTimeout(5000); // Arbitrary wait
389
+ expect(await page.textContent('#status')).toBe('Ready');
390
+ ```
391
+
392
+ **DO poll for actual condition:**
393
+
394
+ ```typescript
395
+ await page.click('#export');
396
+ await recurse(
397
+ () => page.textContent('#status'),
398
+ (status) => status === 'Ready',
399
+ { timeout: 10000 },
400
+ );
401
+ ```
402
+
403
+ **DON'T poll too frequently:**
404
+
405
+ ```typescript
406
+ await recurse(
407
+ () => apiRequest({ method: 'GET', path: '/status' }),
408
+ (res) => res.body.ready,
409
+ { interval: 100 }, // Hammers API every 100ms!
410
+ );
411
+ ```
412
+
413
+ **DO use reasonable interval for API calls:**
414
+
415
+ ```typescript
416
+ await recurse(
417
+ () => apiRequest({ method: 'GET', path: '/status' }),
418
+ (res) => res.body.ready,
419
+ { interval: 2000 }, // Check every 2 seconds (reasonable)
420
+ );
421
+ ```