ma-agents 2.19.2 → 2.20.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (571) hide show
  1. package/agents.code-workspace +11 -0
  2. package/bin/cli.js +250 -151
  3. package/docs/architecture.md +284 -0
  4. package/docs/development-guide.md +122 -0
  5. package/docs/index.md +48 -0
  6. package/docs/project-overview.md +56 -0
  7. package/docs/project-scan-report.json +50 -0
  8. package/docs/source-tree-analysis.md +84 -0
  9. package/docs/validation/bundled-installation-validation.md +52 -0
  10. package/lib/bmad-cache/bmb/.markdownlint-cli2.yaml +35 -0
  11. package/lib/bmad-cache/bmb/.nvmrc +1 -0
  12. package/lib/bmad-cache/bmb/.prettierignore +9 -0
  13. package/lib/bmad-cache/bmb/CNAME +1 -0
  14. package/lib/bmad-cache/bmb/LICENSE +30 -0
  15. package/lib/bmad-cache/bmb/README.md +63 -0
  16. package/lib/bmad-cache/bmb/eslint.config.mjs +141 -0
  17. package/lib/bmad-cache/bmb/package-lock.json +15283 -0
  18. package/lib/bmad-cache/bmb/package.json +96 -0
  19. package/lib/bmad-cache/bmb/prettier.config.mjs +32 -0
  20. package/lib/bmad-cache/bmb/samples/bmad-agent-dream-weaver/bmad-manifest.json +62 -0
  21. package/lib/bmad-cache/bmb/samples/bmad-agent-dream-weaver/scripts/recall_metrics.py +229 -0
  22. package/lib/bmad-cache/bmb/samples/bmad-agent-dream-weaver/scripts/seed_tracker.py +156 -0
  23. package/lib/bmad-cache/bmb/samples/bmad-agent-dream-weaver/scripts/symbol_stats.py +162 -0
  24. package/lib/bmad-cache/bmb/samples/bmad-agent-dream-weaver/scripts/tests/test_recall_metrics.py +115 -0
  25. package/lib/bmad-cache/bmb/samples/bmad-agent-dream-weaver/scripts/tests/test_seed_tracker.py +140 -0
  26. package/lib/bmad-cache/bmb/samples/bmad-agent-dream-weaver/scripts/tests/test_symbol_stats.py +113 -0
  27. package/lib/bmad-cache/bmb/samples/bmad-excalidraw/bmad-manifest.json +18 -0
  28. package/lib/bmad-cache/bmb/samples/bmad-excalidraw/scripts/generate_excalidraw.py +605 -0
  29. package/lib/bmad-cache/bmb/samples/bmad-excalidraw/scripts/tests/test_generate_excalidraw.py +360 -0
  30. package/lib/bmad-cache/bmb/samples/bmad-excalidraw/scripts/tests/test_validate_excalidraw.py +246 -0
  31. package/lib/bmad-cache/bmb/samples/bmad-excalidraw/scripts/validate_excalidraw.py +264 -0
  32. package/lib/bmad-cache/bmb/src/module-help.csv +7 -0
  33. package/lib/bmad-cache/bmb/src/module.yaml +20 -0
  34. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/bmad-manifest.json +24 -0
  35. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/bmad-skill-manifest.yaml +1 -0
  36. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/bmad-manifest-schema.json +103 -0
  37. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/generate-html-report.py +1002 -0
  38. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/manifest.py +420 -0
  39. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/prepass-execution-deps.py +368 -0
  40. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/prepass-prompt-metrics.py +476 -0
  41. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/prepass-structure-capabilities.py +636 -0
  42. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/scan-path-standards.py +253 -0
  43. package/lib/bmad-cache/bmb/src/skills/bmad-agent-builder/scripts/scan-scripts.py +745 -0
  44. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/bmad-manifest.json +23 -0
  45. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/bmad-skill-manifest.yaml +1 -0
  46. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/bmad-manifest-schema.json +103 -0
  47. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/generate-html-report.py +1002 -0
  48. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/manifest.py +420 -0
  49. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/prepass-execution-deps.py +313 -0
  50. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/prepass-prompt-metrics.py +285 -0
  51. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/prepass-workflow-integrity.py +485 -0
  52. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/scan-path-standards.py +213 -0
  53. package/lib/bmad-cache/bmb/src/skills/bmad-workflow-builder/scripts/scan-scripts.py +745 -0
  54. package/lib/bmad-cache/bmb/tools/build-docs.mjs +448 -0
  55. package/lib/bmad-cache/bmb/tools/validate-file-refs.mjs +657 -0
  56. package/lib/bmad-cache/bmb/website/astro.config.mjs +134 -0
  57. package/lib/bmad-cache/bmb/website/public/favicon.ico +0 -0
  58. package/lib/bmad-cache/bmb/website/public/img/bmad-dark.png +0 -0
  59. package/lib/bmad-cache/bmb/website/public/img/bmad-light.png +0 -0
  60. package/lib/bmad-cache/bmb/website/src/components/Banner.astro +56 -0
  61. package/lib/bmad-cache/bmb/website/src/components/Header.astro +94 -0
  62. package/lib/bmad-cache/bmb/website/src/components/MobileMenuFooter.astro +33 -0
  63. package/lib/bmad-cache/bmb/website/src/content/config.ts +6 -0
  64. package/lib/bmad-cache/bmb/website/src/content/docs +1 -0
  65. package/lib/bmad-cache/bmb/website/src/lib/site-url.mjs +25 -0
  66. package/lib/bmad-cache/bmb/website/src/rehype-base-paths.js +88 -0
  67. package/lib/bmad-cache/bmb/website/src/rehype-markdown-links.js +117 -0
  68. package/lib/bmad-cache/bmb/website/src/styles/custom.css +484 -0
  69. package/lib/bmad-cache/cache-manifest.json +30 -0
  70. package/lib/bmad-cache/cis/.markdownlint-cli2.yaml +35 -0
  71. package/lib/bmad-cache/cis/.nvmrc +1 -0
  72. package/lib/bmad-cache/cis/.prettierignore +9 -0
  73. package/lib/bmad-cache/cis/CNAME +1 -0
  74. package/lib/bmad-cache/cis/LICENSE +26 -0
  75. package/lib/bmad-cache/cis/README.md +105 -0
  76. package/lib/bmad-cache/cis/eslint.config.mjs +141 -0
  77. package/lib/bmad-cache/cis/package.json +92 -0
  78. package/lib/bmad-cache/cis/prettier.config.mjs +32 -0
  79. package/lib/bmad-cache/cis/src/agents/brainstorming-coach.agent.yaml +21 -0
  80. package/lib/bmad-cache/cis/src/agents/creative-problem-solver.agent.yaml +21 -0
  81. package/lib/bmad-cache/cis/src/agents/design-thinking-coach.agent.yaml +21 -0
  82. package/lib/bmad-cache/cis/src/agents/innovation-strategist.agent.yaml +21 -0
  83. package/lib/bmad-cache/cis/src/agents/presentation-master.agent.yaml +53 -0
  84. package/lib/bmad-cache/cis/src/agents/storyteller/storyteller.agent.yaml +25 -0
  85. package/lib/bmad-cache/cis/src/module-help.csv +6 -0
  86. package/lib/bmad-cache/cis/src/module.yaml +27 -0
  87. package/lib/bmad-cache/cis/src/teams/creative-squad.yaml +7 -0
  88. package/lib/bmad-cache/cis/src/teams/default-party.csv +12 -0
  89. package/lib/bmad-cache/cis/src/workflows/README.md +175 -0
  90. package/lib/bmad-cache/cis/src/workflows/bmad-cis-design-thinking/bmad-skill-manifest.yaml +1 -0
  91. package/lib/bmad-cache/cis/src/workflows/bmad-cis-design-thinking/design-methods.csv +31 -0
  92. package/lib/bmad-cache/cis/src/workflows/bmad-cis-innovation-strategy/bmad-skill-manifest.yaml +1 -0
  93. package/lib/bmad-cache/cis/src/workflows/bmad-cis-innovation-strategy/innovation-frameworks.csv +31 -0
  94. package/lib/bmad-cache/cis/src/workflows/bmad-cis-problem-solving/bmad-skill-manifest.yaml +1 -0
  95. package/lib/bmad-cache/cis/src/workflows/bmad-cis-problem-solving/solving-methods.csv +31 -0
  96. package/lib/bmad-cache/cis/src/workflows/bmad-cis-storytelling/bmad-skill-manifest.yaml +1 -0
  97. package/lib/bmad-cache/cis/src/workflows/bmad-cis-storytelling/story-types.csv +26 -0
  98. package/lib/bmad-cache/cis/tools/build-docs.mjs +448 -0
  99. package/lib/bmad-cache/cis/website/astro.config.mjs +134 -0
  100. package/lib/bmad-cache/cis/website/public/favicon.ico +0 -0
  101. package/lib/bmad-cache/cis/website/public/img/bmad-dark.png +0 -0
  102. package/lib/bmad-cache/cis/website/public/img/bmad-light.png +0 -0
  103. package/lib/bmad-cache/cis/website/src/components/Banner.astro +56 -0
  104. package/lib/bmad-cache/cis/website/src/components/Header.astro +94 -0
  105. package/lib/bmad-cache/cis/website/src/components/MobileMenuFooter.astro +33 -0
  106. package/lib/bmad-cache/cis/website/src/content/config.ts +6 -0
  107. package/lib/bmad-cache/cis/website/src/content/docs +1 -0
  108. package/lib/bmad-cache/cis/website/src/lib/site-url.mjs +25 -0
  109. package/lib/bmad-cache/cis/website/src/rehype-base-paths.js +88 -0
  110. package/lib/bmad-cache/cis/website/src/rehype-markdown-links.js +117 -0
  111. package/lib/bmad-cache/cis/website/src/styles/custom.css +484 -0
  112. package/lib/bmad-cache/gds/.markdownlint-cli2.yaml +35 -0
  113. package/lib/bmad-cache/gds/.nvmrc +1 -0
  114. package/lib/bmad-cache/gds/.prettierignore +9 -0
  115. package/lib/bmad-cache/gds/CNAME +1 -0
  116. package/lib/bmad-cache/gds/LICENSE +26 -0
  117. package/lib/bmad-cache/gds/README.md +121 -0
  118. package/lib/bmad-cache/gds/eslint.config.mjs +141 -0
  119. package/lib/bmad-cache/gds/package.json +92 -0
  120. package/lib/bmad-cache/gds/prettier.config.mjs +32 -0
  121. package/lib/bmad-cache/gds/src/agents/game-architect.agent.yaml +44 -0
  122. package/lib/bmad-cache/gds/src/agents/game-designer.agent.yaml +45 -0
  123. package/lib/bmad-cache/gds/src/agents/game-dev.agent.yaml +49 -0
  124. package/lib/bmad-cache/gds/src/agents/game-qa.agent.yaml +63 -0
  125. package/lib/bmad-cache/gds/src/agents/game-scrum-master.agent.yaml +52 -0
  126. package/lib/bmad-cache/gds/src/agents/game-solo-dev.agent.yaml +53 -0
  127. package/lib/bmad-cache/gds/src/agents/tech-writer/tech-writer.agent.yaml +45 -0
  128. package/lib/bmad-cache/gds/src/gametest/qa-index.csv +18 -0
  129. package/lib/bmad-cache/gds/src/module-help.csv +35 -0
  130. package/lib/bmad-cache/gds/src/module.yaml +71 -0
  131. package/lib/bmad-cache/gds/src/teams/default-party.csv +12 -0
  132. package/lib/bmad-cache/gds/src/teams/team-gamedev.yaml +29 -0
  133. package/lib/bmad-cache/gds/src/workflows/1-preproduction/brainstorm-game/bmad-skill-manifest.yaml +3 -0
  134. package/lib/bmad-cache/gds/src/workflows/1-preproduction/brainstorm-game/game-brain-methods.csv +26 -0
  135. package/lib/bmad-cache/gds/src/workflows/1-preproduction/game-brief/bmad-skill-manifest.yaml +3 -0
  136. package/lib/bmad-cache/gds/src/workflows/1-preproduction/research/bmad-skill-manifest.yaml +9 -0
  137. package/lib/bmad-cache/gds/src/workflows/1-preproduction/research/gds-domain-research/bmad-skill-manifest.yaml +1 -0
  138. package/lib/bmad-cache/gds/src/workflows/2-design/create-prd/bmad-skill-manifest.yaml +14 -0
  139. package/lib/bmad-cache/gds/src/workflows/2-design/create-prd/data/domain-complexity.csv +15 -0
  140. package/lib/bmad-cache/gds/src/workflows/2-design/create-prd/data/project-types.csv +11 -0
  141. package/lib/bmad-cache/gds/src/workflows/2-design/gdd/bmad-skill-manifest.yaml +3 -0
  142. package/lib/bmad-cache/gds/src/workflows/2-design/gdd/game-types.csv +25 -0
  143. package/lib/bmad-cache/gds/src/workflows/2-design/gds-create-ux-design/bmad-skill-manifest.yaml +1 -0
  144. package/lib/bmad-cache/gds/src/workflows/2-design/narrative/bmad-skill-manifest.yaml +3 -0
  145. package/lib/bmad-cache/gds/src/workflows/3-technical/check-implementation-readiness/bmad-skill-manifest.yaml +3 -0
  146. package/lib/bmad-cache/gds/src/workflows/3-technical/create-epics-and-stories/bmad-skill-manifest.yaml +3 -0
  147. package/lib/bmad-cache/gds/src/workflows/3-technical/game-architecture/architecture-patterns.yaml +507 -0
  148. package/lib/bmad-cache/gds/src/workflows/3-technical/game-architecture/bmad-skill-manifest.yaml +3 -0
  149. package/lib/bmad-cache/gds/src/workflows/3-technical/game-architecture/decision-catalog.yaml +340 -0
  150. package/lib/bmad-cache/gds/src/workflows/3-technical/game-architecture/engine-mcps.yaml +270 -0
  151. package/lib/bmad-cache/gds/src/workflows/3-technical/game-architecture/pattern-categories.csv +13 -0
  152. package/lib/bmad-cache/gds/src/workflows/3-technical/generate-project-context/bmad-skill-manifest.yaml +3 -0
  153. package/lib/bmad-cache/gds/src/workflows/4-production/code-review/bmad-skill-manifest.yaml +3 -0
  154. package/lib/bmad-cache/gds/src/workflows/4-production/correct-course/bmad-skill-manifest.yaml +3 -0
  155. package/lib/bmad-cache/gds/src/workflows/4-production/gds-create-story/bmad-skill-manifest.yaml +1 -0
  156. package/lib/bmad-cache/gds/src/workflows/4-production/gds-dev-story/bmad-skill-manifest.yaml +1 -0
  157. package/lib/bmad-cache/gds/src/workflows/4-production/retrospective/bmad-skill-manifest.yaml +3 -0
  158. package/lib/bmad-cache/gds/src/workflows/4-production/sprint-planning/bmad-skill-manifest.yaml +3 -0
  159. package/lib/bmad-cache/gds/src/workflows/4-production/sprint-planning/sprint-status-template.yaml +55 -0
  160. package/lib/bmad-cache/gds/src/workflows/4-production/sprint-status/bmad-skill-manifest.yaml +3 -0
  161. package/lib/bmad-cache/gds/src/workflows/document-project/bmad-skill-manifest.yaml +3 -0
  162. package/lib/bmad-cache/gds/src/workflows/document-project/documentation-requirements.csv +12 -0
  163. package/lib/bmad-cache/gds/src/workflows/document-project/templates/project-scan-report-schema.json +160 -0
  164. package/lib/bmad-cache/gds/src/workflows/gametest/automate/bmad-skill-manifest.yaml +3 -0
  165. package/lib/bmad-cache/gds/src/workflows/gametest/e2e-scaffold/bmad-skill-manifest.yaml +3 -0
  166. package/lib/bmad-cache/gds/src/workflows/gametest/performance/bmad-skill-manifest.yaml +3 -0
  167. package/lib/bmad-cache/gds/src/workflows/gametest/playtest-plan/bmad-skill-manifest.yaml +3 -0
  168. package/lib/bmad-cache/gds/src/workflows/gametest/test-design/bmad-skill-manifest.yaml +3 -0
  169. package/lib/bmad-cache/gds/src/workflows/gametest/test-framework/bmad-skill-manifest.yaml +3 -0
  170. package/lib/bmad-cache/gds/src/workflows/gametest/test-review/bmad-skill-manifest.yaml +3 -0
  171. package/lib/bmad-cache/gds/src/workflows/gds-quick-flow/gds-quick-dev/bmad-skill-manifest.yaml +4 -0
  172. package/lib/bmad-cache/gds/src/workflows/gds-quick-flow/gds-quick-dev-new-preview/bmad-skill-manifest.yaml +4 -0
  173. package/lib/bmad-cache/gds/src/workflows/gds-quick-flow/quick-spec/bmad-skill-manifest.yaml +3 -0
  174. package/lib/bmad-cache/gds/tools/build-docs.mjs +450 -0
  175. package/lib/bmad-cache/gds/website/astro.config.mjs +134 -0
  176. package/lib/bmad-cache/gds/website/public/favicon.ico +0 -0
  177. package/lib/bmad-cache/gds/website/public/img/bmad-dark.png +0 -0
  178. package/lib/bmad-cache/gds/website/public/img/bmad-light.png +0 -0
  179. package/lib/bmad-cache/gds/website/src/components/Banner.astro +56 -0
  180. package/lib/bmad-cache/gds/website/src/components/Header.astro +94 -0
  181. package/lib/bmad-cache/gds/website/src/components/MobileMenuFooter.astro +33 -0
  182. package/lib/bmad-cache/gds/website/src/content/config.ts +6 -0
  183. package/lib/bmad-cache/gds/website/src/content/docs +1 -0
  184. package/lib/bmad-cache/gds/website/src/lib/site-url.mjs +25 -0
  185. package/lib/bmad-cache/gds/website/src/rehype-base-paths.js +88 -0
  186. package/lib/bmad-cache/gds/website/src/rehype-markdown-links.js +117 -0
  187. package/lib/bmad-cache/gds/website/src/styles/custom.css +484 -0
  188. package/lib/bmad-cache/tea/.coderabbit.yaml +40 -0
  189. package/lib/bmad-cache/tea/.husky/pre-commit +20 -0
  190. package/lib/bmad-cache/tea/.markdownlint-cli2.yaml +36 -0
  191. package/lib/bmad-cache/tea/.nvmrc +1 -0
  192. package/lib/bmad-cache/tea/.prettierignore +9 -0
  193. package/lib/bmad-cache/tea/CHANGELOG.md +253 -0
  194. package/lib/bmad-cache/tea/CONTRIBUTING.md +268 -0
  195. package/lib/bmad-cache/tea/LICENSE +26 -0
  196. package/lib/bmad-cache/tea/README.md +371 -0
  197. package/lib/bmad-cache/tea/SECURITY.md +85 -0
  198. package/lib/bmad-cache/tea/docs/404.md +20 -0
  199. package/lib/bmad-cache/tea/docs/MIGRATION.md +488 -0
  200. package/lib/bmad-cache/tea/docs/explanation/engagement-models.md +767 -0
  201. package/lib/bmad-cache/tea/docs/explanation/fixture-architecture.md +484 -0
  202. package/lib/bmad-cache/tea/docs/explanation/knowledge-base-system.md +601 -0
  203. package/lib/bmad-cache/tea/docs/explanation/network-first-patterns.md +884 -0
  204. package/lib/bmad-cache/tea/docs/explanation/risk-based-testing.md +628 -0
  205. package/lib/bmad-cache/tea/docs/explanation/step-file-architecture.md +599 -0
  206. package/lib/bmad-cache/tea/docs/explanation/subagent-architecture.md +189 -0
  207. package/lib/bmad-cache/tea/docs/explanation/tea-overview.md +474 -0
  208. package/lib/bmad-cache/tea/docs/explanation/test-quality-standards.md +965 -0
  209. package/lib/bmad-cache/tea/docs/explanation/testing-as-engineering.md +115 -0
  210. package/lib/bmad-cache/tea/docs/glossary/index.md +160 -0
  211. package/lib/bmad-cache/tea/docs/how-to/brownfield/use-tea-for-enterprise.md +571 -0
  212. package/lib/bmad-cache/tea/docs/how-to/brownfield/use-tea-with-existing-tests.md +631 -0
  213. package/lib/bmad-cache/tea/docs/how-to/customization/configure-browser-automation.md +243 -0
  214. package/lib/bmad-cache/tea/docs/how-to/customization/integrate-playwright-utils.md +846 -0
  215. package/lib/bmad-cache/tea/docs/how-to/workflows/run-atdd.md +464 -0
  216. package/lib/bmad-cache/tea/docs/how-to/workflows/run-automate.md +693 -0
  217. package/lib/bmad-cache/tea/docs/how-to/workflows/run-nfr-assess.md +731 -0
  218. package/lib/bmad-cache/tea/docs/how-to/workflows/run-test-design.md +144 -0
  219. package/lib/bmad-cache/tea/docs/how-to/workflows/run-test-review.md +634 -0
  220. package/lib/bmad-cache/tea/docs/how-to/workflows/run-trace.md +959 -0
  221. package/lib/bmad-cache/tea/docs/how-to/workflows/setup-ci.md +763 -0
  222. package/lib/bmad-cache/tea/docs/how-to/workflows/setup-test-framework.md +122 -0
  223. package/lib/bmad-cache/tea/docs/how-to/workflows/teach-me-testing.md +302 -0
  224. package/lib/bmad-cache/tea/docs/index.md +74 -0
  225. package/lib/bmad-cache/tea/docs/reference/commands.md +353 -0
  226. package/lib/bmad-cache/tea/docs/reference/configuration.md +1122 -0
  227. package/lib/bmad-cache/tea/docs/reference/knowledge-base.md +404 -0
  228. package/lib/bmad-cache/tea/docs/reference/troubleshooting.md +788 -0
  229. package/lib/bmad-cache/tea/docs/tutorials/learn-testing-tea-academy.md +266 -0
  230. package/lib/bmad-cache/tea/docs/tutorials/tea-lite-quickstart.md +465 -0
  231. package/lib/bmad-cache/tea/eslint.config.mjs +141 -0
  232. package/lib/bmad-cache/tea/package-lock.json +16046 -0
  233. package/lib/bmad-cache/tea/package.json +118 -0
  234. package/lib/bmad-cache/tea/prettier.config.mjs +32 -0
  235. package/lib/bmad-cache/tea/src/agents/tea.agent.yaml +67 -0
  236. package/lib/bmad-cache/tea/src/module-help.csv +10 -0
  237. package/lib/bmad-cache/tea/src/module.yaml +299 -0
  238. package/lib/bmad-cache/tea/src/teams/default-party.csv +2 -0
  239. package/lib/bmad-cache/tea/src/testarch/knowledge/adr-quality-readiness-checklist.md +377 -0
  240. package/lib/bmad-cache/tea/src/testarch/knowledge/api-request.md +563 -0
  241. package/lib/bmad-cache/tea/src/testarch/knowledge/api-testing-patterns.md +915 -0
  242. package/lib/bmad-cache/tea/src/testarch/knowledge/auth-session.md +548 -0
  243. package/lib/bmad-cache/tea/src/testarch/knowledge/burn-in.md +273 -0
  244. package/lib/bmad-cache/tea/src/testarch/knowledge/ci-burn-in.md +717 -0
  245. package/lib/bmad-cache/tea/src/testarch/knowledge/component-tdd.md +486 -0
  246. package/lib/bmad-cache/tea/src/testarch/knowledge/contract-testing.md +1050 -0
  247. package/lib/bmad-cache/tea/src/testarch/knowledge/data-factories.md +500 -0
  248. package/lib/bmad-cache/tea/src/testarch/knowledge/email-auth.md +721 -0
  249. package/lib/bmad-cache/tea/src/testarch/knowledge/error-handling.md +725 -0
  250. package/lib/bmad-cache/tea/src/testarch/knowledge/feature-flags.md +750 -0
  251. package/lib/bmad-cache/tea/src/testarch/knowledge/file-utils.md +456 -0
  252. package/lib/bmad-cache/tea/src/testarch/knowledge/fixture-architecture.md +401 -0
  253. package/lib/bmad-cache/tea/src/testarch/knowledge/fixtures-composition.md +382 -0
  254. package/lib/bmad-cache/tea/src/testarch/knowledge/intercept-network-call.md +426 -0
  255. package/lib/bmad-cache/tea/src/testarch/knowledge/log.md +426 -0
  256. package/lib/bmad-cache/tea/src/testarch/knowledge/network-error-monitor.md +401 -0
  257. package/lib/bmad-cache/tea/src/testarch/knowledge/network-first.md +486 -0
  258. package/lib/bmad-cache/tea/src/testarch/knowledge/network-recorder.md +527 -0
  259. package/lib/bmad-cache/tea/src/testarch/knowledge/nfr-criteria.md +670 -0
  260. package/lib/bmad-cache/tea/src/testarch/knowledge/overview.md +286 -0
  261. package/lib/bmad-cache/tea/src/testarch/knowledge/pact-consumer-di.md +310 -0
  262. package/lib/bmad-cache/tea/src/testarch/knowledge/pact-consumer-framework-setup.md +635 -0
  263. package/lib/bmad-cache/tea/src/testarch/knowledge/pact-mcp.md +204 -0
  264. package/lib/bmad-cache/tea/src/testarch/knowledge/pactjs-utils-consumer-helpers.md +270 -0
  265. package/lib/bmad-cache/tea/src/testarch/knowledge/pactjs-utils-overview.md +216 -0
  266. package/lib/bmad-cache/tea/src/testarch/knowledge/pactjs-utils-provider-verifier.md +315 -0
  267. package/lib/bmad-cache/tea/src/testarch/knowledge/pactjs-utils-request-filter.md +224 -0
  268. package/lib/bmad-cache/tea/src/testarch/knowledge/playwright-cli.md +165 -0
  269. package/lib/bmad-cache/tea/src/testarch/knowledge/playwright-config.md +730 -0
  270. package/lib/bmad-cache/tea/src/testarch/knowledge/probability-impact.md +601 -0
  271. package/lib/bmad-cache/tea/src/testarch/knowledge/recurse.md +421 -0
  272. package/lib/bmad-cache/tea/src/testarch/knowledge/risk-governance.md +615 -0
  273. package/lib/bmad-cache/tea/src/testarch/knowledge/selective-testing.md +732 -0
  274. package/lib/bmad-cache/tea/src/testarch/knowledge/selector-resilience.md +527 -0
  275. package/lib/bmad-cache/tea/src/testarch/knowledge/test-healing-patterns.md +644 -0
  276. package/lib/bmad-cache/tea/src/testarch/knowledge/test-levels-framework.md +473 -0
  277. package/lib/bmad-cache/tea/src/testarch/knowledge/test-priorities-matrix.md +373 -0
  278. package/lib/bmad-cache/tea/src/testarch/knowledge/test-quality.md +664 -0
  279. package/lib/bmad-cache/tea/src/testarch/knowledge/timing-debugging.md +372 -0
  280. package/lib/bmad-cache/tea/src/testarch/knowledge/visual-debugging.md +524 -0
  281. package/lib/bmad-cache/tea/src/testarch/tea-index.csv +43 -0
  282. package/lib/bmad-cache/tea/src/workflows/testarch/README.md +74 -0
  283. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/SKILL.md +6 -0
  284. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/bmad-skill-manifest.yaml +1 -0
  285. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/checklist.md +197 -0
  286. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/data/curriculum.yaml +129 -0
  287. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/data/quiz-questions.yaml +206 -0
  288. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/data/role-paths.yaml +136 -0
  289. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/data/session-content-map.yaml +207 -0
  290. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/data/tea-resources-index.yaml +359 -0
  291. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/instructions.md +130 -0
  292. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-01-init.md +235 -0
  293. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-01b-continue.md +147 -0
  294. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-02-assess.md +258 -0
  295. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-03-session-menu.md +219 -0
  296. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-01.md +460 -0
  297. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-02.md +465 -0
  298. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-03.md +301 -0
  299. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-04.md +234 -0
  300. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-05.md +234 -0
  301. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-06.md +209 -0
  302. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-04-session-07.md +212 -0
  303. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-c/step-05-completion.md +339 -0
  304. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-e/step-e-01-assess-workflow.md +141 -0
  305. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-e/step-e-02-apply-edits.md +122 -0
  306. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/steps-v/step-v-01-validate.md +263 -0
  307. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/templates/certificate-template.md +86 -0
  308. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/templates/progress-template.yaml +95 -0
  309. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/templates/session-notes-template.md +83 -0
  310. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/workflow-plan-teach-me-testing.md +950 -0
  311. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-teach-me-testing/workflow.md +90 -0
  312. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/SKILL.md +6 -0
  313. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/atdd-checklist-template.md +371 -0
  314. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/bmad-skill-manifest.yaml +1 -0
  315. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/checklist.md +374 -0
  316. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/instructions.md +45 -0
  317. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-01-preflight-and-context.md +226 -0
  318. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-01b-resume.md +96 -0
  319. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-02-generation-mode.md +125 -0
  320. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-03-test-strategy.md +110 -0
  321. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-04-generate-tests.md +334 -0
  322. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-04a-subagent-api-failing.md +286 -0
  323. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-04b-subagent-e2e-failing.md +244 -0
  324. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-04c-aggregate.md +370 -0
  325. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-c/step-05-validate-and-complete.md +106 -0
  326. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-e/step-01-assess.md +65 -0
  327. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-e/step-02-apply-edit.md +60 -0
  328. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/steps-v/step-01-validate.md +67 -0
  329. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/validation-report-20260127-095021.md +73 -0
  330. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/validation-report-20260127-102401.md +116 -0
  331. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/workflow-plan.md +21 -0
  332. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/workflow.md +41 -0
  333. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-atdd/workflow.yaml +46 -0
  334. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/SKILL.md +6 -0
  335. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/bmad-skill-manifest.yaml +1 -0
  336. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/checklist.md +611 -0
  337. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/instructions.md +50 -0
  338. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-01-preflight-and-context.md +237 -0
  339. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-01b-resume.md +94 -0
  340. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-02-identify-targets.md +169 -0
  341. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-03-generate-tests.md +394 -0
  342. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-03a-subagent-api.md +263 -0
  343. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-03b-subagent-backend.md +246 -0
  344. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-03b-subagent-e2e.md +213 -0
  345. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-03c-aggregate.md +393 -0
  346. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-c/step-04-validate-and-summarize.md +106 -0
  347. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-e/step-01-assess.md +65 -0
  348. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-e/step-02-apply-edit.md +60 -0
  349. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/steps-v/step-01-validate.md +67 -0
  350. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/validation-report-20260127-095021.md +72 -0
  351. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/validation-report-20260127-102401.md +114 -0
  352. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/workflow-plan.md +20 -0
  353. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/workflow.md +41 -0
  354. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-automate/workflow.yaml +53 -0
  355. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/SKILL.md +6 -0
  356. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/azure-pipelines-template.yaml +155 -0
  357. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/bmad-skill-manifest.yaml +1 -0
  358. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/checklist.md +289 -0
  359. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/github-actions-template.yaml +328 -0
  360. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/gitlab-ci-template.yaml +158 -0
  361. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/harness-pipeline-template.yaml +159 -0
  362. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/instructions.md +45 -0
  363. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/jenkins-pipeline-template.groovy +129 -0
  364. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-c/step-01-preflight.md +158 -0
  365. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-c/step-01b-resume.md +110 -0
  366. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-c/step-02-generate-pipeline.md +279 -0
  367. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-c/step-03-configure-quality-gates.md +135 -0
  368. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-c/step-04-validate-and-summary.md +92 -0
  369. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-e/step-01-assess.md +65 -0
  370. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-e/step-02-apply-edit.md +60 -0
  371. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/steps-v/step-01-validate.md +81 -0
  372. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/validation-report-20260127-095021.md +72 -0
  373. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/validation-report-20260127-102401.md +114 -0
  374. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/workflow-plan.md +20 -0
  375. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/workflow.md +41 -0
  376. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-ci/workflow.yaml +48 -0
  377. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/SKILL.md +6 -0
  378. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/bmad-skill-manifest.yaml +1 -0
  379. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/checklist.md +345 -0
  380. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/instructions.md +45 -0
  381. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-c/step-01-preflight.md +132 -0
  382. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-c/step-01b-resume.md +116 -0
  383. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-c/step-02-select-framework.md +117 -0
  384. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-c/step-03-scaffold-framework.md +323 -0
  385. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-c/step-04-docs-and-scripts.md +105 -0
  386. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-c/step-05-validate-and-summary.md +93 -0
  387. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-e/step-01-assess.md +65 -0
  388. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-e/step-02-apply-edit.md +60 -0
  389. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/steps-v/step-01-validate.md +67 -0
  390. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/validation-report-20260127-095021.md +73 -0
  391. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/validation-report-20260127-102401.md +116 -0
  392. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/workflow-plan.md +22 -0
  393. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/workflow.md +41 -0
  394. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-framework/workflow.yaml +48 -0
  395. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/SKILL.md +6 -0
  396. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/bmad-skill-manifest.yaml +1 -0
  397. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/checklist.md +407 -0
  398. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/instructions.md +43 -0
  399. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/nfr-report-template.md +470 -0
  400. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-01-load-context.md +138 -0
  401. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-01b-resume.md +106 -0
  402. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-02-define-thresholds.md +107 -0
  403. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-03-gather-evidence.md +108 -0
  404. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-04-evaluate-and-score.md +254 -0
  405. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-04a-subagent-security.md +138 -0
  406. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-04b-subagent-performance.md +84 -0
  407. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-04c-subagent-reliability.md +85 -0
  408. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-04d-subagent-scalability.md +88 -0
  409. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-04e-aggregate-nfr.md +264 -0
  410. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-c/step-05-generate-report.md +108 -0
  411. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-e/step-01-assess.md +65 -0
  412. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-e/step-02-apply-edit.md +60 -0
  413. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/steps-v/step-01-validate.md +67 -0
  414. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/validation-report-20260127-095021.md +73 -0
  415. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/validation-report-20260127-102401.md +116 -0
  416. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/workflow-plan.md +19 -0
  417. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/workflow.md +41 -0
  418. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-nfr/workflow.yaml +48 -0
  419. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/SKILL.md +6 -0
  420. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/bmad-skill-manifest.yaml +1 -0
  421. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/checklist.md +464 -0
  422. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/instructions.md +105 -0
  423. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-c/step-01-detect-mode.md +134 -0
  424. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-c/step-01b-resume.md +102 -0
  425. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-c/step-02-load-context.md +242 -0
  426. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-c/step-03-risk-and-testability.md +110 -0
  427. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-c/step-04-coverage-plan.md +123 -0
  428. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-c/step-05-generate-output.md +222 -0
  429. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-e/step-01-assess.md +65 -0
  430. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-e/step-02-apply-edit.md +60 -0
  431. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/steps-v/step-01-validate.md +67 -0
  432. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/test-design-architecture-template.md +230 -0
  433. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/test-design-handoff-template.md +70 -0
  434. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/test-design-qa-template.md +396 -0
  435. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/test-design-template.md +344 -0
  436. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/validation-report-20260127-095021.md +73 -0
  437. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/validation-report-20260127-102401.md +116 -0
  438. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/workflow-plan.md +22 -0
  439. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/workflow.md +41 -0
  440. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-design/workflow.yaml +77 -0
  441. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/SKILL.md +6 -0
  442. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/bmad-skill-manifest.yaml +1 -0
  443. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/checklist.md +475 -0
  444. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/instructions.md +45 -0
  445. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-01-load-context.md +197 -0
  446. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-01b-resume.md +104 -0
  447. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-02-discover-tests.md +113 -0
  448. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-03-quality-evaluation.md +274 -0
  449. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-03a-subagent-determinism.md +214 -0
  450. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-03b-subagent-isolation.md +125 -0
  451. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-03c-subagent-maintainability.md +102 -0
  452. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-03e-subagent-performance.md +117 -0
  453. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-03f-aggregate-scores.md +277 -0
  454. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-c/step-04-generate-report.md +111 -0
  455. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-e/step-01-assess.md +65 -0
  456. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-e/step-02-apply-edit.md +60 -0
  457. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/steps-v/step-01-validate.md +67 -0
  458. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/test-review-template.md +387 -0
  459. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/validation-report-20260127-095021.md +72 -0
  460. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/validation-report-20260127-102401.md +114 -0
  461. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/workflow-plan.md +18 -0
  462. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/workflow.md +41 -0
  463. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-test-review/workflow.yaml +48 -0
  464. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/SKILL.md +6 -0
  465. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/bmad-skill-manifest.yaml +1 -0
  466. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/checklist.md +647 -0
  467. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/instructions.md +43 -0
  468. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-c/step-01-load-context.md +105 -0
  469. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-c/step-01b-resume.md +102 -0
  470. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-c/step-02-discover-tests.md +112 -0
  471. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-c/step-03-map-criteria.md +97 -0
  472. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-c/step-04-analyze-gaps.md +421 -0
  473. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-c/step-05-gate-decision.md +266 -0
  474. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-e/step-01-assess.md +65 -0
  475. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-e/step-02-apply-edit.md +60 -0
  476. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/steps-v/step-01-validate.md +67 -0
  477. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/trace-template.md +708 -0
  478. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/validation-report-20260127-095021.md +73 -0
  479. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/validation-report-20260127-102401.md +116 -0
  480. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/workflow-plan.md +21 -0
  481. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/workflow.md +41 -0
  482. package/lib/bmad-cache/tea/src/workflows/testarch/bmad-testarch-trace/workflow.yaml +56 -0
  483. package/lib/bmad-cache/tea/test/README.md +23 -0
  484. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/critical-actions/actions-as-string.agent.yaml +27 -0
  485. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/critical-actions/empty-string-in-actions.agent.yaml +30 -0
  486. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu/empty-menu.agent.yaml +22 -0
  487. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu/missing-menu.agent.yaml +20 -0
  488. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-commands/empty-command-target.agent.yaml +25 -0
  489. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-commands/no-command-target.agent.yaml +24 -0
  490. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-triggers/camel-case.agent.yaml +25 -0
  491. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-triggers/compound-invalid-format.agent.yaml +25 -0
  492. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-triggers/compound-mismatched-kebab.agent.yaml +25 -0
  493. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-triggers/duplicate-triggers.agent.yaml +31 -0
  494. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-triggers/empty-trigger.agent.yaml +25 -0
  495. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-triggers/leading-asterisk.agent.yaml +25 -0
  496. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-triggers/snake-case.agent.yaml +25 -0
  497. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/menu-triggers/trigger-with-spaces.agent.yaml +25 -0
  498. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/metadata/empty-module-string.agent.yaml +26 -0
  499. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/metadata/empty-name.agent.yaml +24 -0
  500. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/metadata/extra-metadata-fields.agent.yaml +27 -0
  501. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/metadata/missing-id.agent.yaml +23 -0
  502. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/persona/empty-principles-array.agent.yaml +24 -0
  503. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/persona/empty-string-in-principles.agent.yaml +27 -0
  504. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/persona/extra-persona-fields.agent.yaml +27 -0
  505. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/persona/missing-role.agent.yaml +24 -0
  506. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/prompts/empty-content.agent.yaml +29 -0
  507. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/prompts/extra-prompt-fields.agent.yaml +31 -0
  508. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/prompts/missing-content.agent.yaml +28 -0
  509. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/prompts/missing-id.agent.yaml +28 -0
  510. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/top-level/empty-file.agent.yaml +5 -0
  511. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/top-level/extra-top-level-keys.agent.yaml +28 -0
  512. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/top-level/missing-agent-key.agent.yaml +11 -0
  513. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/yaml-errors/invalid-indentation.agent.yaml +19 -0
  514. package/lib/bmad-cache/tea/test/fixtures/agent-schema/invalid/yaml-errors/malformed-yaml.agent.yaml +18 -0
  515. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/critical-actions/empty-critical-actions.agent.yaml +24 -0
  516. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/critical-actions/no-critical-actions.agent.yaml +22 -0
  517. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/critical-actions/valid-critical-actions.agent.yaml +27 -0
  518. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/menu/multiple-menu-items.agent.yaml +31 -0
  519. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/menu/single-menu-item.agent.yaml +22 -0
  520. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/menu-commands/all-command-types.agent.yaml +38 -0
  521. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/menu-commands/multiple-commands.agent.yaml +24 -0
  522. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/menu-triggers/compound-triggers.agent.yaml +31 -0
  523. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/menu-triggers/kebab-case-triggers.agent.yaml +34 -0
  524. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/metadata/core-agent-with-module.agent.yaml +24 -0
  525. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/metadata/empty-module-name-in-path.agent.yaml +24 -0
  526. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/metadata/malformed-path-treated-as-core.agent.yaml +24 -0
  527. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/metadata/module-agent-correct.agent.yaml +24 -0
  528. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/metadata/module-agent-missing-module.agent.yaml +23 -0
  529. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/metadata/wrong-module-value.agent.yaml +24 -0
  530. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/persona/complete-persona.agent.yaml +24 -0
  531. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/prompts/empty-prompts.agent.yaml +24 -0
  532. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/prompts/no-prompts.agent.yaml +22 -0
  533. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/prompts/valid-prompts-minimal.agent.yaml +28 -0
  534. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/prompts/valid-prompts-with-description.agent.yaml +30 -0
  535. package/lib/bmad-cache/tea/test/fixtures/agent-schema/valid/top-level/minimal-core-agent.agent.yaml +24 -0
  536. package/lib/bmad-cache/tea/test/schema/agent.js +491 -0
  537. package/lib/bmad-cache/tea/test/test-agent-schema.js +387 -0
  538. package/lib/bmad-cache/tea/test/test-installation-components.js +214 -0
  539. package/lib/bmad-cache/tea/test/test-knowledge-base.js +208 -0
  540. package/lib/bmad-cache/tea/test/unit-test-schema.js +133 -0
  541. package/lib/bmad-cache/tea/test/validate-agent-schema.js +110 -0
  542. package/lib/bmad-cache/tea/tools/build-docs.js +575 -0
  543. package/lib/bmad-cache/tea/tools/fix-doc-links.js +288 -0
  544. package/lib/bmad-cache/tea/tools/schema/agent.js +491 -0
  545. package/lib/bmad-cache/tea/tools/validate-agent-schema.js +111 -0
  546. package/lib/bmad-cache/tea/tools/validate-doc-links.js +371 -0
  547. package/lib/bmad-cache/tea/tools/validate-tea-workflow-descriptions.js +122 -0
  548. package/lib/bmad-cache/tea/tools/verify-paths.js +100 -0
  549. package/lib/bmad-cache/tea/website/README.md +137 -0
  550. package/lib/bmad-cache/tea/website/astro.config.mjs +179 -0
  551. package/lib/bmad-cache/tea/website/package-lock.json +6856 -0
  552. package/lib/bmad-cache/tea/website/package.json +24 -0
  553. package/lib/bmad-cache/tea/website/public/favicon.ico +0 -0
  554. package/lib/bmad-cache/tea/website/public/img/tea-logo.svg +7 -0
  555. package/lib/bmad-cache/tea/website/public/robots.txt +37 -0
  556. package/lib/bmad-cache/tea/website/src/components/Banner.astro +59 -0
  557. package/lib/bmad-cache/tea/website/src/components/Header.astro +121 -0
  558. package/lib/bmad-cache/tea/website/src/components/MobileMenuFooter.astro +53 -0
  559. package/lib/bmad-cache/tea/website/src/content/config.ts +6 -0
  560. package/lib/bmad-cache/tea/website/src/content/docs +1 -0
  561. package/lib/bmad-cache/tea/website/src/lib/site-url.js +25 -0
  562. package/lib/bmad-cache/tea/website/src/pages/404.astro +11 -0
  563. package/lib/bmad-cache/tea/website/src/rehype-base-paths.js +89 -0
  564. package/lib/bmad-cache/tea/website/src/rehype-markdown-links.js +117 -0
  565. package/lib/bmad-cache/tea/website/src/styles/custom.css +499 -0
  566. package/lib/bmad-cache/tea/website/tsconfig.json +9 -0
  567. package/lib/bmad.js +76 -10
  568. package/lib/installer.js +23 -1
  569. package/package.json +4 -2
  570. package/scripts/build-bmad-cache.js +288 -0
  571. package/test/yes-flag.test.js +193 -0
