gsd-pi 2.76.0 → 2.77.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 (536) hide show
  1. package/README.md +45 -25
  2. package/dist/claude-cli-check.js +32 -3
  3. package/dist/mcp-server.d.ts +7 -0
  4. package/dist/mcp-server.js +35 -1
  5. package/dist/onboarding.js +45 -0
  6. package/dist/resource-loader.d.ts +1 -1
  7. package/dist/resource-loader.js +2 -8
  8. package/dist/resources/agents/researcher.md +1 -1
  9. package/dist/resources/extensions/claude-code-cli/readiness.js +31 -8
  10. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +77 -17
  11. package/dist/resources/extensions/gsd/auto/loop.js +9 -0
  12. package/dist/resources/extensions/gsd/auto/phases.js +104 -11
  13. package/dist/resources/extensions/gsd/auto/run-unit.js +38 -2
  14. package/dist/resources/extensions/gsd/auto/session.js +22 -1
  15. package/dist/resources/extensions/gsd/auto-dispatch.js +16 -3
  16. package/dist/resources/extensions/gsd/auto-model-selection.js +53 -16
  17. package/dist/resources/extensions/gsd/auto-post-unit.js +25 -2
  18. package/dist/resources/extensions/gsd/auto-prompts.js +14 -0
  19. package/dist/resources/extensions/gsd/auto-recovery.js +32 -1
  20. package/dist/resources/extensions/gsd/auto-start.js +58 -57
  21. package/dist/resources/extensions/gsd/auto-verification.js +33 -0
  22. package/dist/resources/extensions/gsd/auto-worktree.js +51 -53
  23. package/dist/resources/extensions/gsd/auto.js +70 -28
  24. package/dist/resources/extensions/gsd/blocked-models.js +68 -0
  25. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +93 -1
  26. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +39 -9
  27. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +93 -0
  28. package/dist/resources/extensions/gsd/bootstrap/memory-tools.js +3 -0
  29. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +12 -0
  30. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +52 -6
  31. package/dist/resources/extensions/gsd/bootstrap/system-context.js +84 -23
  32. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +34 -2
  33. package/dist/resources/extensions/gsd/clean-root-preflight.js +93 -0
  34. package/dist/resources/extensions/gsd/commands-extract-learnings.js +54 -89
  35. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +968 -23
  36. package/dist/resources/extensions/gsd/compaction-snapshot.js +121 -0
  37. package/dist/resources/extensions/gsd/complexity-classifier.js +5 -3
  38. package/dist/resources/extensions/gsd/db-writer.js +88 -16
  39. package/dist/resources/extensions/gsd/doctor-git-checks.js +23 -29
  40. package/dist/resources/extensions/gsd/doctor-providers.js +51 -5
  41. package/dist/resources/extensions/gsd/ecosystem/gsd-extension-api.js +1 -0
  42. package/dist/resources/extensions/gsd/error-classifier.js +31 -3
  43. package/dist/resources/extensions/gsd/exec-history.js +120 -0
  44. package/dist/resources/extensions/gsd/exec-sandbox.js +258 -0
  45. package/dist/resources/extensions/gsd/gitignore.js +1 -0
  46. package/dist/resources/extensions/gsd/gsd-db.js +168 -23
  47. package/dist/resources/extensions/gsd/guided-flow.js +190 -1
  48. package/dist/resources/extensions/gsd/health-widget.js +4 -1
  49. package/dist/resources/extensions/gsd/hook-emitter.js +108 -0
  50. package/dist/resources/extensions/gsd/init-wizard.js +15 -1
  51. package/dist/resources/extensions/gsd/key-manager.js +28 -0
  52. package/dist/resources/extensions/gsd/memory-backfill.js +126 -0
  53. package/dist/resources/extensions/gsd/memory-store.js +19 -0
  54. package/dist/resources/extensions/gsd/model-router.js +36 -3
  55. package/dist/resources/extensions/gsd/pre-execution-checks.js +44 -9
  56. package/dist/resources/extensions/gsd/preferences-types.js +9 -0
  57. package/dist/resources/extensions/gsd/preferences-validation.js +83 -0
  58. package/dist/resources/extensions/gsd/preferences.js +17 -17
  59. package/dist/resources/extensions/gsd/prompt-loader.js +22 -7
  60. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +1 -1
  61. package/dist/resources/extensions/gsd/prompts/complete-slice.md +2 -2
  62. package/dist/resources/extensions/gsd/prompts/debug-diagnose.md +2 -0
  63. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +8 -0
  64. package/dist/resources/extensions/gsd/prompts/discuss.md +29 -2
  65. package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -2
  66. package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  67. package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -0
  68. package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -0
  69. package/dist/resources/extensions/gsd/safety/evidence-collector.js +96 -0
  70. package/dist/resources/extensions/gsd/safety/file-change-validator.js +13 -5
  71. package/dist/resources/extensions/gsd/safety/safety-harness.js +5 -1
  72. package/dist/resources/extensions/gsd/state.js +43 -4
  73. package/dist/resources/extensions/gsd/token-counter.js +22 -5
  74. package/dist/resources/extensions/gsd/tools/complete-milestone.js +16 -10
  75. package/dist/resources/extensions/gsd/tools/exec-search-tool.js +59 -0
  76. package/dist/resources/extensions/gsd/tools/exec-tool.js +126 -0
  77. package/dist/resources/extensions/gsd/tools/memory-tools.js +26 -1
  78. package/dist/resources/extensions/gsd/tools/resume-tool.js +23 -0
  79. package/dist/resources/extensions/gsd/uok/plan-v2.js +20 -3
  80. package/dist/resources/extensions/gsd/workflow-mcp.js +3 -0
  81. package/dist/resources/extensions/gsd/workflow-templates/spike.md +6 -0
  82. package/dist/resources/extensions/gsd/worktree-resolver.js +50 -10
  83. package/dist/resources/extensions/search-the-web/command-search-provider.js +5 -4
  84. package/dist/resources/extensions/search-the-web/native-search.js +45 -13
  85. package/dist/resources/skills/api-design/SKILL.md +190 -0
  86. package/dist/resources/skills/create-mcp-server/SKILL.md +121 -0
  87. package/dist/resources/skills/decompose-into-slices/SKILL.md +139 -0
  88. package/dist/resources/skills/dependency-upgrade/SKILL.md +158 -0
  89. package/dist/resources/skills/design-an-interface/SKILL.md +102 -0
  90. package/dist/resources/skills/forensics/SKILL.md +153 -0
  91. package/dist/resources/skills/grill-me/SKILL.md +93 -0
  92. package/dist/resources/skills/handoff/SKILL.md +121 -0
  93. package/dist/resources/skills/observability/SKILL.md +174 -0
  94. package/dist/resources/skills/security-review/SKILL.md +181 -0
  95. package/dist/resources/skills/spike-wrap-up/SKILL.md +138 -0
  96. package/dist/resources/skills/tdd/SKILL.md +112 -0
  97. package/dist/resources/skills/verify-before-complete/SKILL.md +98 -0
  98. package/dist/resources/skills/write-docs/SKILL.md +82 -0
  99. package/dist/resources/skills/write-milestone-brief/SKILL.md +135 -0
  100. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  101. package/dist/web/standalone/.next/BUILD_ID +1 -1
  102. package/dist/web/standalone/.next/app-path-routes-manifest.json +10 -10
  103. package/dist/web/standalone/.next/build-manifest.json +2 -2
  104. package/dist/web/standalone/.next/required-server-files.json +1 -1
  105. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  106. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  107. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  108. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  109. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  110. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  111. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  112. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  113. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  114. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  115. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  116. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  117. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  118. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  119. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  120. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  121. package/dist/web/standalone/.next/server/app/index.html +1 -1
  122. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  123. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  124. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  125. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  126. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  127. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  128. package/dist/web/standalone/.next/server/app-paths-manifest.json +10 -10
  129. package/dist/web/standalone/.next/server/chunks/6897.js +2 -2
  130. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  131. package/dist/web/standalone/.next/server/middleware-manifest.json +1 -1
  132. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  133. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  134. package/dist/web/standalone/server.js +1 -1
  135. package/dist/welcome-screen.js +6 -1
  136. package/dist/wizard.js +2 -0
  137. package/package.json +1 -1
  138. package/packages/daemon/package.json +2 -2
  139. package/packages/mcp-server/dist/remote-questions.d.ts +45 -0
  140. package/packages/mcp-server/dist/remote-questions.d.ts.map +1 -0
  141. package/packages/mcp-server/dist/remote-questions.js +732 -0
  142. package/packages/mcp-server/dist/remote-questions.js.map +1 -0
  143. package/packages/mcp-server/dist/server.d.ts +7 -0
  144. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  145. package/packages/mcp-server/dist/server.js +70 -8
  146. package/packages/mcp-server/dist/server.js.map +1 -1
  147. package/packages/mcp-server/dist/session-manager.d.ts +14 -0
  148. package/packages/mcp-server/dist/session-manager.d.ts.map +1 -1
  149. package/packages/mcp-server/dist/session-manager.js +49 -1
  150. package/packages/mcp-server/dist/session-manager.js.map +1 -1
  151. package/packages/mcp-server/dist/workflow-tools.d.ts +1 -1
  152. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  153. package/packages/mcp-server/dist/workflow-tools.js +163 -25
  154. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  155. package/packages/mcp-server/package.json +4 -3
  156. package/packages/mcp-server/src/mcp-server.test.ts +67 -0
  157. package/packages/mcp-server/src/remote-questions.test.ts +294 -0
  158. package/packages/mcp-server/src/remote-questions.ts +916 -0
  159. package/packages/mcp-server/src/server.ts +89 -14
  160. package/packages/mcp-server/src/session-manager.ts +43 -1
  161. package/packages/mcp-server/src/workflow-tools.test.ts +146 -1
  162. package/packages/mcp-server/src/workflow-tools.ts +215 -43
  163. package/packages/mcp-server/tsconfig.test.json +19 -0
  164. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  165. package/packages/native/package.json +1 -1
  166. package/packages/pi-agent-core/dist/agent-loop.js +12 -0
  167. package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
  168. package/packages/pi-agent-core/dist/types.d.ts +30 -0
  169. package/packages/pi-agent-core/dist/types.d.ts.map +1 -1
  170. package/packages/pi-agent-core/dist/types.js.map +1 -1
  171. package/packages/pi-agent-core/package.json +1 -1
  172. package/packages/pi-agent-core/src/agent-loop.ts +14 -0
  173. package/packages/pi-agent-core/src/types.ts +34 -0
  174. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
  175. package/packages/pi-ai/dist/models/custom.d.ts +38 -0
  176. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -1
  177. package/packages/pi-ai/dist/models/custom.js +41 -0
  178. package/packages/pi-ai/dist/models/custom.js.map +1 -1
  179. package/packages/pi-ai/dist/providers/anthropic-auth.test.js +1 -1
  180. package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
  181. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.d.ts +2 -0
  182. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.d.ts.map +1 -0
  183. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js +13 -0
  184. package/packages/pi-ai/dist/providers/anthropic-bearer-auth.test.js.map +1 -0
  185. package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
  186. package/packages/pi-ai/dist/providers/anthropic-shared.js +27 -4
  187. package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
  188. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  189. package/packages/pi-ai/dist/providers/anthropic.js +13 -4
  190. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  191. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts +2 -0
  192. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts.map +1 -0
  193. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +80 -0
  194. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -0
  195. package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
  196. package/packages/pi-ai/dist/providers/openai-completions.js +60 -15
  197. package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
  198. package/packages/pi-ai/dist/providers/simple-options.d.ts +10 -0
  199. package/packages/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
  200. package/packages/pi-ai/dist/providers/simple-options.js +16 -1
  201. package/packages/pi-ai/dist/providers/simple-options.js.map +1 -1
  202. package/packages/pi-ai/dist/providers/think-tag-parser.d.ts +17 -0
  203. package/packages/pi-ai/dist/providers/think-tag-parser.d.ts.map +1 -0
  204. package/packages/pi-ai/dist/providers/think-tag-parser.js +75 -0
  205. package/packages/pi-ai/dist/providers/think-tag-parser.js.map +1 -0
  206. package/packages/pi-ai/dist/providers/think-tag-parser.test.d.ts +2 -0
  207. package/packages/pi-ai/dist/providers/think-tag-parser.test.d.ts.map +1 -0
  208. package/packages/pi-ai/dist/providers/think-tag-parser.test.js +41 -0
  209. package/packages/pi-ai/dist/providers/think-tag-parser.test.js.map +1 -0
  210. package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  211. package/packages/pi-ai/dist/utils/oauth/github-copilot.js +12 -2
  212. package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
  213. package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js +164 -14
  214. package/packages/pi-ai/dist/utils/oauth/github-copilot.test.js.map +1 -1
  215. package/packages/pi-ai/dist/utils/oauth/google-antigravity.d.ts.map +1 -1
  216. package/packages/pi-ai/dist/utils/oauth/google-antigravity.js +15 -3
  217. package/packages/pi-ai/dist/utils/oauth/google-antigravity.js.map +1 -1
  218. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.d.ts +2 -0
  219. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.d.ts.map +1 -0
  220. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js +67 -0
  221. package/packages/pi-ai/dist/utils/oauth/google-antigravity.test.js.map +1 -0
  222. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.d.ts.map +1 -1
  223. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.js +16 -3
  224. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.js.map +1 -1
  225. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.d.ts +2 -0
  226. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.d.ts.map +1 -0
  227. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js +67 -0
  228. package/packages/pi-ai/dist/utils/oauth/google-gemini-cli.test.js.map +1 -0
  229. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts +2 -0
  230. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts.map +1 -0
  231. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js +289 -0
  232. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js.map +1 -0
  233. package/packages/pi-ai/package.json +1 -1
  234. package/packages/pi-ai/src/models/custom.ts +42 -0
  235. package/packages/pi-ai/src/providers/anthropic-auth.test.ts +1 -1
  236. package/packages/pi-ai/src/providers/anthropic-bearer-auth.test.ts +26 -0
  237. package/packages/pi-ai/src/providers/anthropic-shared.ts +26 -5
  238. package/packages/pi-ai/src/providers/anthropic.ts +15 -4
  239. package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +98 -0
  240. package/packages/pi-ai/src/providers/openai-completions.ts +57 -16
  241. package/packages/pi-ai/src/providers/simple-options.ts +17 -1
  242. package/packages/pi-ai/src/providers/think-tag-parser.test.ts +44 -0
  243. package/packages/pi-ai/src/providers/think-tag-parser.ts +94 -0
  244. package/packages/pi-ai/src/utils/oauth/github-copilot.test.ts +200 -23
  245. package/packages/pi-ai/src/utils/oauth/github-copilot.ts +12 -2
  246. package/packages/pi-ai/src/utils/oauth/google-antigravity.test.ts +84 -0
  247. package/packages/pi-ai/src/utils/oauth/google-antigravity.ts +15 -5
  248. package/packages/pi-ai/src/utils/oauth/google-gemini-cli.test.ts +84 -0
  249. package/packages/pi-ai/src/utils/oauth/google-gemini-cli.ts +16 -5
  250. package/packages/pi-ai/src/utils/oauth/oauth-providers.test.ts +363 -0
  251. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  252. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +3 -2
  253. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
  254. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -0
  255. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  256. package/packages/pi-coding-agent/dist/core/agent-session.js +32 -2
  257. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  258. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
  259. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
  260. package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
  261. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  262. package/packages/pi-coding-agent/dist/core/extensions/loader.js +4 -0
  263. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  264. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +35 -2
  265. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
  266. package/packages/pi-coding-agent/dist/core/extensions/runner.js +233 -0
  267. package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
  268. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +205 -2
  269. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  270. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  271. package/packages/pi-coding-agent/dist/core/hooks-runner.d.ts +53 -0
  272. package/packages/pi-coding-agent/dist/core/hooks-runner.d.ts.map +1 -0
  273. package/packages/pi-coding-agent/dist/core/hooks-runner.js +337 -0
  274. package/packages/pi-coding-agent/dist/core/hooks-runner.js.map +1 -0
  275. package/packages/pi-coding-agent/dist/core/hooks-runner.test.d.ts +2 -0
  276. package/packages/pi-coding-agent/dist/core/hooks-runner.test.d.ts.map +1 -0
  277. package/packages/pi-coding-agent/dist/core/hooks-runner.test.js +234 -0
  278. package/packages/pi-coding-agent/dist/core/hooks-runner.test.js.map +1 -0
  279. package/packages/pi-coding-agent/dist/core/index.d.ts +1 -0
  280. package/packages/pi-coding-agent/dist/core/index.d.ts.map +1 -1
  281. package/packages/pi-coding-agent/dist/core/index.js +1 -0
  282. package/packages/pi-coding-agent/dist/core/index.js.map +1 -1
  283. package/packages/pi-coding-agent/dist/core/model-discovery.d.ts +3 -1
  284. package/packages/pi-coding-agent/dist/core/model-discovery.d.ts.map +1 -1
  285. package/packages/pi-coding-agent/dist/core/model-discovery.js +92 -12
  286. package/packages/pi-coding-agent/dist/core/model-discovery.js.map +1 -1
  287. package/packages/pi-coding-agent/dist/core/model-discovery.test.js +16 -1
  288. package/packages/pi-coding-agent/dist/core/model-discovery.test.js.map +1 -1
  289. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.d.ts +2 -0
  290. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.d.ts.map +1 -0
  291. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.js +40 -0
  292. package/packages/pi-coding-agent/dist/core/model-registry-auth-header.test.js.map +1 -0
  293. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts +2 -0
  294. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts.map +1 -0
  295. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js +203 -0
  296. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js.map +1 -0
  297. package/packages/pi-coding-agent/dist/core/model-registry-discovery.test.js +61 -1
  298. package/packages/pi-coding-agent/dist/core/model-registry-discovery.test.js.map +1 -1
  299. package/packages/pi-coding-agent/dist/core/model-registry.d.ts +5 -0
  300. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  301. package/packages/pi-coding-agent/dist/core/model-registry.js +90 -10
  302. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  303. package/packages/pi-coding-agent/dist/core/redact-secrets.d.ts +2 -0
  304. package/packages/pi-coding-agent/dist/core/redact-secrets.d.ts.map +1 -0
  305. package/packages/pi-coding-agent/dist/core/redact-secrets.js +49 -0
  306. package/packages/pi-coding-agent/dist/core/redact-secrets.js.map +1 -0
  307. package/packages/pi-coding-agent/dist/core/redact-secrets.test.d.ts +2 -0
  308. package/packages/pi-coding-agent/dist/core/redact-secrets.test.d.ts.map +1 -0
  309. package/packages/pi-coding-agent/dist/core/redact-secrets.test.js +67 -0
  310. package/packages/pi-coding-agent/dist/core/redact-secrets.test.js.map +1 -0
  311. package/packages/pi-coding-agent/dist/core/session-manager.d.ts.map +1 -1
  312. package/packages/pi-coding-agent/dist/core/session-manager.js +10 -6
  313. package/packages/pi-coding-agent/dist/core/session-manager.js.map +1 -1
  314. package/packages/pi-coding-agent/dist/core/session-manager.test.js +45 -1
  315. package/packages/pi-coding-agent/dist/core/session-manager.test.js.map +1 -1
  316. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +55 -0
  317. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  318. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  319. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  320. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  321. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  322. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts +1 -1
  323. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.d.ts.map +1 -1
  324. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js +5 -4
  325. package/packages/pi-coding-agent/dist/modes/interactive/components/chat-frame.js.map +1 -1
  326. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.d.ts.map +1 -1
  327. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.js +13 -7
  328. package/packages/pi-coding-agent/dist/modes/interactive/components/provider-manager.js.map +1 -1
  329. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.d.ts +7 -6
  330. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -1
  331. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.js +29 -21
  332. package/packages/pi-coding-agent/dist/modes/interactive/components/skill-invocation-message.js.map +1 -1
  333. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  334. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +13 -1
  335. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  336. package/packages/pi-coding-agent/package.json +1 -1
  337. package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +3 -2
  338. package/packages/pi-coding-agent/src/core/agent-session.ts +38 -2
  339. package/packages/pi-coding-agent/src/core/extensions/index.ts +16 -0
  340. package/packages/pi-coding-agent/src/core/extensions/loader.ts +5 -0
  341. package/packages/pi-coding-agent/src/core/extensions/runner.ts +351 -0
  342. package/packages/pi-coding-agent/src/core/extensions/types.ts +258 -0
  343. package/packages/pi-coding-agent/src/core/hooks-runner.test.ts +269 -0
  344. package/packages/pi-coding-agent/src/core/hooks-runner.ts +460 -0
  345. package/packages/pi-coding-agent/src/core/index.ts +10 -0
  346. package/packages/pi-coding-agent/src/core/model-discovery.test.ts +19 -0
  347. package/packages/pi-coding-agent/src/core/model-discovery.ts +99 -12
  348. package/packages/pi-coding-agent/src/core/model-registry-auth-header.test.ts +44 -0
  349. package/packages/pi-coding-agent/src/core/model-registry-custom-caps.test.ts +245 -0
  350. package/packages/pi-coding-agent/src/core/model-registry-discovery.test.ts +75 -0
  351. package/packages/pi-coding-agent/src/core/model-registry.ts +102 -10
  352. package/packages/pi-coding-agent/src/core/redact-secrets.test.ts +86 -0
  353. package/packages/pi-coding-agent/src/core/redact-secrets.ts +58 -0
  354. package/packages/pi-coding-agent/src/core/session-manager.test.ts +65 -1
  355. package/packages/pi-coding-agent/src/core/session-manager.ts +10 -6
  356. package/packages/pi-coding-agent/src/core/settings-manager.ts +57 -0
  357. package/packages/pi-coding-agent/src/index.ts +16 -0
  358. package/packages/pi-coding-agent/src/modes/interactive/components/chat-frame.ts +6 -6
  359. package/packages/pi-coding-agent/src/modes/interactive/components/provider-manager.ts +16 -7
  360. package/packages/pi-coding-agent/src/modes/interactive/components/skill-invocation-message.ts +36 -22
  361. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +13 -1
  362. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  363. package/packages/pi-tui/package.json +1 -1
  364. package/packages/rpc-client/package.json +1 -1
  365. package/pkg/package.json +1 -1
  366. package/scripts/link-workspace-packages.cjs +1 -0
  367. package/src/resources/agents/researcher.md +1 -1
  368. package/src/resources/extensions/claude-code-cli/readiness.ts +32 -8
  369. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +78 -17
  370. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +149 -5
  371. package/src/resources/extensions/gsd/auto/loop-deps.ts +14 -0
  372. package/src/resources/extensions/gsd/auto/loop.ts +9 -0
  373. package/src/resources/extensions/gsd/auto/phases.ts +131 -10
  374. package/src/resources/extensions/gsd/auto/run-unit.ts +40 -2
  375. package/src/resources/extensions/gsd/auto/session.ts +35 -2
  376. package/src/resources/extensions/gsd/auto-dispatch.ts +16 -3
  377. package/src/resources/extensions/gsd/auto-model-selection.ts +71 -15
  378. package/src/resources/extensions/gsd/auto-post-unit.ts +29 -3
  379. package/src/resources/extensions/gsd/auto-prompts.ts +28 -1
  380. package/src/resources/extensions/gsd/auto-recovery.ts +26 -1
  381. package/src/resources/extensions/gsd/auto-start.ts +60 -68
  382. package/src/resources/extensions/gsd/auto-verification.ts +33 -0
  383. package/src/resources/extensions/gsd/auto-worktree.ts +62 -63
  384. package/src/resources/extensions/gsd/auto.ts +73 -28
  385. package/src/resources/extensions/gsd/blocked-models.ts +98 -0
  386. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +120 -1
  387. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +40 -9
  388. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +109 -0
  389. package/src/resources/extensions/gsd/bootstrap/memory-tools.ts +5 -0
  390. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +15 -0
  391. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +54 -6
  392. package/src/resources/extensions/gsd/bootstrap/system-context.ts +89 -26
  393. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +35 -2
  394. package/src/resources/extensions/gsd/clean-root-preflight.ts +111 -0
  395. package/src/resources/extensions/gsd/commands-extract-learnings.ts +55 -90
  396. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +898 -32
  397. package/src/resources/extensions/gsd/compaction-snapshot.ts +165 -0
  398. package/src/resources/extensions/gsd/complexity-classifier.ts +5 -3
  399. package/src/resources/extensions/gsd/db-writer.ts +88 -17
  400. package/src/resources/extensions/gsd/doctor-git-checks.ts +23 -27
  401. package/src/resources/extensions/gsd/doctor-providers.ts +59 -6
  402. package/src/resources/extensions/gsd/ecosystem/gsd-extension-api.ts +2 -0
  403. package/src/resources/extensions/gsd/error-classifier.ts +36 -3
  404. package/src/resources/extensions/gsd/exec-history.ts +153 -0
  405. package/src/resources/extensions/gsd/exec-sandbox.ts +326 -0
  406. package/src/resources/extensions/gsd/gitignore.ts +1 -1
  407. package/src/resources/extensions/gsd/gsd-db.ts +186 -23
  408. package/src/resources/extensions/gsd/guided-flow.ts +222 -1
  409. package/src/resources/extensions/gsd/health-widget.ts +3 -1
  410. package/src/resources/extensions/gsd/hook-emitter.ts +188 -0
  411. package/src/resources/extensions/gsd/init-wizard.ts +15 -1
  412. package/src/resources/extensions/gsd/journal.ts +2 -1
  413. package/src/resources/extensions/gsd/key-manager.ts +28 -0
  414. package/src/resources/extensions/gsd/memory-backfill.ts +140 -0
  415. package/src/resources/extensions/gsd/memory-store.ts +26 -0
  416. package/src/resources/extensions/gsd/model-router.ts +42 -1
  417. package/src/resources/extensions/gsd/pre-execution-checks.ts +46 -10
  418. package/src/resources/extensions/gsd/preferences-types.ts +46 -0
  419. package/src/resources/extensions/gsd/preferences-validation.ts +79 -0
  420. package/src/resources/extensions/gsd/preferences.ts +17 -17
  421. package/src/resources/extensions/gsd/prompt-loader.ts +30 -7
  422. package/src/resources/extensions/gsd/prompts/complete-milestone.md +1 -1
  423. package/src/resources/extensions/gsd/prompts/complete-slice.md +2 -2
  424. package/src/resources/extensions/gsd/prompts/debug-diagnose.md +2 -0
  425. package/src/resources/extensions/gsd/prompts/discuss-headless.md +8 -0
  426. package/src/resources/extensions/gsd/prompts/discuss.md +29 -2
  427. package/src/resources/extensions/gsd/prompts/execute-task.md +3 -2
  428. package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  429. package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -0
  430. package/src/resources/extensions/gsd/prompts/research-slice.md +1 -0
  431. package/src/resources/extensions/gsd/safety/evidence-collector.ts +119 -0
  432. package/src/resources/extensions/gsd/safety/file-change-validator.ts +17 -4
  433. package/src/resources/extensions/gsd/safety/safety-harness.ts +9 -0
  434. package/src/resources/extensions/gsd/state.ts +45 -4
  435. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +188 -2
  436. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +95 -1
  437. package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +12 -0
  438. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +49 -0
  439. package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +141 -0
  440. package/src/resources/extensions/gsd/tests/auto-start-model-capture.test.ts +33 -3
  441. package/src/resources/extensions/gsd/tests/auto-thinking-restore.test.ts +38 -0
  442. package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +23 -0
  443. package/src/resources/extensions/gsd/tests/blocked-models.test.ts +98 -0
  444. package/src/resources/extensions/gsd/tests/bundled-skill-triggers.test.ts +54 -0
  445. package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +186 -0
  446. package/src/resources/extensions/gsd/tests/commands-extract-learnings.test.ts +68 -66
  447. package/src/resources/extensions/gsd/tests/compaction-snapshot.test.ts +123 -0
  448. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +61 -1
  449. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  450. package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
  451. package/src/resources/extensions/gsd/tests/complexity-classifier.test.ts +3 -3
  452. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +2 -0
  453. package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +42 -0
  454. package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +8 -4
  455. package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +148 -3
  456. package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +1 -1
  457. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +306 -1
  458. package/src/resources/extensions/gsd/tests/escalation.test.ts +1 -1
  459. package/src/resources/extensions/gsd/tests/exec-history.test.ts +237 -0
  460. package/src/resources/extensions/gsd/tests/exec-sandbox.test.ts +210 -0
  461. package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +58 -0
  462. package/src/resources/extensions/gsd/tests/flat-rate-routing-guard.test.ts +40 -9
  463. package/src/resources/extensions/gsd/tests/freeform-decisions.test.ts +62 -0
  464. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +447 -1
  465. package/src/resources/extensions/gsd/tests/init-wizard.test.ts +27 -0
  466. package/src/resources/extensions/gsd/tests/integration/doctor-git-symlink-cwd.test.ts +11 -0
  467. package/src/resources/extensions/gsd/tests/integration/doctor-git.test.ts +78 -0
  468. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +1 -0
  469. package/src/resources/extensions/gsd/tests/integration/gitignore-tracked-gsd.test.ts +1 -0
  470. package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +30 -0
  471. package/src/resources/extensions/gsd/tests/interactive-routing-bypass.test.ts +1 -1
  472. package/src/resources/extensions/gsd/tests/isolation-none-branch-guard.test.ts +1 -1
  473. package/src/resources/extensions/gsd/tests/issue-4540-regressions.test.ts +288 -0
  474. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +37 -0
  475. package/src/resources/extensions/gsd/tests/key-manager.test.ts +9 -0
  476. package/src/resources/extensions/gsd/tests/load-memory-block.test.ts +36 -0
  477. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
  478. package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +12 -0
  479. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  480. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +19 -0
  481. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +37 -0
  482. package/src/resources/extensions/gsd/tests/pre-exec-backtick-strip.test.ts +14 -0
  483. package/src/resources/extensions/gsd/tests/pre-exec-gate-loop.test.ts +272 -0
  484. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +356 -0
  485. package/src/resources/extensions/gsd/tests/preferences.test.ts +110 -0
  486. package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +44 -0
  487. package/src/resources/extensions/gsd/tests/prompt-loader-extension-dir.test.ts +49 -0
  488. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +103 -4
  489. package/src/resources/extensions/gsd/tests/ready-phrase-no-files-4573.test.ts +388 -0
  490. package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +9 -3
  491. package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +230 -0
  492. package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +205 -0
  493. package/src/resources/extensions/gsd/tests/save-gate-result-render.test.ts +95 -0
  494. package/src/resources/extensions/gsd/tests/schema-v21-sequence.test.ts +413 -0
  495. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +32 -40
  496. package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +56 -0
  497. package/src/resources/extensions/gsd/tests/token-counter.test.ts +105 -1
  498. package/src/resources/extensions/gsd/tests/tool-compatibility.test.ts +107 -0
  499. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +23 -0
  500. package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +9 -3
  501. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +65 -2
  502. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +35 -0
  503. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +6 -1
  504. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +78 -5
  505. package/src/resources/extensions/gsd/tests/write-gate.test.ts +64 -0
  506. package/src/resources/extensions/gsd/tests/zombie-gsd-state.test.ts +3 -1
  507. package/src/resources/extensions/gsd/token-counter.ts +22 -5
  508. package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
  509. package/src/resources/extensions/gsd/tools/exec-search-tool.ts +81 -0
  510. package/src/resources/extensions/gsd/tools/exec-tool.ts +183 -0
  511. package/src/resources/extensions/gsd/tools/memory-tools.ts +31 -1
  512. package/src/resources/extensions/gsd/tools/resume-tool.ts +40 -0
  513. package/src/resources/extensions/gsd/uok/plan-v2.ts +26 -3
  514. package/src/resources/extensions/gsd/workflow-logger.ts +4 -1
  515. package/src/resources/extensions/gsd/workflow-mcp.ts +3 -0
  516. package/src/resources/extensions/gsd/workflow-templates/spike.md +6 -0
  517. package/src/resources/extensions/gsd/worktree-resolver.ts +54 -9
  518. package/src/resources/extensions/search-the-web/command-search-provider.ts +5 -4
  519. package/src/resources/extensions/search-the-web/native-search.ts +48 -12
  520. package/src/resources/skills/api-design/SKILL.md +190 -0
  521. package/src/resources/skills/create-mcp-server/SKILL.md +121 -0
  522. package/src/resources/skills/decompose-into-slices/SKILL.md +139 -0
  523. package/src/resources/skills/dependency-upgrade/SKILL.md +158 -0
  524. package/src/resources/skills/design-an-interface/SKILL.md +102 -0
  525. package/src/resources/skills/forensics/SKILL.md +153 -0
  526. package/src/resources/skills/grill-me/SKILL.md +93 -0
  527. package/src/resources/skills/handoff/SKILL.md +121 -0
  528. package/src/resources/skills/observability/SKILL.md +174 -0
  529. package/src/resources/skills/security-review/SKILL.md +181 -0
  530. package/src/resources/skills/spike-wrap-up/SKILL.md +138 -0
  531. package/src/resources/skills/tdd/SKILL.md +112 -0
  532. package/src/resources/skills/verify-before-complete/SKILL.md +98 -0
  533. package/src/resources/skills/write-docs/SKILL.md +82 -0
  534. package/src/resources/skills/write-milestone-brief/SKILL.md +135 -0
  535. /package/dist/web/standalone/.next/static/{ssX7BLv3Dw9Fb4CtrCGeR → pV-mPo7rYGb5JBC09C8GG}/_buildManifest.js +0 -0
  536. /package/dist/web/standalone/.next/static/{ssX7BLv3Dw9Fb4CtrCGeR → pV-mPo7rYGb5JBC09C8GG}/_ssgManifest.js +0 -0