@@ -0,0 +1,657 @@
1
+ /**
2
+ * File Reference Validator for bmad-builder
3
+ *
4
+ * Validates cross-file references in BMB source files (agents, workflows, steps).
5
+ * Catches broken file paths, missing referenced files, and absolute path leaks.
6
+ * Auto-detects own module code from module.yaml and skips external module refs.
7
+ *
8
+ * What it checks:
9
+ * - {project-root}/_bmad/bmb/ references → src/ files
10
+ * - Relative path references (./file.md, ../data/file.csv)
11
+ * - Frontmatter path variables (nextStepFile, stepTemplate, etc.)
12
+ * - CSV workflow-file column → source files
13
+ * - Absolute path leak detection (/Users/, /home/, C:\)
14
+ *
15
+ * What it skips:
16
+ * - External module refs ({project-root}/_bmad/core/, bmm/, etc.)
17
+ * - Relative refs resolving outside src/ (../../../../core/)
18
+ * - Install-generated files (config.yaml, docs/ KBs)
19
+ * - Template placeholders ([N], [name], [template])
20
+ * - Runtime variables ({output_folder}, {bmad_builder_output_folder}, etc.)
21
+ * - {{mustache}} template variables
22
+ * - Lines with <!-- validate-file-refs:ignore --> comment
23
+ * - Lines after <!-- validate-file-refs:ignore-next-line --> comment
24
+ * - Refs with EXAMPLE- or invalid- filename prefix in data/ directories
25
+ *
26
+ * Usage:
27
+ * node tools/validate-file-refs.mjs # Warning mode (exit 0)
28
+ * node tools/validate-file-refs.mjs --strict # Fail on issues (exit 1)
29
+ * node tools/validate-file-refs.mjs --verbose # Show all checked refs
30
+ * node tools/validate-file-refs.mjs --include-external # Show external refs as INFO
31
+ */
32
+
33
+ import fs from 'node:fs';
34
+ import path from 'node:path';
35
+ import { fileURLToPath } from 'node:url';
36
+ import yaml from 'yaml';
37
+ import { parse as parseCsv } from 'csv-parse/sync';
38
+
39
+ const __filename = fileURLToPath(import.meta.url);
40
+ const __dirname = path.dirname(__filename);
41
+
42
+ // --- CLI Parsing ---
43
+
44
+ const flags = new Set(process.argv.slice(2).filter((a) => a.startsWith('--')));
45
+ const VERBOSE = flags.has('--verbose');
46
+ const STRICT = flags.has('--strict');
47
+ const INCLUDE_EXTERNAL = flags.has('--include-external');
48
+
49
+ const PROJECT_ROOT = path.resolve(__dirname, '..');
50
+ const SRC_DIR = path.join(PROJECT_ROOT, 'src');
51
+
52
+ // --- Constants ---
53
+
54
+ const SCAN_EXTENSIONS = new Set(['.yaml', '.yml', '.md', '.csv']);
55
+ const SKIP_DIRS = new Set(['node_modules', '_module-installer', '.git']);
56
+
57
+ // Install-generated paths that don't exist in the source tree
58
+ const INSTALL_ONLY_PATHS = ['docs/'];
59
+ const INSTALL_GENERATED_FILES = ['config.yaml'];
60
+
61
+ // Runtime variables that cannot be resolved statically
62
+ const UNRESOLVABLE_VARS = [
63
+ '{output_folder}',
64
+ '{value}',
65
+ '{timestamp}',
66
+ '{config_source}:',
67
+ '{installed_path}',
68
+ '{shared_path}',
69
+ '{planning_artifacts}',
70
+ '{research_topic}',
71
+ '{user_name}',
72
+ '{communication_language}',
73
+ '{bmad_builder_output_folder}',
74
+ '{new_workflow_name}',
75
+ '{module_code}',
76
+ '{workflow_name}',
77
+ '{project_name}',
78
+ '{datetime}',
79
+ '{date}',
80
+ '{count}',
81
+ '{epic_number}',
82
+ '{sidecar-folder}',
83
+ '{targetWorkflowPath}',
84
+ '{workflow_folder_path}',
85
+ '{module_output_folder}',
86
+ ];
87
+
88
+ // Frontmatter keys that contain file paths
89
+ const FRONTMATTER_PATH_KEYS = new Set([
90
+ 'nextStepFile',
91
+ 'thisStepFile',
92
+ 'nextStep',
93
+ 'continueStepFile',
94
+ 'skipToStepFile',
95
+ 'altStepFile',
96
+ 'workflowFile',
97
+ 'stepTemplate',
98
+ 'agentTemplate',
99
+ 'agentArch',
100
+ 'menuHandlingStandards',
101
+ 'outputFormatStandards',
102
+ 'frontmatterStandards',
103
+ 'brainstormContext',
104
+ 'workflowExamples',
105
+ 'templateFile',
106
+ 'outputFile',
107
+ 'workflowPlanFile',
108
+ 'validationReportFile',
109
+ 'advancedElicitationTask',
110
+ 'partyModeWorkflow',
111
+ ]);
112
+
113
+ // Regex patterns
114
+ const PROJECT_ROOT_REF = /\{project-root\}\/_bmad\/([^\s'"<>})\]`]+)/g;
115
+ const RELATIVE_PATH_QUOTED = /['"](\.\.\/?[^'"]+\.(?:md|yaml|yml|xml|json|csv|txt))['"]/g;
116
+ const RELATIVE_PATH_DOT = /['"](\.\/[^'"]+\.(?:md|yaml|yml|xml|json|csv|txt))['"]/g;
117
+ const ABS_PATH_LEAK = /(?:\/Users\/|\/home\/|[A-Z]:\\)/;
118
+
119
+ // Inline suppression comments
120
+ const IGNORE_COMMENT = /<!--\s*validate-file-refs:ignore\s*-->/;
121
+ const IGNORE_NEXT_LINE_COMMENT = /<!--\s*validate-file-refs:ignore-next-line\s*-->/;
122
+
123
+ // Data directory example filename prefixes (auto-skipped)
124
+ const DATA_DIR_EXAMPLE_PREFIXES = ['EXAMPLE-', 'invalid-'];
125
+
126
+ // --- Helpers ---
127
+
128
+ function escapeAnnotation(str) {
129
+ return str.replaceAll('%', '%25').replaceAll('\r', '%0D').replaceAll('\n', '%0A');
130
+ }
131
+
132
+ function stripCodeBlocks(content) {
133
+ return content.replaceAll(/```[\s\S]*?```/g, (m) => m.replaceAll(/[^\n]/g, ''));
134
+ }
135
+
136
+ function offsetToLine(content, offset) {
137
+ let line = 1;
138
+ for (let i = 0; i < offset && i < content.length; i++) {
139
+ if (content[i] === '\n') line++;
140
+ }
141
+ return line;
142
+ }
143
+
144
+ /**
145
+ * Detect whether a reference contains [bracketed] template placeholders.
146
+ * Matches [non-numeric] content like [N], [name], [template], [output].
147
+ * Does NOT match [1], [2] (numbered list items).
148
+ */
149
+ function isBracketedPlaceholder(refStr) {
150
+ return /\[[^\]]*[A-Za-z][^\]]*\]/.test(refStr);
151
+ }
152
+
153
+ /**
154
+ * Check if a line should be ignored via inline suppression comments.
155
+ * Supports <!-- validate-file-refs:ignore --> on the same line
156
+ * and <!-- validate-file-refs:ignore-next-line --> on the previous line.
157
+ */
158
+ function isLineIgnored(contentLines, lineNumber) {
159
+ const idx = lineNumber - 1;
160
+ if (idx < 0 || idx >= contentLines.length) return false;
161
+ if (IGNORE_COMMENT.test(contentLines[idx])) return true;
162
+ if (idx > 0 && IGNORE_NEXT_LINE_COMMENT.test(contentLines[idx - 1])) return true;
163
+ return false;
164
+ }
165
+
166
+ /**
167
+ * Check if a reference uses a documentation-example filename convention
168
+ * inside a data/ directory. Files prefixed with EXAMPLE- or invalid-
169
+ * are treated as illustrative and skipped.
170
+ */
171
+ function isDataDirExample(filePath, refStr) {
172
+ if (!filePath.includes('/data/')) return false;
173
+ const basename = path.basename(refStr);
174
+ return DATA_DIR_EXAMPLE_PREFIXES.some((prefix) => basename.startsWith(prefix));
175
+ }
176
+
177
+ /**
178
+ * Check if a reference string is statically resolvable.
179
+ */
180
+ function isResolvable(refStr) {
181
+ if (refStr.includes('{{')) return false;
182
+ if (isBracketedPlaceholder(refStr)) return false;
183
+ for (const v of UNRESOLVABLE_VARS) {
184
+ if (refStr.includes(v)) return false;
185
+ }
186
+ return true;
187
+ }
188
+
189
+ /**
190
+ * Check if a cleaned path is install-generated (not in source tree).
191
+ */
192
+ function isInstallGenerated(cleanedPath) {
193
+ for (const prefix of INSTALL_ONLY_PATHS) {
194
+ if (cleanedPath.startsWith(prefix)) return true;
195
+ }
196
+ const basename = path.basename(cleanedPath);
197
+ for (const generated of INSTALL_GENERATED_FILES) {
198
+ if (basename === generated) return true;
199
+ }
200
+ return false;
201
+ }
202
+
203
+ /**
204
+ * Read module.yaml to detect the module's own code (e.g., "bmb").
205
+ */
206
+ function detectModuleCode(srcDir) {
207
+ const moduleYamlPath = path.join(srcDir, 'module.yaml');
208
+ if (!fs.existsSync(moduleYamlPath)) return null;
209
+ try {
210
+ const content = fs.readFileSync(moduleYamlPath, 'utf-8');
211
+ const data = yaml.parse(content);
212
+ return data?.code || null;
213
+ } catch {
214
+ return null;
215
+ }
216
+ }
217
+
218
+ /**
219
+ * Check if a {project-root}/_bmad/ ref is external (different module).
220
+ */
221
+ function isExternalRef(refStr, moduleCode) {
222
+ if (!moduleCode) return false;
223
+ const match = refStr.match(/\{project-root\}\/_bmad\/([^/]+)\//);
224
+ if (!match) return false;
225
+ const refModule = match[1];
226
+ // _memory, _config are special framework paths, not external modules
227
+ if (refModule.startsWith('_')) return false;
228
+ return refModule !== moduleCode;
229
+ }
230
+
231
+ /**
232
+ * Map {project-root}/_bmad/bmb/ paths to src/ paths.
233
+ * Returns null for install-generated or external refs.
234
+ */
235
+ function mapInstalledToSource(refPath, moduleCode) {
236
+ const match = refPath.match(/\{project-root\}\/_bmad\/([^/]+)\/(.*)/);
237
+ if (!match) return null;
238
+
239
+ const refModule = match[1];
240
+ const subPath = match[2];
241
+
242
+ // External module — skip
243
+ if (moduleCode && refModule !== moduleCode) return null;
244
+
245
+ // Install-generated — skip
246
+ if (isInstallGenerated(subPath)) return null;
247
+
248
+ return path.join(SRC_DIR, subPath);
249
+ }
250
+
251
+ // --- File Discovery ---
252
+
253
+ function getSourceFiles(dir) {
254
+ const files = [];
255
+ function walk(currentDir) {
256
+ const entries = fs.readdirSync(currentDir, { withFileTypes: true });
257
+ for (const entry of entries) {
258
+ if (SKIP_DIRS.has(entry.name)) continue;
259
+ const fullPath = path.join(currentDir, entry.name);
260
+ if (entry.isDirectory()) {
261
+ walk(fullPath);
262
+ } else if (entry.isFile() && SCAN_EXTENSIONS.has(path.extname(entry.name))) {
263
+ files.push(fullPath);
264
+ }
265
+ }
266
+ }
267
+ walk(dir);
268
+ return files;
269
+ }
270
+
271
+ // --- Reference Extraction ---
272
+
273
+ /**
274
+ * Extract references from YAML files.
275
+ */
276
+ function extractYamlRefs(filePath, content) {
277
+ const refs = [];
278
+ let doc;
279
+ try {
280
+ doc = yaml.parseDocument(content);
281
+ } catch {
282
+ return refs;
283
+ }
284
+
285
+ function checkValue(value, range, keyPath) {
286
+ if (typeof value !== 'string') return;
287
+ if (!isResolvable(value)) return;
288
+
289
+ const line = range ? offsetToLine(content, range[0]) : undefined;
290
+
291
+ // {project-root}/_bmad/ refs
292
+ const prMatch = value.match(/\{project-root\}\/_bmad\/[^\s'"<>})\]`]+/);
293
+ if (prMatch) {
294
+ refs.push({ file: filePath, raw: prMatch[0], type: 'project-root', line, key: keyPath });
295
+ }
296
+
297
+ // Relative paths
298
+ const relMatch = value.match(/^\.\.?\/[^\s'"<>})\]`]+\.(?:md|yaml|yml|xml|json|csv|txt)$/);
299
+ if (relMatch) {
300
+ refs.push({ file: filePath, raw: relMatch[0], type: 'relative', line, key: keyPath });
301
+ }
302
+ }
303
+
304
+ function walkNode(node, keyPath) {
305
+ if (!node) return;
306
+ if (yaml.isMap(node)) {
307
+ for (const item of node.items) {
308
+ const key = item.key && item.key.value !== undefined ? item.key.value : '?';
309
+ const childPath = keyPath ? `${keyPath}.${key}` : String(key);
310
+ walkNode(item.value, childPath);
311
+ }
312
+ } else if (yaml.isSeq(node)) {
313
+ for (const [i, item] of node.items.entries()) {
314
+ walkNode(item, `${keyPath}[${i}]`);
315
+ }
316
+ } else if (yaml.isScalar(node)) {
317
+ checkValue(node.value, node.range, keyPath);
318
+ }
319
+ }
320
+
321
+ walkNode(doc.contents, '');
322
+ return refs;
323
+ }
324
+
325
+ /**
326
+ * Extract references from markdown files (frontmatter + body).
327
+ */
328
+ function extractMarkdownRefs(filePath, content) {
329
+ const refs = [];
330
+
331
+ // Parse frontmatter
332
+ const fmMatch = content.match(/^---\n([\s\S]*?)\n---/);
333
+ if (fmMatch) {
334
+ try {
335
+ const fmData = yaml.parse(fmMatch[1]);
336
+ if (fmData && typeof fmData === 'object') {
337
+ for (const [key, value] of Object.entries(fmData)) {
338
+ if (typeof value !== 'string') continue;
339
+ if (!isResolvable(value)) continue;
340
+
341
+ if (FRONTMATTER_PATH_KEYS.has(key)) {
342
+ const line = offsetToLine(content, content.indexOf(`${key}:`));
343
+ if (value.includes('{project-root}/_bmad/')) {
344
+ refs.push({ file: filePath, raw: value, type: 'project-root', line, key });
345
+ } else if (value.startsWith('./') || value.startsWith('../')) {
346
+ refs.push({ file: filePath, raw: value, type: 'relative', line, key });
347
+ }
348
+ }
349
+ }
350
+ }
351
+ } catch {
352
+ // Unparseable frontmatter
353
+ }
354
+ }
355
+
356
+ // Body references (after stripping code blocks)
357
+ const stripped = stripCodeBlocks(content);
358
+
359
+ // {project-root}/_bmad/ refs in body text
360
+ PROJECT_ROOT_REF.lastIndex = 0;
361
+ let match;
362
+ while ((match = PROJECT_ROOT_REF.exec(stripped)) !== null) {
363
+ const raw = `{project-root}/_bmad/${match[1]}`;
364
+ if (!isResolvable(raw)) continue;
365
+ // Skip if already captured from frontmatter
366
+ if (refs.some((r) => r.raw === raw && r.file === filePath)) continue;
367
+ refs.push({
368
+ file: filePath,
369
+ raw,
370
+ type: 'project-root',
371
+ line: offsetToLine(stripped, match.index),
372
+ });
373
+ }
374
+
375
+ // Quoted relative paths in body
376
+ for (const regex of [RELATIVE_PATH_QUOTED, RELATIVE_PATH_DOT]) {
377
+ regex.lastIndex = 0;
378
+ while ((match = regex.exec(stripped)) !== null) {
379
+ const raw = match[1];
380
+ if (!isResolvable(raw)) continue;
381
+ if (refs.some((r) => r.raw === raw && r.file === filePath)) continue;
382
+ refs.push({
383
+ file: filePath,
384
+ raw,
385
+ type: 'relative',
386
+ line: offsetToLine(stripped, match.index),
387
+ });
388
+ }
389
+ }
390
+
391
+ return refs;
392
+ }
393
+
394
+ /**
395
+ * Extract workflow-file references from CSV files.
396
+ */
397
+ function extractCsvRefs(filePath, content) {
398
+ const refs = [];
399
+ let records;
400
+ try {
401
+ records = parseCsv(content, {
402
+ columns: true,
403
+ skip_empty_lines: true,
404
+ relax_column_count: true,
405
+ });
406
+ } catch {
407
+ return refs;
408
+ }
409
+
410
+ const firstRecord = records[0];
411
+ if (!firstRecord || !('workflow-file' in firstRecord)) return refs;
412
+
413
+ for (const [i, record] of records.entries()) {
414
+ const raw = record['workflow-file'];
415
+ if (!raw || raw.trim() === '') continue;
416
+ if (!isResolvable(raw)) continue;
417
+
418
+ const line = i + 2; // header + 0-based index + 1
419
+ // CSV uses bare _bmad/ prefix
420
+ refs.push({ file: filePath, raw, type: 'project-root', line });
421
+ }
422
+
423
+ return refs;
424
+ }
425
+
426
+ /**
427
+ * Detect absolute path leaks in file content.
428
+ */
429
+ function checkAbsolutePathLeaks(filePath, content) {
430
+ const leaks = [];
431
+ let ignoredCount = 0;
432
+ const stripped = stripCodeBlocks(content);
433
+ const lines = stripped.split('\n');
434
+ const originalLines = content.split('\n');
435
+
436
+ for (const [i, line] of lines.entries()) {
437
+ if (ABS_PATH_LEAK.test(line)) {
438
+ if (isLineIgnored(originalLines, i + 1)) {
439
+ ignoredCount++;
440
+ } else {
441
+ leaks.push({ file: filePath, line: i + 1, content: line.trim().slice(0, 100) });
442
+ }
443
+ }
444
+ }
445
+ return { leaks, ignoredCount };
446
+ }
447
+
448
+ // --- Reference Resolution ---
449
+
450
+ function resolveRef(ref, moduleCode) {
451
+ if (ref.type === 'project-root') {
452
+ // Handle bare _bmad/ prefix (from CSV)
453
+ let refPath = ref.raw;
454
+ if (!refPath.includes('{project-root}') && refPath.startsWith('_bmad/')) {
455
+ refPath = `{project-root}/${refPath}`;
456
+ }
457
+ return mapInstalledToSource(refPath, moduleCode);
458
+ }
459
+
460
+ if (ref.type === 'relative') {
461
+ const resolved = path.resolve(path.dirname(ref.file), ref.raw);
462
+ // Skip if resolves outside src/
463
+ if (!resolved.startsWith(SRC_DIR)) return null;
464
+ return resolved;
465
+ }
466
+
467
+ return null;
468
+ }
469
+
470
+ // --- Exports for testing ---
471
+
472
+ export const _testing = {
473
+ mapInstalledToSource,
474
+ isResolvable,
475
+ extractYamlRefs,
476
+ extractMarkdownRefs,
477
+ extractCsvRefs,
478
+ checkAbsolutePathLeaks,
479
+ detectModuleCode,
480
+ isExternalRef,
481
+ isBracketedPlaceholder,
482
+ isInstallGenerated,
483
+ isLineIgnored,
484
+ isDataDirExample,
485
+ resolveRef,
486
+ getSourceFiles,
487
+ stripCodeBlocks,
488
+ offsetToLine,
489
+ SRC_DIR,
490
+ PROJECT_ROOT,
491
+ };
492
+
493
+ // --- Main ---
494
+
495
+ const _isMain = process.argv[1] && path.resolve(process.argv[1]) === path.resolve(__filename);
496
+ if (_isMain) {
497
+ const moduleCode = detectModuleCode(SRC_DIR);
498
+ console.log(`\nValidating file references in: ${path.relative(process.cwd(), SRC_DIR)}/`);
499
+ console.log(`Mode: ${STRICT ? 'STRICT (exit 1 on issues)' : 'WARNING (exit 0)'}${VERBOSE ? ' + VERBOSE' : ''}`);
500
+ console.log(`Module: ${moduleCode || '(unknown)'}\n`);
501
+
502
+ const files = getSourceFiles(SRC_DIR);
503
+ console.log(`Files to scan: ${files.length}\n`);
504
+
505
+ let totalRefs = 0;
506
+ let brokenRefs = 0;
507
+ let totalLeaks = 0;
508
+ let externalRefs = 0;
509
+ let ignoredRefs = 0;
510
+ let filesWithIssues = 0;
511
+ const refsByType = { 'project-root': 0, relative: 0 };
512
+ const allIssues = [];
513
+
514
+ for (const filePath of files) {
515
+ const relativePath = path.relative(PROJECT_ROOT, filePath);
516
+ const content = fs.readFileSync(filePath, 'utf-8');
517
+ const ext = path.extname(filePath);
518
+ const contentLines = content.split('\n');
519
+
520
+ // Extract references by file type
521
+ let refs;
522
+ if (ext === '.yaml' || ext === '.yml') {
523
+ refs = extractYamlRefs(filePath, content);
524
+ } else if (ext === '.csv') {
525
+ refs = extractCsvRefs(filePath, content);
526
+ } else {
527
+ refs = extractMarkdownRefs(filePath, content);
528
+ }
529
+
530
+ // Filter inline-ignored and data-dir example refs
531
+ refs = refs.filter((ref) => {
532
+ if (ref.line && isLineIgnored(contentLines, ref.line)) {
533
+ ignoredRefs++;
534
+ return false;
535
+ }
536
+ if (isDataDirExample(filePath, ref.raw)) {
537
+ ignoredRefs++;
538
+ return false;
539
+ }
540
+ return true;
541
+ });
542
+
543
+ const broken = [];
544
+ const external = [];
545
+
546
+ for (const ref of refs) {
547
+ totalRefs++;
548
+ if (ref.type in refsByType) refsByType[ref.type]++;
549
+
550
+ // Check for external module refs
551
+ if (ref.type === 'project-root' && isExternalRef(ref.raw, moduleCode)) {
552
+ externalRefs++;
553
+ if (INCLUDE_EXTERNAL) {
554
+ external.push({ ref, module: ref.raw.match(/\{project-root\}\/_bmad\/([^/]+)\//)?.[1] });
555
+ }
556
+ continue;
557
+ }
558
+
559
+ const resolved = resolveRef(ref, moduleCode);
560
+ if (resolved === null) continue; // Skipped (install-generated, external, outside src)
561
+
562
+ if (!fs.existsSync(resolved)) {
563
+ broken.push({ ref, resolved: path.relative(PROJECT_ROOT, resolved) });
564
+ brokenRefs++;
565
+ }
566
+ }
567
+
568
+ // Absolute path leaks
569
+ const { leaks, ignoredCount: leakIgnored } = checkAbsolutePathLeaks(filePath, content);
570
+ totalLeaks += leaks.length;
571
+ ignoredRefs += leakIgnored;
572
+
573
+ const hasIssues = broken.length > 0 || leaks.length > 0;
574
+ const hasInfo = external.length > 0;
575
+
576
+ if (hasIssues) {
577
+ filesWithIssues++;
578
+ console.log(`\n${relativePath}`);
579
+
580
+ for (const { ref, resolved } of broken) {
581
+ const location = ref.line ? `line ${ref.line}` : ref.key ? `key: ${ref.key}` : '';
582
+ console.log(` [BROKEN] ${ref.raw}${location ? ` (${location})` : ''}`);
583
+ console.log(` Target not found: ${resolved}`);
584
+ allIssues.push({ file: relativePath, line: ref.line || 1, ref: ref.raw, issue: 'broken ref' });
585
+ if (process.env.GITHUB_ACTIONS) {
586
+ const line = ref.line || 1;
587
+ console.log(`::warning file=${relativePath},line=${line}::${escapeAnnotation(`Broken reference: ${ref.raw} → ${resolved}`)}`);
588
+ }
589
+ }
590
+
591
+ for (const leak of leaks) {
592
+ console.log(` [ABS-PATH] Line ${leak.line}: ${leak.content}`);
593
+ allIssues.push({ file: relativePath, line: leak.line, ref: leak.content, issue: 'abs-path' });
594
+ if (process.env.GITHUB_ACTIONS) {
595
+ console.log(`::warning file=${relativePath},line=${leak.line}::${escapeAnnotation(`Absolute path leak: ${leak.content}`)}`);
596
+ }
597
+ }
598
+ } else if (VERBOSE && refs.length > 0) {
599
+ console.log(` [OK] ${relativePath} (${refs.length} refs)`);
600
+ }
601
+
602
+ if (hasInfo) {
603
+ for (const { ref, module: mod } of external) {
604
+ console.log(` [INFO] External ref to ${mod}: ${ref.raw}`);
605
+ }
606
+ }
607
+ }
608
+
609
+ // Summary
610
+ const totalIssues = brokenRefs + totalLeaks;
611
+ console.log(`\n${'─'.repeat(60)}`);
612
+ console.log(`\nSummary:`);
613
+ console.log(` Files scanned: ${files.length}`);
614
+ console.log(` References checked: ${totalRefs}`);
615
+ console.log(` project-root refs: ${refsByType['project-root']}`);
616
+ console.log(` relative refs: ${refsByType.relative}`);
617
+ console.log(` External (skipped): ${externalRefs}`);
618
+ if (ignoredRefs > 0) {
619
+ console.log(` Suppressed (ignored): ${ignoredRefs}`);
620
+ }
621
+ console.log(` Broken references: ${brokenRefs}`);
622
+ console.log(` Absolute path leaks: ${totalLeaks}`);
623
+ console.log(
624
+ ` Total issues: ${totalIssues} / ${totalRefs} refs (${totalRefs > 0 ? ((totalIssues / totalRefs) * 100).toFixed(1) : 0}%)`,
625
+ );
626
+
627
+ const hasIssues = totalIssues > 0;
628
+
629
+ if (hasIssues) {
630
+ console.log(` Files affected: ${filesWithIssues}`);
631
+ if (STRICT) {
632
+ console.log(`\n [STRICT MODE] Exiting with failure.`);
633
+ } else {
634
+ console.log(`\n Run with --strict to treat warnings as errors.`);
635
+ }
636
+ } else {
637
+ console.log(`\n All file references valid!`);
638
+ }
639
+ console.log('');
640
+
641
+ // GHA step summary
642
+ if (process.env.GITHUB_STEP_SUMMARY) {
643
+ let summary = '## BMB File Reference Validation\n\n';
644
+ if (allIssues.length > 0) {
645
+ summary += '| File | Line | Reference | Issue |\n';
646
+ summary += '|------|------|-----------|-------|\n';
647
+ for (const iss of allIssues) {
648
+ summary += `| ${iss.file} | ${iss.line} | ${iss.ref} | ${iss.issue} |\n`;
649
+ }
650
+ summary += '\n';
651
+ }
652
+ summary += `**${files.length} files scanned, ${totalRefs} references checked, ${brokenRefs + totalLeaks} issues found**\n`;
653
+ fs.appendFileSync(process.env.GITHUB_STEP_SUMMARY, summary);
654
+ }
655
+
656
+ process.exit(hasIssues && STRICT ? 1 : 0);
657
+ }