@@ -0,0 +1,272 @@
1
+ /**
2
+ * pre-exec-gate-loop.test.ts — Regression tests for #4551.
3
+ *
4
+ * Verifies that when a pre-execution gate fails on a plan-slice unit:
5
+ * 1. `s.lastPreExecFailure` is populated on the AutoSession with the blocking
6
+ * findings and a verdict excerpt.
7
+ * 2. The `planning → plan-slice` dispatch rule reads that field and injects a
8
+ * "Fix these specific issues" section into the prompt.
9
+ * 3. The field is cleared (consumed) after the prompt is built so that stale
10
+ * context does not bleed into an unrelated future plan-slice run.
11
+ * 4. When the failure belongs to a *different* unit ID, the dispatch rule
12
+ * does NOT inject the stale context into the prompt.
13
+ */
14
+
15
+ import test from "node:test";
16
+ import assert from "node:assert/strict";
17
+ import { mkdtempSync, mkdirSync, writeFileSync, rmSync } from "node:fs";
18
+ import { join } from "node:path";
19
+ import { tmpdir } from "node:os";
20
+
21
+ import { AutoSession } from "../auto/session.ts";
22
+ import { resolveDispatch } from "../auto-dispatch.ts";
23
+ import type { DispatchContext } from "../auto-dispatch.ts";
24
+ import { buildPlanSlicePrompt } from "../auto-prompts.ts";
25
+ import {
26
+ openDatabase,
27
+ closeDatabase,
28
+ insertMilestone,
29
+ insertSlice,
30
+ insertTask,
31
+ } from "../gsd-db.ts";
32
+ import { deriveStateFromDb } from "../state.ts";
33
+ import { _clearGsdRootCache } from "../paths.ts";
34
+ import { invalidateAllCaches } from "../cache.ts";
35
+
36
+ // ─── Helpers ─────────────────────────────────────────────────────────────────
37
+
38
+ function makeTempBase(): string {
39
+ const base = mkdtempSync(join(tmpdir(), "gsd-4551-"));
40
+ mkdirSync(join(base, ".gsd", "milestones", "M001", "slices", "S01"), { recursive: true });
41
+ mkdirSync(join(base, ".gsd", "milestones", "M001", "slices", "S01", "tasks"), { recursive: true });
42
+ return base;
43
+ }
44
+
45
+ function seedPlanningState(base: string): void {
46
+ openDatabase(join(base, ".gsd", "gsd.db"));
47
+ insertMilestone({ id: "M001", title: "Test Milestone", status: "active" });
48
+ insertSlice({
49
+ id: "S01",
50
+ milestoneId: "M001",
51
+ title: "Core Slice",
52
+ status: "pending",
53
+ risk: "medium",
54
+ depends: [],
55
+ demo: "demo",
56
+ sequence: 1,
57
+ isSketch: false,
58
+ });
59
+ // Write minimal ROADMAP so state derivation doesn't error
60
+ writeFileSync(
61
+ join(base, ".gsd", "milestones", "M001", "M001-ROADMAP.md"),
62
+ "# Roadmap\n",
63
+ );
64
+ }
65
+
66
+ function cleanup(base: string, originalCwd: string): void {
67
+ try { closeDatabase(); } catch { /* noop */ }
68
+ try { process.chdir(originalCwd); } catch { /* noop */ }
69
+ try { rmSync(base, { recursive: true, force: true }); } catch { /* noop */ }
70
+ }
71
+
72
+ // ─── Tests ────────────────────────────────────────────────────────────────────
73
+
74
+ test("#4551: AutoSession.lastPreExecFailure defaults to null", () => {
75
+ const s = new AutoSession();
76
+ assert.equal(s.lastPreExecFailure, null, "lastPreExecFailure must start null");
77
+ });
78
+
79
+ test("#4551: AutoSession.reset() clears lastPreExecFailure", () => {
80
+ const s = new AutoSession();
81
+ s.lastPreExecFailure = {
82
+ unitId: "M001/S01",
83
+ blockingFindings: ["[file] src/foo.ts: file not found"],
84
+ verdictExcerpt: "status=fail; 1 blocking issue detected",
85
+ };
86
+ s.reset();
87
+ assert.equal(s.lastPreExecFailure, null, "reset() must clear lastPreExecFailure");
88
+ });
89
+
90
+ test("#4551: buildPlanSlicePrompt injects fix section when priorPreExecFailure provided", async (t) => {
91
+ const originalCwd = process.cwd();
92
+ const base = makeTempBase();
93
+ t.after(() => cleanup(base, originalCwd));
94
+
95
+ seedPlanningState(base);
96
+ process.chdir(base);
97
+ _clearGsdRootCache();
98
+ invalidateAllCaches();
99
+
100
+ const prompt = await buildPlanSlicePrompt(
101
+ "M001", "Test Milestone", "S01", "Core Slice", base,
102
+ undefined,
103
+ {
104
+ priorPreExecFailure: {
105
+ blockingFindings: [
106
+ "[file] src/utils/helper.ts: file not found",
107
+ "[package] nonexistent-pkg: package not found on npm",
108
+ ],
109
+ verdictExcerpt: "status=fail; 2 blocking issues detected",
110
+ },
111
+ },
112
+ );
113
+
114
+ assert.ok(
115
+ prompt.includes("Fix these specific issues from the prior pre-exec check"),
116
+ "prompt must contain the fix section heading",
117
+ );
118
+ assert.ok(
119
+ prompt.includes("src/utils/helper.ts: file not found"),
120
+ "prompt must include the specific file finding",
121
+ );
122
+ assert.ok(
123
+ prompt.includes("nonexistent-pkg: package not found on npm"),
124
+ "prompt must include the specific package finding",
125
+ );
126
+ assert.ok(
127
+ prompt.includes("status=fail; 2 blocking issues detected"),
128
+ "prompt must include the verdict excerpt",
129
+ );
130
+ });
131
+
132
+ test("#4551: buildPlanSlicePrompt with no priorPreExecFailure does NOT include fix section", async (t) => {
133
+ const originalCwd = process.cwd();
134
+ const base = makeTempBase();
135
+ t.after(() => cleanup(base, originalCwd));
136
+
137
+ seedPlanningState(base);
138
+ process.chdir(base);
139
+ _clearGsdRootCache();
140
+ invalidateAllCaches();
141
+
142
+ const prompt = await buildPlanSlicePrompt(
143
+ "M001", "Test Milestone", "S01", "Core Slice", base,
144
+ undefined,
145
+ { /* no priorPreExecFailure */ },
146
+ );
147
+
148
+ assert.ok(
149
+ !prompt.includes("Fix these specific issues from the prior pre-exec check"),
150
+ "prompt must NOT include the fix section when no failure context is given",
151
+ );
152
+ });
153
+
154
+ test("#4551: dispatch rule injects failure context and clears session field", async (t) => {
155
+ const originalCwd = process.cwd();
156
+ const base = makeTempBase();
157
+ t.after(() => cleanup(base, originalCwd));
158
+
159
+ seedPlanningState(base);
160
+ // Write a RESEARCH file so the dispatch rule skips research-slice and reaches
161
+ // plan-slice (which is the phase we're testing).
162
+ writeFileSync(
163
+ join(base, ".gsd", "milestones", "M001", "slices", "S01", "S01-RESEARCH.md"),
164
+ "# Research\n",
165
+ );
166
+ process.chdir(base);
167
+ _clearGsdRootCache();
168
+ invalidateAllCaches();
169
+
170
+ const state = await deriveStateFromDb(base);
171
+ assert.equal(state.phase, "planning", "state must be in planning phase");
172
+
173
+ const session = new AutoSession();
174
+ session.basePath = base;
175
+ session.active = true;
176
+ session.lastPreExecFailure = {
177
+ unitId: "M001/S01",
178
+ blockingFindings: ["[file] src/missing.ts: file not found"],
179
+ verdictExcerpt: "status=fail; 1 blocking issue detected",
180
+ };
181
+
182
+ const ctx: DispatchContext = {
183
+ basePath: base,
184
+ mid: "M001",
185
+ midTitle: "Test Milestone",
186
+ state,
187
+ prefs: { phases: { reassess_after_slice: false, skip_research: true } } as any,
188
+ session,
189
+ };
190
+
191
+ const result = await resolveDispatch(ctx);
192
+ assert.equal(result.action, "dispatch", "must dispatch a unit");
193
+ if (result.action !== "dispatch") throw new Error("unreachable");
194
+ assert.equal(result.unitType, "plan-slice", "must be a plan-slice unit");
195
+
196
+ // The fix section must appear in the prompt
197
+ assert.ok(
198
+ result.prompt.includes("Fix these specific issues from the prior pre-exec check"),
199
+ "dispatched prompt must include the fix section",
200
+ );
201
+ assert.ok(
202
+ result.prompt.includes("src/missing.ts: file not found"),
203
+ "dispatched prompt must include the specific blocking finding",
204
+ );
205
+
206
+ // Field must be cleared after consumption
207
+ assert.equal(
208
+ session.lastPreExecFailure,
209
+ null,
210
+ "lastPreExecFailure must be cleared after being consumed by the dispatch rule",
211
+ );
212
+ });
213
+
214
+ test("#4551: dispatch rule does NOT inject stale failure for a different slice", async (t) => {
215
+ const originalCwd = process.cwd();
216
+ const base = makeTempBase();
217
+ t.after(() => cleanup(base, originalCwd));
218
+
219
+ seedPlanningState(base);
220
+ // Write a RESEARCH file so dispatch reaches plan-slice, making the assertion
221
+ // about the prompt meaningful (we can check it's a plan-slice prompt without
222
+ // the fix section rather than a research-slice prompt without it).
223
+ writeFileSync(
224
+ join(base, ".gsd", "milestones", "M001", "slices", "S01", "S01-RESEARCH.md"),
225
+ "# Research\n",
226
+ );
227
+ process.chdir(base);
228
+ _clearGsdRootCache();
229
+ invalidateAllCaches();
230
+
231
+ const state = await deriveStateFromDb(base);
232
+
233
+ const session = new AutoSession();
234
+ session.basePath = base;
235
+ session.active = true;
236
+ // Failure belongs to a different slice (S02), not the active one (S01)
237
+ session.lastPreExecFailure = {
238
+ unitId: "M001/S02",
239
+ blockingFindings: ["[file] src/other.ts: file not found"],
240
+ verdictExcerpt: "status=fail; 1 blocking issue detected",
241
+ };
242
+
243
+ const ctx: DispatchContext = {
244
+ basePath: base,
245
+ mid: "M001",
246
+ midTitle: "Test Milestone",
247
+ state,
248
+ prefs: { phases: { reassess_after_slice: false, skip_research: true } } as any,
249
+ session,
250
+ };
251
+
252
+ const result = await resolveDispatch(ctx);
253
+ assert.equal(result.action, "dispatch");
254
+ if (result.action !== "dispatch") throw new Error("unreachable");
255
+
256
+ // The stale fix section must NOT appear
257
+ assert.ok(
258
+ !result.prompt.includes("Fix these specific issues from the prior pre-exec check"),
259
+ "prompt must NOT include fix section for a mismatched unit ID",
260
+ );
261
+ assert.ok(
262
+ !result.prompt.includes("src/other.ts"),
263
+ "prompt must NOT include findings from a different slice",
264
+ );
265
+
266
+ // Field must remain untouched (not consumed)
267
+ assert.notEqual(
268
+ session.lastPreExecFailure,
269
+ null,
270
+ "lastPreExecFailure must NOT be cleared when unit IDs don't match",
271
+ );
272
+ });
@@ -140,6 +140,25 @@ import type { Request } from 'express';
140
140
  assert.ok(packages.includes("typescript"));
141
141
  assert.ok(!packages.includes("-D"));
142
142
  });
143
+
144
+ // Regression tests for #4388: prose containing `from "..."` must not produce false-positive packages
145
+ test("does not treat prose 'from \"What's Next\"' as a package name (#4388)", () => {
146
+ const desc = 'Build the feature described from "What\'s Next" in the roadmap';
147
+ const packages = extractPackageReferences(desc);
148
+ assert.deepEqual(packages, [], `prose 'from "What\\'s Next"' must not produce package names, got: ${JSON.stringify(packages)}`);
149
+ });
150
+
151
+ test("does not treat prose \"from 'master'\" as a package name (#4388)", () => {
152
+ const desc = "Review changes from 'master' branch before merging";
153
+ const packages = extractPackageReferences(desc);
154
+ assert.deepEqual(packages, [], `prose "from 'master'" must not produce package names, got: ${JSON.stringify(packages)}`);
155
+ });
156
+
157
+ test("still extracts import statements in code blocks after #4388 fix", () => {
158
+ const desc = "```typescript\nimport express from 'express';\nimport { Router } from 'express';\n```";
159
+ const packages = extractPackageReferences(desc);
160
+ assert.ok(packages.includes("express"), "import...from in code blocks must still be recognized");
161
+ });
143
162
  });
144
163
 
145
164
  // ─── File Path Consistency Tests ─────────────────────────────────────────────
@@ -1580,6 +1599,221 @@ describe("checkTaskOrdering directory inputs (#4446)", () => {
1580
1599
  });
1581
1600
  });
1582
1601
 
1602
+ // ─── Regression Tests: checkTaskOrdering false positive for pre-execution refs (#4071) ──
1603
+
1604
+ describe("checkTaskOrdering false positive for pre-execution refs (#4071)", () => {
1605
+ test("completed task at higher index does not trigger ordering violation for its outputs", () => {
1606
+ // Scenario: after a replan, a completed task at higher array index has already
1607
+ // created a file. A new earlier-sequence task reads that file. Since the
1608
+ // completed task already ran, its output is available regardless of disk state.
1609
+ // checkTaskOrdering must not flag this as a sequence violation.
1610
+ const tasks = [
1611
+ createTask({
1612
+ id: "T_NEW",
1613
+ sequence: 1,
1614
+ status: "pending",
1615
+ inputs: ["artifacts/setup.json"],
1616
+ expected_output: [],
1617
+ }),
1618
+ createTask({
1619
+ id: "T_SETUP",
1620
+ sequence: 5,
1621
+ status: "completed",
1622
+ inputs: [],
1623
+ expected_output: ["artifacts/setup.json"],
1624
+ }),
1625
+ ];
1626
+
1627
+ const results = checkTaskOrdering(tasks, "/tmp");
1628
+ assert.equal(
1629
+ results.length,
1630
+ 0,
1631
+ "completed task outputs must not trigger ordering violations for earlier-sequence tasks that read them",
1632
+ );
1633
+ });
1634
+
1635
+ test("pending task at higher index still triggers ordering violation", () => {
1636
+ // A PENDING task at higher index creating a file is a real violation.
1637
+ // Only completed tasks get the exemption.
1638
+ const tasks = [
1639
+ createTask({
1640
+ id: "T01",
1641
+ sequence: 1,
1642
+ status: "pending",
1643
+ inputs: ["artifacts/output.json"],
1644
+ expected_output: [],
1645
+ }),
1646
+ createTask({
1647
+ id: "T02",
1648
+ sequence: 5,
1649
+ status: "pending",
1650
+ inputs: [],
1651
+ expected_output: ["artifacts/output.json"],
1652
+ }),
1653
+ ];
1654
+
1655
+ const results = checkTaskOrdering(tasks, "/tmp");
1656
+ assert.equal(
1657
+ results.length,
1658
+ 1,
1659
+ "pending task at higher index must still be flagged as ordering violation",
1660
+ );
1661
+ assert.equal(results[0].blocking, true);
1662
+ assert.ok(results[0].message.includes("T01"));
1663
+ assert.ok(results[0].message.includes("T02"));
1664
+ assert.ok(results[0].message.includes("sequence violation"));
1665
+ });
1666
+
1667
+ test("pending-first then completed-later: completed replaces pending in fileCreators (#4572)", () => {
1668
+ // Regression for CodeRabbit Major finding on PR #4572:
1669
+ // fileCreators only stored the FIRST task for a given path. If a PENDING task at
1670
+ // array index 1 was registered first, and a COMPLETED task at array index 2 also
1671
+ // declared the same output path, the completed entry was discarded. Line ~529 then
1672
+ // saw a pending creator with index > i and incorrectly fired a sequence violation
1673
+ // for the reader at array index 0.
1674
+ //
1675
+ // Scenario: path first declared by pending task (index 1), then by completed task
1676
+ // (index 2). Reader is at index 0. Without the fix a violation fires; with the fix
1677
+ // the completed entry replaces the pending entry and grants the exemption.
1678
+ const tasks = [
1679
+ // array index 0 — reads the shared path
1680
+ createTask({
1681
+ id: "T_READER",
1682
+ sequence: 1,
1683
+ status: "pending",
1684
+ inputs: ["shared/artifact.json"],
1685
+ expected_output: [],
1686
+ }),
1687
+ // array index 1 — pending producer (visited first during map build)
1688
+ createTask({
1689
+ id: "T_PENDING_PRODUCER",
1690
+ sequence: 5,
1691
+ status: "pending",
1692
+ inputs: [],
1693
+ expected_output: ["shared/artifact.json"],
1694
+ }),
1695
+ // array index 2 — completed producer (visited second; must replace pending entry)
1696
+ createTask({
1697
+ id: "T_COMPLETED_PRODUCER",
1698
+ sequence: 2,
1699
+ status: "completed",
1700
+ inputs: [],
1701
+ expected_output: ["shared/artifact.json"],
1702
+ }),
1703
+ ];
1704
+
1705
+ // Without the fix: creator = T_PENDING_PRODUCER (index 1), !creator.completed && 1 > 0 → violation.
1706
+ // With the fix: creator = T_COMPLETED_PRODUCER (index 2), creator.completed → no violation.
1707
+ const results = checkTaskOrdering(tasks, "/tmp");
1708
+ assert.equal(
1709
+ results.length,
1710
+ 0,
1711
+ "completed producer must replace pending producer in fileCreators and suppress false violation",
1712
+ );
1713
+ });
1714
+
1715
+ test("completed task output exemption applies regardless of whether file exists on disk", (t) => {
1716
+ // The completed-task exemption must work even when the file is not on disk
1717
+ // (e.g., the file was a temporary artifact that was cleaned up after the task ran).
1718
+ const tempDir = join(tmpdir(), `pre-exec-completed-task-${Date.now()}`);
1719
+ mkdirSync(tempDir, { recursive: true });
1720
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1721
+
1722
+ // File deliberately NOT created on disk — completed task ran in a prior session
1723
+ const tasks = [
1724
+ createTask({
1725
+ id: "T_MAIN",
1726
+ sequence: 0,
1727
+ status: "pending",
1728
+ inputs: ["generated/config.json"],
1729
+ expected_output: [],
1730
+ }),
1731
+ createTask({
1732
+ id: "T_INIT",
1733
+ sequence: 10,
1734
+ status: "completed",
1735
+ inputs: [],
1736
+ expected_output: ["generated/config.json"],
1737
+ }),
1738
+ ];
1739
+
1740
+ const results = checkTaskOrdering(tasks, tempDir);
1741
+ assert.equal(
1742
+ results.length,
1743
+ 0,
1744
+ "completed task exemption must apply even when file is absent from disk",
1745
+ );
1746
+ });
1747
+ });
1748
+
1749
+ describe("checkFilePathConsistency completed-task output exemption (#4071)", () => {
1750
+ test("completed task at higher index does not cause false positive for file it produced", (t) => {
1751
+ // Parallel to the checkTaskOrdering fix: checkFilePathConsistency also uses
1752
+ // getExpectedOutputsUpTo which historically only looked at prior-index tasks.
1753
+ // A completed task at a higher index has already run and its outputs are available.
1754
+ const tempDir = join(tmpdir(), `pre-exec-fc-completed-${Date.now()}`);
1755
+ mkdirSync(tempDir, { recursive: true });
1756
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1757
+
1758
+ // File is NOT on disk — completed task ran in a prior session and file was cleaned
1759
+ const tasks = [
1760
+ createTask({
1761
+ id: "T_MAIN",
1762
+ sequence: 1,
1763
+ status: "pending",
1764
+ inputs: ["artifacts/config.json"],
1765
+ expected_output: [],
1766
+ }),
1767
+ createTask({
1768
+ id: "T_SETUP",
1769
+ sequence: 10,
1770
+ status: "completed",
1771
+ inputs: [],
1772
+ expected_output: ["artifacts/config.json"],
1773
+ }),
1774
+ ];
1775
+
1776
+ const results = checkFilePathConsistency(tasks, tempDir);
1777
+ assert.equal(
1778
+ results.length,
1779
+ 0,
1780
+ "completed task at higher index should satisfy inputs of pending tasks that read its outputs",
1781
+ );
1782
+ });
1783
+
1784
+ test("pending task at higher index still causes a missing-file error", (t) => {
1785
+ const tempDir = join(tmpdir(), `pre-exec-fc-pending-${Date.now()}`);
1786
+ mkdirSync(tempDir, { recursive: true });
1787
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1788
+
1789
+ const tasks = [
1790
+ createTask({
1791
+ id: "T01",
1792
+ sequence: 1,
1793
+ status: "pending",
1794
+ inputs: ["artifacts/output.json"],
1795
+ expected_output: [],
1796
+ }),
1797
+ createTask({
1798
+ id: "T02",
1799
+ sequence: 10,
1800
+ status: "pending",
1801
+ inputs: [],
1802
+ expected_output: ["artifacts/output.json"],
1803
+ }),
1804
+ ];
1805
+
1806
+ const results = checkFilePathConsistency(tasks, tempDir);
1807
+ assert.equal(
1808
+ results.length,
1809
+ 1,
1810
+ "pending task at higher index must still be flagged — the file is not available yet",
1811
+ );
1812
+ assert.equal(results[0].blocking, true);
1813
+ assert.equal(results[0].target, "artifacts/output.json");
1814
+ });
1815
+ });
1816
+
1583
1817
  describe("checkFilePathConsistency self-referential inputs (#4459)", () => {
1584
1818
  test("input that is also in the same task's expected_output is not blocking when missing on disk", (t) => {
1585
1819
  const tempDir = join(tmpdir(), `pre-exec-self-output-${Date.now()}`);
@@ -1645,3 +1879,125 @@ describe("checkFilePathConsistency self-referential inputs (#4459)", () => {
1645
1879
  );
1646
1880
  });
1647
1881
  });
1882
+
1883
+ // ─── Regression Tests: quote-wrapped inputs treated as literal paths (#3747) ──
1884
+
1885
+ describe("checkFilePathConsistency quote-wrapped annotation (#3747)", () => {
1886
+ test("double-quoted path annotation is stripped before path check", (t) => {
1887
+ // Plan documents sometimes emit `"src/foo.ts"` (double-quote wrapped) as an
1888
+ // input value. The checker must strip the quotes before checking existence so
1889
+ // it doesn't produce a false-positive "file not found" error.
1890
+ const tempDir = join(tmpdir(), `pre-exec-quote-${Date.now()}`);
1891
+ mkdirSync(join(tempDir, "src"), { recursive: true });
1892
+ writeFileSync(join(tempDir, "src/foo.ts"), "// content");
1893
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1894
+
1895
+ const tasks = [
1896
+ createTask({
1897
+ id: "T01",
1898
+ inputs: ['"src/foo.ts"'],
1899
+ expected_output: [],
1900
+ }),
1901
+ ];
1902
+
1903
+ const results = checkFilePathConsistency(tasks, tempDir);
1904
+ assert.equal(
1905
+ results.length,
1906
+ 0,
1907
+ "Double-quoted path should be stripped and resolved to the real file",
1908
+ );
1909
+ });
1910
+
1911
+ test("single-quoted path annotation is stripped before path check", (t) => {
1912
+ const tempDir = join(tmpdir(), `pre-exec-squote-${Date.now()}`);
1913
+ mkdirSync(join(tempDir, "src"), { recursive: true });
1914
+ writeFileSync(join(tempDir, "src/bar.ts"), "// content");
1915
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1916
+
1917
+ const tasks = [
1918
+ createTask({
1919
+ id: "T01",
1920
+ inputs: ["'src/bar.ts'"],
1921
+ expected_output: [],
1922
+ }),
1923
+ ];
1924
+
1925
+ const results = checkFilePathConsistency(tasks, tempDir);
1926
+ assert.equal(
1927
+ results.length,
1928
+ 0,
1929
+ "Single-quoted path should be stripped and resolved to the real file",
1930
+ );
1931
+ });
1932
+
1933
+ test("backtick-only wrapped path without annotation resolves correctly", (t) => {
1934
+ // The bare form `src/foo.ts` (no dash annotation) must also work
1935
+ const tempDir = join(tmpdir(), `pre-exec-backtick-bare-${Date.now()}`);
1936
+ mkdirSync(join(tempDir, "src"), { recursive: true });
1937
+ writeFileSync(join(tempDir, "src/baz.ts"), "// content");
1938
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1939
+
1940
+ const tasks = [
1941
+ createTask({
1942
+ id: "T01",
1943
+ inputs: ["`src/baz.ts`"],
1944
+ expected_output: [],
1945
+ }),
1946
+ ];
1947
+
1948
+ const results = checkFilePathConsistency(tasks, tempDir);
1949
+ assert.equal(
1950
+ results.length,
1951
+ 0,
1952
+ "Bare backtick-wrapped path should resolve to the real file",
1953
+ );
1954
+ });
1955
+
1956
+ test("prose value with spaces inside quotes is skipped (not a path)", () => {
1957
+ // "some description text" contains spaces — should not be checked as a path
1958
+ const tasks = [
1959
+ createTask({
1960
+ id: "T01",
1961
+ inputs: ['"some description text"'],
1962
+ expected_output: [],
1963
+ }),
1964
+ ];
1965
+
1966
+ const results = checkFilePathConsistency(tasks, "/tmp");
1967
+ assert.equal(
1968
+ results.length,
1969
+ 0,
1970
+ "Quoted prose with spaces should not be treated as a file path",
1971
+ );
1972
+ });
1973
+
1974
+ test("17-error scenario: mixed annotated inputs produce 0 blocking errors", (t) => {
1975
+ // Reproduces the M004-ej6j88/S07 scenario from issue #3747 where a plan with
1976
+ // multiple backtick- and quote-wrapped input strings causes 17 false blocking errors.
1977
+ const tempDir = join(tmpdir(), `pre-exec-3747-scenario-${Date.now()}`);
1978
+ mkdirSync(join(tempDir, "src"), { recursive: true });
1979
+ writeFileSync(join(tempDir, "src/foo.ts"), "// content");
1980
+ writeFileSync(join(tempDir, "src/bar.ts"), "// content");
1981
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1982
+
1983
+ const tasks = [
1984
+ createTask({
1985
+ id: "T01",
1986
+ inputs: [
1987
+ "`src/foo.ts`",
1988
+ '"src/bar.ts"',
1989
+ "some description text",
1990
+ "Existing enum definition",
1991
+ ],
1992
+ expected_output: [],
1993
+ }),
1994
+ ];
1995
+
1996
+ const results = checkFilePathConsistency(tasks, tempDir);
1997
+ assert.equal(
1998
+ results.length,
1999
+ 0,
2000
+ "Annotated file paths and prose inputs should produce zero blocking errors",
2001
+ );
2002
+ });
2003
+ });