@opengsd/gsd-pi 1.2.0-dev.84c56d87 → 1.2.0-dev.8e6112e9

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 (631) hide show
  1. package/dist/cli-model-override.d.ts +15 -0
  2. package/dist/cli-model-override.js +21 -0
  3. package/dist/cli.js +1 -18
  4. package/dist/headless-events.js +7 -5
  5. package/dist/loader.js +6 -4
  6. package/dist/mcp-server.js +2 -1
  7. package/dist/register-agent-bundles.d.ts +11 -2
  8. package/dist/register-agent-bundles.js +18 -4
  9. package/dist/resource-loader.d.ts +10 -5
  10. package/dist/resource-loader.js +121 -6
  11. package/dist/resources/.managed-resources-content-hash +1 -1
  12. package/dist/resources/GSD-WORKFLOW.md +5 -4
  13. package/dist/resources/extensions/ask-user-questions.js +3 -2
  14. package/dist/resources/extensions/async-jobs/async-bash-tool.js +30 -64
  15. package/dist/resources/extensions/async-jobs/await-tool.js +80 -12
  16. package/dist/resources/extensions/async-jobs/index.js +65 -0
  17. package/dist/resources/extensions/async-jobs/job-manager.js +12 -1
  18. package/dist/resources/extensions/bg-shell/bg-shell-command.js +6 -6
  19. package/dist/resources/extensions/bg-shell/bg-shell-tool.js +10 -7
  20. package/dist/resources/extensions/bg-shell/overlay.js +9 -6
  21. package/dist/resources/extensions/bg-shell/process-manager.js +54 -25
  22. package/dist/resources/extensions/bg-shell/readiness-detector.js +11 -0
  23. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +447 -215
  24. package/dist/resources/extensions/claude-code-cli/turn-assembler.js +33 -1
  25. package/dist/resources/extensions/gsd/auto/closeout.js +215 -0
  26. package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +17 -2
  27. package/dist/resources/extensions/gsd/auto/detect-stuck.js +33 -13
  28. package/dist/resources/extensions/gsd/auto/dispatch-history.js +120 -0
  29. package/dist/resources/extensions/gsd/auto/dispatch-key.js +37 -0
  30. package/dist/resources/extensions/gsd/auto/dispatch.js +365 -0
  31. package/dist/resources/extensions/gsd/auto/finalize.js +347 -0
  32. package/dist/resources/extensions/gsd/auto/loop.js +7 -1
  33. package/dist/resources/extensions/gsd/auto/milestone-lease-reclaim.js +56 -0
  34. package/dist/resources/extensions/gsd/auto/orchestrator.js +174 -69
  35. package/dist/resources/extensions/gsd/auto/phase-helpers.js +146 -0
  36. package/dist/resources/extensions/gsd/auto/phases.js +17 -2329
  37. package/dist/resources/extensions/gsd/auto/pre-dispatch.js +534 -0
  38. package/dist/resources/extensions/gsd/auto/session.js +3 -0
  39. package/dist/resources/extensions/gsd/auto/unit-phase.js +694 -0
  40. package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +1 -1
  41. package/dist/resources/extensions/gsd/auto/worktree-safety-phase.js +125 -0
  42. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +11 -34
  43. package/dist/resources/extensions/gsd/auto-dispatch.js +50 -58
  44. package/dist/resources/extensions/gsd/auto-model-selection.js +36 -13
  45. package/dist/resources/extensions/gsd/auto-post-unit.js +30 -12
  46. package/dist/resources/extensions/gsd/auto-prompts.js +78 -19
  47. package/dist/resources/extensions/gsd/auto-start.js +35 -15
  48. package/dist/resources/extensions/gsd/auto-unit-closeout.js +45 -21
  49. package/dist/resources/extensions/gsd/auto-unit-tool-scope.js +5 -4
  50. package/dist/resources/extensions/gsd/auto-verification.js +23 -30
  51. package/dist/resources/extensions/gsd/auto-worktree.js +15 -2
  52. package/dist/resources/extensions/gsd/auto.js +52 -2
  53. package/dist/resources/extensions/gsd/blocked-models.js +28 -0
  54. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +26 -6
  55. package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +60 -13
  56. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +2 -2
  57. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +145 -50
  58. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +302 -80
  59. package/dist/resources/extensions/gsd/browser-daemon-auto-prep.js +83 -0
  60. package/dist/resources/extensions/gsd/closeout-wizard.js +92 -0
  61. package/dist/resources/extensions/gsd/commands/context.js +16 -2
  62. package/dist/resources/extensions/gsd/commands-handlers.js +46 -3
  63. package/dist/resources/extensions/gsd/commands-mcp-status.js +2 -2
  64. package/dist/resources/extensions/gsd/commands-workflow-templates.js +9 -2
  65. package/dist/resources/extensions/gsd/consent-question.js +353 -0
  66. package/dist/resources/extensions/gsd/consent-verdict.js +63 -0
  67. package/dist/resources/extensions/gsd/constants.js +0 -2
  68. package/dist/resources/extensions/gsd/crash-recovery.js +8 -3
  69. package/dist/resources/extensions/gsd/db/engine.js +5 -3
  70. package/dist/resources/extensions/gsd/db/queries.js +56 -0
  71. package/dist/resources/extensions/gsd/db-writer.js +8 -17
  72. package/dist/resources/extensions/gsd/dispatch-guard.js +10 -35
  73. package/dist/resources/extensions/gsd/doctor-engine-checks.js +5 -5
  74. package/dist/resources/extensions/gsd/doctor-environment.js +256 -125
  75. package/dist/resources/extensions/gsd/doctor-git-checks.js +2 -18
  76. package/dist/resources/extensions/gsd/engine-hook-contract.js +70 -0
  77. package/dist/resources/extensions/gsd/exec-sandbox.js +30 -10
  78. package/dist/resources/extensions/gsd/files.js +33 -19
  79. package/dist/resources/extensions/gsd/gsd-command-home.js +22 -12
  80. package/dist/resources/extensions/gsd/gsd-db.js +11 -8
  81. package/dist/resources/extensions/gsd/guidance.js +60 -0
  82. package/dist/resources/extensions/gsd/guided-flow.js +93 -4
  83. package/dist/resources/extensions/gsd/health-widget.js +87 -28
  84. package/dist/resources/extensions/gsd/markdown-renderer.js +10 -0
  85. package/dist/resources/extensions/gsd/mcp-bridge.js +10 -0
  86. package/dist/resources/extensions/gsd/memory-relations.js +1 -1
  87. package/dist/resources/extensions/gsd/milestone-closeout.js +85 -24
  88. package/dist/resources/extensions/gsd/milestone-planning-persistence.js +2 -2
  89. package/dist/resources/extensions/gsd/milestone-reopen-events.js +3 -5
  90. package/dist/resources/extensions/gsd/milestone-settlement.js +2 -2
  91. package/dist/resources/extensions/gsd/notifications.js +12 -7
  92. package/dist/resources/extensions/gsd/parsers-legacy.js +16 -4
  93. package/dist/resources/extensions/gsd/preferences-models.js +2 -2
  94. package/dist/resources/extensions/gsd/projection-flush.js +7 -0
  95. package/dist/resources/extensions/gsd/prompts/complete-slice.md +4 -4
  96. package/dist/resources/extensions/gsd/prompts/execute-task.md +3 -2
  97. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
  98. package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
  99. package/dist/resources/extensions/gsd/prompts/quick-task.md +1 -1
  100. package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
  101. package/dist/resources/extensions/gsd/prompts/refine-slice.md +1 -1
  102. package/dist/resources/extensions/gsd/prompts/replan-slice.md +1 -1
  103. package/dist/resources/extensions/gsd/prompts/research-milestone.md +1 -1
  104. package/dist/resources/extensions/gsd/prompts/research-slice.md +1 -1
  105. package/dist/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  106. package/dist/resources/extensions/gsd/prompts/run-uat.md +9 -5
  107. package/dist/resources/extensions/gsd/prompts/system.md +5 -2
  108. package/dist/resources/extensions/gsd/prompts/triage-captures.md +1 -1
  109. package/dist/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
  110. package/dist/resources/extensions/gsd/prompts/workflow-start.md +2 -1
  111. package/dist/resources/extensions/gsd/reactive-graph.js +8 -1
  112. package/dist/resources/extensions/gsd/roadmap-slices.js +25 -3
  113. package/dist/resources/extensions/gsd/safety/destructive-confirmation.js +108 -0
  114. package/dist/resources/extensions/gsd/session-lock.js +1 -1
  115. package/dist/resources/extensions/gsd/skill-activation.js +3 -6
  116. package/dist/resources/extensions/gsd/state.js +11 -2
  117. package/dist/resources/extensions/gsd/tool-contract.js +14 -3
  118. package/dist/resources/extensions/gsd/tool-presentation-plan.js +4 -4
  119. package/dist/resources/extensions/gsd/tool-surface-readiness.js +83 -31
  120. package/dist/resources/extensions/gsd/tools/complete-milestone.js +3 -2
  121. package/dist/resources/extensions/gsd/tools/complete-slice.js +22 -12
  122. package/dist/resources/extensions/gsd/tools/complete-task.js +65 -2
  123. package/dist/resources/extensions/gsd/tools/exec-tool.js +5 -0
  124. package/dist/resources/extensions/gsd/tools/plan-slice.js +2 -2
  125. package/dist/resources/extensions/gsd/tools/plan-task.js +2 -2
  126. package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +2 -2
  127. package/dist/resources/extensions/gsd/tools/reopen-milestone.js +2 -2
  128. package/dist/resources/extensions/gsd/tools/reopen-slice.js +2 -2
  129. package/dist/resources/extensions/gsd/tools/reopen-task.js +2 -2
  130. package/dist/resources/extensions/gsd/tools/replan-slice.js +2 -2
  131. package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +67 -2
  132. package/dist/resources/extensions/gsd/uat-policy.js +40 -15
  133. package/dist/resources/extensions/gsd/unit-context-composer.js +65 -0
  134. package/dist/resources/extensions/gsd/unit-registry.js +34 -4
  135. package/dist/resources/extensions/gsd/verdict-parser.js +1 -1
  136. package/dist/resources/extensions/gsd/verification-verdict.js +2 -1
  137. package/dist/resources/extensions/gsd/workflow-event-ledger.js +91 -0
  138. package/dist/resources/extensions/gsd/workflow-event-vocabulary.js +46 -0
  139. package/dist/resources/extensions/gsd/workflow-events.js +6 -18
  140. package/dist/resources/extensions/gsd/workflow-mcp-auto-prep.js +2 -0
  141. package/dist/resources/extensions/gsd/workflow-mcp-readiness-cache.js +105 -0
  142. package/dist/resources/extensions/gsd/workflow-reconcile.js +21 -56
  143. package/dist/resources/extensions/gsd/worktree-lifecycle.js +3 -2
  144. package/dist/resources/extensions/gsd/worktree-manager.js +7 -1
  145. package/dist/resources/extensions/gsd/worktree-safety.js +28 -26
  146. package/dist/resources/extensions/gsd/worktree.js +8 -1
  147. package/dist/resources/extensions/mcp-client/manager.js +6 -1
  148. package/dist/resources/extensions/shared/gsd-browser-cli.js +45 -3
  149. package/dist/resources/shared/gsd-browser-path-sync.js +214 -0
  150. package/dist/resources/shared/package-manager-detection.js +1 -1
  151. package/dist/resources/shared/package.json +3 -0
  152. package/dist/resources/skills/create-skill/SKILL.md +3 -0
  153. package/dist/resources/skills/create-skill/references/skill-structure.md +1 -0
  154. package/dist/runtime-checks.d.ts +10 -0
  155. package/dist/runtime-checks.js +27 -0
  156. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  157. package/dist/update-check.d.ts +2 -0
  158. package/dist/update-check.js +24 -1
  159. package/dist/update-cmd.js +20 -3
  160. package/dist/web/standalone/.next/BUILD_ID +1 -1
  161. package/dist/web/standalone/.next/app-path-routes-manifest.json +6 -6
  162. package/dist/web/standalone/.next/build-manifest.json +3 -3
  163. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  164. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  165. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  166. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  167. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  168. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  169. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  170. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  171. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  172. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  173. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  174. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  175. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  176. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  177. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  178. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  179. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  180. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  181. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  182. package/dist/web/standalone/.next/server/app/api/update/route.js.nft.json +1 -1
  183. package/dist/web/standalone/.next/server/app/index.html +1 -1
  184. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  185. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  186. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  187. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  188. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  189. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  190. package/dist/web/standalone/.next/server/app-paths-manifest.json +6 -6
  191. package/dist/web/standalone/.next/server/chunks/8357.js +2 -2
  192. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  193. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  194. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  195. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  196. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  197. package/dist/web/standalone/.next/static/chunks/{796.cf859a427a2cb2ac.js → 796.e0bdc932325d7e03.js} +1 -1
  198. package/dist/web/standalone/.next/static/chunks/{webpack-fbea77b5f9953368.js → webpack-f0285ce91d4ec9ef.js} +1 -1
  199. package/dist/web/standalone/node_modules/node-pty/build/Makefile +1 -1
  200. package/dist/web/standalone/node_modules/postcss/lib/container.js +26 -18
  201. package/dist/web/standalone/node_modules/postcss/lib/css-syntax-error.js +47 -14
  202. package/dist/web/standalone/node_modules/postcss/lib/declaration.js +4 -4
  203. package/dist/web/standalone/node_modules/postcss/lib/fromJSON.js +3 -3
  204. package/dist/web/standalone/node_modules/postcss/lib/input.js +54 -29
  205. package/dist/web/standalone/node_modules/postcss/lib/lazy-result.js +47 -37
  206. package/dist/web/standalone/node_modules/postcss/lib/map-generator.js +26 -9
  207. package/dist/web/standalone/node_modules/postcss/lib/no-work-result.js +57 -55
  208. package/dist/web/standalone/node_modules/postcss/lib/node.js +99 -31
  209. package/dist/web/standalone/node_modules/postcss/lib/parse.js +1 -1
  210. package/dist/web/standalone/node_modules/postcss/lib/parser.js +10 -9
  211. package/dist/web/standalone/node_modules/postcss/lib/postcss.js +12 -12
  212. package/dist/web/standalone/node_modules/postcss/lib/previous-map.js +30 -11
  213. package/dist/web/standalone/node_modules/postcss/lib/processor.js +7 -7
  214. package/dist/web/standalone/node_modules/postcss/lib/result.js +5 -5
  215. package/dist/web/standalone/node_modules/postcss/lib/rule.js +6 -6
  216. package/dist/web/standalone/node_modules/postcss/lib/stringifier.js +69 -28
  217. package/dist/web/standalone/node_modules/postcss/lib/tokenize.js +6 -2
  218. package/dist/web/standalone/node_modules/postcss/package.json +48 -48
  219. package/package.json +3 -3
  220. package/packages/cloud-mcp-gateway/package.json +2 -2
  221. package/packages/contracts/dist/rpc.d.ts +1 -0
  222. package/packages/contracts/dist/rpc.d.ts.map +1 -1
  223. package/packages/contracts/dist/rpc.js.map +1 -1
  224. package/packages/contracts/package.json +1 -1
  225. package/packages/daemon/package.json +4 -4
  226. package/packages/gsd-agent-core/dist/sdk.d.ts.map +1 -1
  227. package/packages/gsd-agent-core/dist/sdk.js +6 -4
  228. package/packages/gsd-agent-core/dist/sdk.js.map +1 -1
  229. package/packages/gsd-agent-core/package.json +5 -5
  230. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts +2 -0
  231. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
  232. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js +10 -0
  233. package/packages/gsd-agent-modes/dist/modes/interactive/components/settings-selector.js.map +1 -1
  234. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts +13 -0
  235. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  236. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js +55 -6
  237. package/packages/gsd-agent-modes/dist/modes/interactive/components/tool-execution.js.map +1 -1
  238. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts +2 -0
  239. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.d.ts.map +1 -1
  240. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js +34 -5
  241. package/packages/gsd-agent-modes/dist/modes/interactive/components/transcript-design.js.map +1 -1
  242. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  243. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js +7 -0
  244. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  245. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
  246. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js +8 -1
  247. package/packages/gsd-agent-modes/dist/modes/interactive/controllers/input-controller.js.map +1 -1
  248. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.d.ts.map +1 -1
  249. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js +11 -1
  250. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-chat-render.js.map +1 -1
  251. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts +1 -0
  252. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  253. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js +12 -0
  254. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-mode.js.map +1 -1
  255. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.d.ts.map +1 -1
  256. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js +4 -4
  257. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-auth.js.map +1 -1
  258. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.d.ts.map +1 -1
  259. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js +4 -0
  260. package/packages/gsd-agent-modes/dist/modes/interactive/interactive-selectors-settings.js.map +1 -1
  261. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  262. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js +3 -1
  263. package/packages/gsd-agent-modes/dist/modes/rpc/rpc-mode.js.map +1 -1
  264. package/packages/gsd-agent-modes/package.json +7 -7
  265. package/packages/mcp-server/README.md +12 -3
  266. package/packages/mcp-server/dist/cli-runner.d.ts +40 -0
  267. package/packages/mcp-server/dist/cli-runner.d.ts.map +1 -0
  268. package/packages/mcp-server/dist/cli-runner.js +137 -0
  269. package/packages/mcp-server/dist/cli-runner.js.map +1 -0
  270. package/packages/mcp-server/dist/cli.js +2 -53
  271. package/packages/mcp-server/dist/cli.js.map +1 -1
  272. package/packages/mcp-server/dist/moonshot-tool-schema.d.ts +29 -0
  273. package/packages/mcp-server/dist/moonshot-tool-schema.d.ts.map +1 -0
  274. package/packages/mcp-server/dist/moonshot-tool-schema.js +50 -0
  275. package/packages/mcp-server/dist/moonshot-tool-schema.js.map +1 -0
  276. package/packages/mcp-server/dist/pid-registry.d.ts +46 -0
  277. package/packages/mcp-server/dist/pid-registry.d.ts.map +1 -0
  278. package/packages/mcp-server/dist/pid-registry.js +452 -0
  279. package/packages/mcp-server/dist/pid-registry.js.map +1 -0
  280. package/packages/mcp-server/dist/probe-mode.d.ts +4 -0
  281. package/packages/mcp-server/dist/probe-mode.d.ts.map +1 -0
  282. package/packages/mcp-server/dist/probe-mode.js +10 -0
  283. package/packages/mcp-server/dist/probe-mode.js.map +1 -0
  284. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  285. package/packages/mcp-server/dist/server.js +4 -0
  286. package/packages/mcp-server/dist/server.js.map +1 -1
  287. package/packages/mcp-server/dist/stdio-watchdog.d.ts +8 -0
  288. package/packages/mcp-server/dist/stdio-watchdog.d.ts.map +1 -0
  289. package/packages/mcp-server/dist/stdio-watchdog.js +40 -0
  290. package/packages/mcp-server/dist/stdio-watchdog.js.map +1 -0
  291. package/packages/mcp-server/dist/workflow-tools.d.ts +18 -18
  292. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  293. package/packages/mcp-server/dist/workflow-tools.js +161 -81
  294. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  295. package/packages/mcp-server/package.json +5 -4
  296. package/packages/native/package.json +1 -1
  297. package/packages/pi-agent-core/dist/agent-loop.js +43 -2
  298. package/packages/pi-agent-core/dist/agent-loop.js.map +1 -1
  299. package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts +1 -0
  300. package/packages/pi-agent-core/dist/harness/env/nodejs.d.ts.map +1 -1
  301. package/packages/pi-agent-core/dist/harness/env/nodejs.js +34 -3
  302. package/packages/pi-agent-core/dist/harness/env/nodejs.js.map +1 -1
  303. package/packages/pi-agent-core/dist/index.d.ts +1 -0
  304. package/packages/pi-agent-core/dist/index.d.ts.map +1 -1
  305. package/packages/pi-agent-core/dist/index.js +3 -0
  306. package/packages/pi-agent-core/dist/index.js.map +1 -1
  307. package/packages/pi-agent-core/package.json +1 -1
  308. package/packages/pi-ai/README.md +1 -0
  309. package/packages/pi-ai/dist/image-models.generated.d.ts +2 -2
  310. package/packages/pi-ai/dist/image-models.generated.js +6 -6
  311. package/packages/pi-ai/dist/image-models.generated.js.map +1 -1
  312. package/packages/pi-ai/dist/index.d.ts +2 -0
  313. package/packages/pi-ai/dist/index.d.ts.map +1 -1
  314. package/packages/pi-ai/dist/index.js +2 -0
  315. package/packages/pi-ai/dist/index.js.map +1 -1
  316. package/packages/pi-ai/dist/models.generated.d.ts +419 -221
  317. package/packages/pi-ai/dist/models.generated.d.ts.map +1 -1
  318. package/packages/pi-ai/dist/models.generated.js +460 -261
  319. package/packages/pi-ai/dist/models.generated.js.map +1 -1
  320. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  321. package/packages/pi-ai/dist/providers/anthropic.js +12 -7
  322. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  323. package/packages/pi-ai/dist/providers/google-shared.d.ts +5 -0
  324. package/packages/pi-ai/dist/providers/google-shared.d.ts.map +1 -1
  325. package/packages/pi-ai/dist/providers/google-shared.js +12 -3
  326. package/packages/pi-ai/dist/providers/google-shared.js.map +1 -1
  327. package/packages/pi-ai/dist/providers/openai-completions.d.ts.map +1 -1
  328. package/packages/pi-ai/dist/providers/openai-completions.js +7 -3
  329. package/packages/pi-ai/dist/providers/openai-completions.js.map +1 -1
  330. package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts +9 -0
  331. package/packages/pi-ai/dist/utils/moonshot-tool-schema.d.ts.map +1 -0
  332. package/packages/pi-ai/dist/utils/moonshot-tool-schema.js +34 -0
  333. package/packages/pi-ai/dist/utils/moonshot-tool-schema.js.map +1 -0
  334. package/packages/pi-ai/dist/utils/oauth/github-copilot.d.ts.map +1 -1
  335. package/packages/pi-ai/dist/utils/oauth/github-copilot.js +6 -2
  336. package/packages/pi-ai/dist/utils/oauth/github-copilot.js.map +1 -1
  337. package/packages/pi-ai/package.json +3 -2
  338. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +2 -2
  339. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
  340. package/packages/pi-coding-agent/dist/core/auth-storage.js +19 -13
  341. package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
  342. package/packages/pi-coding-agent/dist/core/provider-readiness.d.ts.map +1 -1
  343. package/packages/pi-coding-agent/dist/core/provider-readiness.js +13 -6
  344. package/packages/pi-coding-agent/dist/core/provider-readiness.js.map +1 -1
  345. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +3 -0
  346. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  347. package/packages/pi-coding-agent/dist/core/settings-manager.js +11 -0
  348. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  349. package/packages/pi-coding-agent/dist/core/tools/bash.d.ts +11 -0
  350. package/packages/pi-coding-agent/dist/core/tools/bash.d.ts.map +1 -1
  351. package/packages/pi-coding-agent/dist/core/tools/bash.js +53 -11
  352. package/packages/pi-coding-agent/dist/core/tools/bash.js.map +1 -1
  353. package/packages/pi-coding-agent/dist/index.d.ts +1 -1
  354. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  355. package/packages/pi-coding-agent/dist/index.js +1 -1
  356. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  357. package/packages/pi-coding-agent/dist/theme/theme.d.ts.map +1 -1
  358. package/packages/pi-coding-agent/dist/theme/theme.js +45 -17
  359. package/packages/pi-coding-agent/dist/theme/theme.js.map +1 -1
  360. package/packages/pi-coding-agent/dist/utils/shell.d.ts +28 -2
  361. package/packages/pi-coding-agent/dist/utils/shell.d.ts.map +1 -1
  362. package/packages/pi-coding-agent/dist/utils/shell.js +56 -10
  363. package/packages/pi-coding-agent/dist/utils/shell.js.map +1 -1
  364. package/packages/pi-coding-agent/package.json +7 -7
  365. package/packages/pi-tui/dist/index.d.ts +1 -1
  366. package/packages/pi-tui/dist/index.d.ts.map +1 -1
  367. package/packages/pi-tui/dist/index.js +1 -1
  368. package/packages/pi-tui/dist/index.js.map +1 -1
  369. package/packages/pi-tui/dist/terminal-image.d.ts +33 -0
  370. package/packages/pi-tui/dist/terminal-image.d.ts.map +1 -1
  371. package/packages/pi-tui/dist/terminal-image.js +54 -2
  372. package/packages/pi-tui/dist/terminal-image.js.map +1 -1
  373. package/packages/pi-tui/dist/tui.d.ts +8 -0
  374. package/packages/pi-tui/dist/tui.d.ts.map +1 -1
  375. package/packages/pi-tui/dist/tui.js +63 -18
  376. package/packages/pi-tui/dist/tui.js.map +1 -1
  377. package/packages/pi-tui/dist/utils.d.ts.map +1 -1
  378. package/packages/pi-tui/dist/utils.js +110 -36
  379. package/packages/pi-tui/dist/utils.js.map +1 -1
  380. package/packages/pi-tui/package.json +2 -2
  381. package/packages/rpc-client/package.json +2 -2
  382. package/pkg/dist/theme/theme.d.ts.map +1 -1
  383. package/pkg/dist/theme/theme.js +45 -17
  384. package/pkg/dist/theme/theme.js.map +1 -1
  385. package/pkg/package.json +1 -1
  386. package/src/resources/GSD-WORKFLOW.md +5 -4
  387. package/src/resources/extensions/ask-user-questions.ts +7 -2
  388. package/src/resources/extensions/async-jobs/async-bash-cancel.test.ts +360 -0
  389. package/src/resources/extensions/async-jobs/async-bash-tool.ts +33 -56
  390. package/src/resources/extensions/async-jobs/await-tool.test.ts +139 -0
  391. package/src/resources/extensions/async-jobs/await-tool.ts +82 -12
  392. package/src/resources/extensions/async-jobs/index.ts +79 -0
  393. package/src/resources/extensions/async-jobs/job-manager.ts +21 -1
  394. package/src/resources/extensions/bg-shell/bg-shell-command.ts +6 -6
  395. package/src/resources/extensions/bg-shell/bg-shell-tool.ts +10 -6
  396. package/src/resources/extensions/bg-shell/overlay.ts +9 -5
  397. package/src/resources/extensions/bg-shell/process-manager.ts +50 -25
  398. package/src/resources/extensions/bg-shell/readiness-detector.ts +12 -0
  399. package/src/resources/extensions/bg-shell/tests/lifecycle-and-utilities.test.ts +48 -1
  400. package/src/resources/extensions/browser-tools/tests/gsd-browser-launch-config.test.mjs +40 -1
  401. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +531 -226
  402. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +672 -7
  403. package/src/resources/extensions/claude-code-cli/turn-assembler.ts +38 -1
  404. package/src/resources/extensions/gsd/auto/closeout.ts +309 -0
  405. package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +21 -3
  406. package/src/resources/extensions/gsd/auto/detect-stuck.ts +32 -9
  407. package/src/resources/extensions/gsd/auto/dispatch-history.ts +168 -0
  408. package/src/resources/extensions/gsd/auto/dispatch-key.ts +39 -0
  409. package/src/resources/extensions/gsd/auto/dispatch.ts +449 -0
  410. package/src/resources/extensions/gsd/auto/finalize.ts +445 -0
  411. package/src/resources/extensions/gsd/auto/loop.ts +7 -1
  412. package/src/resources/extensions/gsd/auto/milestone-lease-reclaim.ts +74 -0
  413. package/src/resources/extensions/gsd/auto/orchestrator.ts +193 -71
  414. package/src/resources/extensions/gsd/auto/phase-helpers.ts +199 -0
  415. package/src/resources/extensions/gsd/auto/phases.ts +58 -3022
  416. package/src/resources/extensions/gsd/auto/pre-dispatch.ts +704 -0
  417. package/src/resources/extensions/gsd/auto/session.ts +3 -0
  418. package/src/resources/extensions/gsd/auto/unit-phase.ts +910 -0
  419. package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +1 -1
  420. package/src/resources/extensions/gsd/auto/worktree-safety-phase.ts +149 -0
  421. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +18 -48
  422. package/src/resources/extensions/gsd/auto-dispatch.ts +48 -61
  423. package/src/resources/extensions/gsd/auto-model-selection.ts +41 -12
  424. package/src/resources/extensions/gsd/auto-post-unit.ts +33 -12
  425. package/src/resources/extensions/gsd/auto-prompts.ts +115 -35
  426. package/src/resources/extensions/gsd/auto-start.ts +36 -18
  427. package/src/resources/extensions/gsd/auto-unit-closeout.ts +83 -28
  428. package/src/resources/extensions/gsd/auto-unit-tool-scope.ts +4 -4
  429. package/src/resources/extensions/gsd/auto-verification.ts +26 -28
  430. package/src/resources/extensions/gsd/auto-worktree.ts +15 -2
  431. package/src/resources/extensions/gsd/auto.ts +64 -2
  432. package/src/resources/extensions/gsd/blocked-models.ts +49 -0
  433. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +34 -5
  434. package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +79 -12
  435. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +2 -2
  436. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +163 -55
  437. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +350 -86
  438. package/src/resources/extensions/gsd/browser-daemon-auto-prep.ts +108 -0
  439. package/src/resources/extensions/gsd/closeout-wizard.ts +102 -0
  440. package/src/resources/extensions/gsd/commands/context.ts +16 -2
  441. package/src/resources/extensions/gsd/commands-handlers.ts +46 -3
  442. package/src/resources/extensions/gsd/commands-mcp-status.ts +2 -2
  443. package/src/resources/extensions/gsd/commands-workflow-templates.ts +11 -4
  444. package/src/resources/extensions/gsd/consent-question.ts +431 -0
  445. package/src/resources/extensions/gsd/consent-verdict.ts +86 -0
  446. package/src/resources/extensions/gsd/constants.ts +0 -3
  447. package/src/resources/extensions/gsd/crash-recovery.ts +10 -2
  448. package/src/resources/extensions/gsd/db/engine.ts +5 -3
  449. package/src/resources/extensions/gsd/db/queries.ts +66 -0
  450. package/src/resources/extensions/gsd/db-writer.ts +11 -19
  451. package/src/resources/extensions/gsd/dispatch-guard.ts +8 -31
  452. package/src/resources/extensions/gsd/doctor-engine-checks.ts +5 -4
  453. package/src/resources/extensions/gsd/doctor-environment.ts +267 -142
  454. package/src/resources/extensions/gsd/doctor-git-checks.ts +2 -19
  455. package/src/resources/extensions/gsd/engine-hook-contract.ts +79 -0
  456. package/src/resources/extensions/gsd/exec-sandbox.ts +49 -9
  457. package/src/resources/extensions/gsd/files.ts +33 -12
  458. package/src/resources/extensions/gsd/gsd-command-home.ts +13 -3
  459. package/src/resources/extensions/gsd/gsd-db.ts +13 -10
  460. package/src/resources/extensions/gsd/guidance.ts +78 -0
  461. package/src/resources/extensions/gsd/guided-flow.ts +145 -24
  462. package/src/resources/extensions/gsd/health-widget.ts +91 -27
  463. package/src/resources/extensions/gsd/markdown-renderer.ts +11 -0
  464. package/src/resources/extensions/gsd/mcp-bridge.ts +39 -0
  465. package/src/resources/extensions/gsd/memory-relations.ts +1 -1
  466. package/src/resources/extensions/gsd/milestone-closeout.ts +109 -24
  467. package/src/resources/extensions/gsd/milestone-planning-persistence.ts +2 -2
  468. package/src/resources/extensions/gsd/milestone-reopen-events.ts +3 -6
  469. package/src/resources/extensions/gsd/milestone-settlement.ts +2 -2
  470. package/src/resources/extensions/gsd/notifications.ts +13 -6
  471. package/src/resources/extensions/gsd/parsers-legacy.ts +16 -4
  472. package/src/resources/extensions/gsd/preferences-models.ts +2 -1
  473. package/src/resources/extensions/gsd/projection-flush.ts +20 -0
  474. package/src/resources/extensions/gsd/prompts/complete-slice.md +4 -4
  475. package/src/resources/extensions/gsd/prompts/execute-task.md +3 -2
  476. package/src/resources/extensions/gsd/prompts/plan-milestone.md +1 -1
  477. package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
  478. package/src/resources/extensions/gsd/prompts/quick-task.md +1 -1
  479. package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +1 -1
  480. package/src/resources/extensions/gsd/prompts/refine-slice.md +1 -1
  481. package/src/resources/extensions/gsd/prompts/replan-slice.md +1 -1
  482. package/src/resources/extensions/gsd/prompts/research-milestone.md +1 -1
  483. package/src/resources/extensions/gsd/prompts/research-slice.md +1 -1
  484. package/src/resources/extensions/gsd/prompts/rewrite-docs.md +1 -1
  485. package/src/resources/extensions/gsd/prompts/run-uat.md +9 -5
  486. package/src/resources/extensions/gsd/prompts/system.md +5 -2
  487. package/src/resources/extensions/gsd/prompts/triage-captures.md +1 -1
  488. package/src/resources/extensions/gsd/prompts/validate-milestone.md +1 -1
  489. package/src/resources/extensions/gsd/prompts/workflow-start.md +2 -1
  490. package/src/resources/extensions/gsd/reactive-graph.ts +11 -1
  491. package/src/resources/extensions/gsd/roadmap-slices.ts +28 -3
  492. package/src/resources/extensions/gsd/safety/destructive-confirmation.ts +134 -0
  493. package/src/resources/extensions/gsd/session-lock.ts +1 -1
  494. package/src/resources/extensions/gsd/skill-activation.ts +3 -6
  495. package/src/resources/extensions/gsd/state.ts +12 -1
  496. package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +1 -1
  497. package/src/resources/extensions/gsd/tests/auto-blocked-remediation-message.test.ts +1 -1
  498. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +206 -22
  499. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +97 -1
  500. package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +273 -37
  501. package/src/resources/extensions/gsd/tests/auto-pause-double-entry-guard.test.ts +1 -1
  502. package/src/resources/extensions/gsd/tests/auto-paused-ui-cleanup.test.ts +77 -1
  503. package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +2 -1
  504. package/src/resources/extensions/gsd/tests/auto-remote-session-lock-cleanup.test.ts +65 -3
  505. package/src/resources/extensions/gsd/tests/auto-start-orphan-bootstrap.test.ts +236 -0
  506. package/src/resources/extensions/gsd/tests/auto-unit-closeout.test.ts +169 -1
  507. package/src/resources/extensions/gsd/tests/blocked-models.test.ts +19 -0
  508. package/src/resources/extensions/gsd/tests/browser-daemon-auto-prep.test.ts +144 -0
  509. package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +42 -0
  510. package/src/resources/extensions/gsd/tests/complete-task.test.ts +141 -5
  511. package/src/resources/extensions/gsd/tests/consent-question.test.ts +351 -0
  512. package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +67 -0
  513. package/src/resources/extensions/gsd/tests/db-writer.test.ts +15 -4
  514. package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +12 -11
  515. package/src/resources/extensions/gsd/tests/derive-state-helpers.test.ts +36 -0
  516. package/src/resources/extensions/gsd/tests/destructive-confirmation.test.ts +303 -0
  517. package/src/resources/extensions/gsd/tests/discuss-routing-fixes.test.ts +12 -2
  518. package/src/resources/extensions/gsd/tests/dispatch-history.test.ts +328 -0
  519. package/src/resources/extensions/gsd/tests/dist-redirect.mjs +8 -0
  520. package/src/resources/extensions/gsd/tests/doctor-git-checks-terminal.test.ts +73 -0
  521. package/src/resources/extensions/gsd/tests/dynamic-bash-no-cap.test.ts +132 -0
  522. package/src/resources/extensions/gsd/tests/engine-hook-contract.test.ts +148 -0
  523. package/src/resources/extensions/gsd/tests/engine-interfaces-contract.test.ts +117 -91
  524. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +113 -0
  525. package/src/resources/extensions/gsd/tests/exec-graceful-kill.test.ts +193 -0
  526. package/src/resources/extensions/gsd/tests/exec-tool.test.ts +29 -1
  527. package/src/resources/extensions/gsd/tests/gsd-command-home.test.ts +120 -0
  528. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +27 -0
  529. package/src/resources/extensions/gsd/tests/guidance.test.ts +23 -0
  530. package/src/resources/extensions/gsd/tests/guided-dispatch-root.test.ts +18 -6
  531. package/src/resources/extensions/gsd/tests/integration/auto-worktree.test.ts +15 -0
  532. package/src/resources/extensions/gsd/tests/integration/doctor-environment-async.test.ts +104 -0
  533. package/src/resources/extensions/gsd/tests/integration/run-uat.test.ts +217 -0
  534. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +47 -16
  535. package/src/resources/extensions/gsd/tests/mcp-project-config.test.ts +3 -1
  536. package/src/resources/extensions/gsd/tests/mcp-readiness-preflight.test.ts +205 -0
  537. package/src/resources/extensions/gsd/tests/mcp-status.test.ts +6 -5
  538. package/src/resources/extensions/gsd/tests/milestone-closeout.test.ts +95 -4
  539. package/src/resources/extensions/gsd/tests/milestone-merge-stash-restore.test.ts +1 -1
  540. package/src/resources/extensions/gsd/tests/milestone-report-path.test.ts +1 -1
  541. package/src/resources/extensions/gsd/tests/milestone-settlement.test.ts +92 -0
  542. package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +1 -1
  543. package/src/resources/extensions/gsd/tests/model-unittype-mapping.test.ts +32 -1
  544. package/src/resources/extensions/gsd/tests/notifications.test.ts +64 -9
  545. package/src/resources/extensions/gsd/tests/oauth-api-model-routing.test.ts +167 -0
  546. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +18 -0
  547. package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +2 -2
  548. package/src/resources/extensions/gsd/tests/parsers-legacy-importers.test.ts +143 -0
  549. package/src/resources/extensions/gsd/tests/phases-merge-error-stops-auto.test.ts +1 -1
  550. package/src/resources/extensions/gsd/tests/phases-terminal-complete-idempotent.test.ts +242 -0
  551. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +3 -3
  552. package/src/resources/extensions/gsd/tests/post-exec-retry-bypass.test.ts +63 -2
  553. package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +10 -2
  554. package/src/resources/extensions/gsd/tests/prompt-db.test.ts +124 -6
  555. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +2 -4
  556. package/src/resources/extensions/gsd/tests/remote-notification-from-desktop.test.ts +31 -81
  557. package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +68 -0
  558. package/src/resources/extensions/gsd/tests/runtime-invariant-modules.test.ts +26 -2
  559. package/src/resources/extensions/gsd/tests/single-writer-invariant.test.ts +170 -48
  560. package/src/resources/extensions/gsd/tests/skill-activation.test.ts +20 -17
  561. package/src/resources/extensions/gsd/tests/start-auto-detached.test.ts +7 -3
  562. package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +1 -1
  563. package/src/resources/extensions/gsd/tests/teardown-chdir-failure-clears-registry.test.ts +17 -0
  564. package/src/resources/extensions/gsd/tests/token-tool-gating.test.ts +45 -2
  565. package/src/resources/extensions/gsd/tests/tool-surface-readiness.test.ts +184 -10
  566. package/src/resources/extensions/gsd/tests/tool-unavailable-retry.test.ts +33 -0
  567. package/src/resources/extensions/gsd/tests/transport-gate-double-complete.test.ts +139 -0
  568. package/src/resources/extensions/gsd/tests/uat-policy.test.ts +88 -0
  569. package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +44 -0
  570. package/src/resources/extensions/gsd/tests/uok-audit-unified.test.ts +8 -0
  571. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +1 -1
  572. package/src/resources/extensions/gsd/tests/verification-verdict.test.ts +2 -0
  573. package/src/resources/extensions/gsd/tests/workflow-events.test.ts +19 -0
  574. package/src/resources/extensions/gsd/tests/workflow-mcp-readiness-cache.test.ts +119 -0
  575. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +65 -2
  576. package/src/resources/extensions/gsd/tests/workflow-phase-contract-matrix.test.ts +332 -0
  577. package/src/resources/extensions/gsd/tests/workflow-reconcile.test.ts +20 -0
  578. package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +92 -0
  579. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +273 -38
  580. package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +1 -1
  581. package/src/resources/extensions/gsd/tests/worktree-project-root-degrade.test.ts +1 -1
  582. package/src/resources/extensions/gsd/tests/worktree-safety-phase.test.ts +100 -0
  583. package/src/resources/extensions/gsd/tests/worktree-safety.test.ts +72 -0
  584. package/src/resources/extensions/gsd/tests/worktree-teardown-safety.test.ts +22 -0
  585. package/src/resources/extensions/gsd/tests/worktree.test.ts +18 -0
  586. package/src/resources/extensions/gsd/tests/write-gate-seam.test.ts +358 -0
  587. package/src/resources/extensions/gsd/tests/write-gate.test.ts +67 -1
  588. package/src/resources/extensions/gsd/tool-contract.ts +38 -3
  589. package/src/resources/extensions/gsd/tool-presentation-plan.ts +4 -4
  590. package/src/resources/extensions/gsd/tool-surface-readiness.ts +126 -19
  591. package/src/resources/extensions/gsd/tools/complete-milestone.ts +3 -2
  592. package/src/resources/extensions/gsd/tools/complete-slice.ts +22 -12
  593. package/src/resources/extensions/gsd/tools/complete-task.ts +90 -2
  594. package/src/resources/extensions/gsd/tools/exec-tool.ts +4 -0
  595. package/src/resources/extensions/gsd/tools/plan-slice.ts +2 -2
  596. package/src/resources/extensions/gsd/tools/plan-task.ts +2 -2
  597. package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +2 -2
  598. package/src/resources/extensions/gsd/tools/reopen-milestone.ts +2 -2
  599. package/src/resources/extensions/gsd/tools/reopen-slice.ts +2 -2
  600. package/src/resources/extensions/gsd/tools/reopen-task.ts +2 -2
  601. package/src/resources/extensions/gsd/tools/replan-slice.ts +2 -2
  602. package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +81 -2
  603. package/src/resources/extensions/gsd/uat-policy.ts +60 -15
  604. package/src/resources/extensions/gsd/unit-context-composer.ts +99 -0
  605. package/src/resources/extensions/gsd/unit-registry.ts +34 -4
  606. package/src/resources/extensions/gsd/verdict-parser.ts +1 -1
  607. package/src/resources/extensions/gsd/verification-verdict.ts +4 -2
  608. package/src/resources/extensions/gsd/workflow-event-ledger.ts +131 -0
  609. package/src/resources/extensions/gsd/workflow-event-vocabulary.ts +59 -0
  610. package/src/resources/extensions/gsd/workflow-events.ts +12 -20
  611. package/src/resources/extensions/gsd/workflow-mcp-auto-prep.ts +2 -0
  612. package/src/resources/extensions/gsd/workflow-mcp-readiness-cache.ts +150 -0
  613. package/src/resources/extensions/gsd/workflow-reconcile.ts +29 -62
  614. package/src/resources/extensions/gsd/worktree-lifecycle.ts +3 -8
  615. package/src/resources/extensions/gsd/worktree-manager.ts +6 -1
  616. package/src/resources/extensions/gsd/worktree-safety.ts +41 -39
  617. package/src/resources/extensions/gsd/worktree.ts +7 -1
  618. package/src/resources/extensions/mcp-client/manager.ts +7 -1
  619. package/src/resources/extensions/shared/gsd-browser-cli.ts +54 -3
  620. package/src/resources/shared/gsd-browser-path-sync.ts +273 -0
  621. package/src/resources/shared/package-manager-detection.ts +1 -1
  622. package/src/resources/shared/package.json +3 -0
  623. package/src/resources/skills/create-skill/SKILL.md +3 -0
  624. package/src/resources/skills/create-skill/references/skill-structure.md +1 -0
  625. package/dist/resources/extensions/gsd/user-input-boundary.js +0 -218
  626. package/dist/resources/skills/gsd-browser/SKILL.md +0 -41
  627. package/src/resources/extensions/gsd/tests/user-input-boundary.test.ts +0 -173
  628. package/src/resources/extensions/gsd/user-input-boundary.ts +0 -216
  629. package/src/resources/skills/gsd-browser/SKILL.md +0 -41
  630. /package/dist/web/standalone/.next/static/{AOpDeK_gJHU8OZjRo31gQ → pZbHa49xI-knmKlphIRq0}/_buildManifest.js +0 -0
  631. /package/dist/web/standalone/.next/static/{AOpDeK_gJHU8OZjRo31gQ → pZbHa49xI-knmKlphIRq0}/_ssgManifest.js +0 -0
@@ -3,22 +3,24 @@
3
3
 
4
4
  import test from "node:test";
5
5
  import assert from "node:assert/strict";
6
- import { mkdtempSync, mkdirSync, writeFileSync, rmSync } from "node:fs";
6
+ import { mkdtempSync, mkdirSync, writeFileSync, rmSync, existsSync, readFileSync } from "node:fs";
7
7
  import { join } from "node:path";
8
8
  import { tmpdir } from "node:os";
9
9
  import { openDatabase, insertAssessment, insertMilestone, insertSlice, closeDatabase } from "../gsd-db.js";
10
10
  import {
11
11
  isMilestoneCloseoutSettled,
12
12
  evaluateCompleteMilestoneDispatch,
13
+ isCompletedMilestoneTerminal,
14
+ repairMissingMilestoneSummaryProjection,
13
15
  } from "../milestone-closeout.js";
14
16
  import type { DispatchContext } from "../auto-dispatch.js";
15
17
 
16
18
  /** Build a minimal DispatchContext for the dispatch-policy branches under test. */
17
- function makeDispatchCtx(base: string, phase: string): DispatchContext {
19
+ function makeDispatchCtx(base: string, phase: string, mid = "M001"): DispatchContext {
18
20
  return {
19
21
  basePath: base,
20
- mid: "M001",
21
- midTitle: "M001: Test",
22
+ mid,
23
+ midTitle: `${mid}: Test`,
22
24
  state: { phase } as DispatchContext["state"],
23
25
  prefs: undefined,
24
26
  } as DispatchContext;
@@ -119,3 +121,92 @@ test("evaluateCompleteMilestoneDispatch skips when milestone is already closed",
119
121
  assert.ok(action, "an already-closed milestone in completing-milestone should yield an action");
120
122
  assert.equal(action!.action, "skip", "already-closed milestone should resolve to skip (idempotent)");
121
123
  });
124
+
125
+ test("isCompletedMilestoneTerminal accepts DB complete without SUMMARY artifact", async () => {
126
+ const base = mkdtempSync(join(tmpdir(), "gsd-terminal-db-complete-"));
127
+ tmpDirs.push(base);
128
+ mkdirSync(join(base, ".gsd"), { recursive: true });
129
+ openDatabase(join(base, ".gsd", "gsd.db"));
130
+ insertMilestone({ id: "M008", title: "Done", status: "complete" });
131
+ insertSlice({ id: "S01", milestoneId: "M008", title: "Slice", status: "complete" });
132
+
133
+ assert.equal(await isCompletedMilestoneTerminal(base, "M008"), true);
134
+ });
135
+
136
+ test("isCompletedMilestoneTerminal accepts validation-pass with all slices closed", async () => {
137
+ const base = mkdtempSync(join(tmpdir(), "gsd-terminal-validation-pass-"));
138
+ tmpDirs.push(base);
139
+ mkdirSync(join(base, ".gsd"), { recursive: true });
140
+ openDatabase(join(base, ".gsd", "gsd.db"));
141
+ insertMilestone({ id: "M008", title: "Active", status: "active" });
142
+ insertSlice({ id: "S01", milestoneId: "M008", title: "Slice", status: "complete" });
143
+ insertAssessment({
144
+ path: "milestones/M008/M008-VALIDATION.md",
145
+ milestoneId: "M008",
146
+ status: "pass",
147
+ scope: "milestone-validation",
148
+ fullContent: "verdict: pass",
149
+ });
150
+
151
+ assert.equal(await isCompletedMilestoneTerminal(base, "M008"), true);
152
+ });
153
+
154
+ test("evaluateCompleteMilestoneDispatch repairs missing SUMMARY when DB is closed", async () => {
155
+ const base = mkdtempSync(join(tmpdir(), "gsd-dispatch-repair-summary-"));
156
+ tmpDirs.push(base);
157
+ mkdirSync(join(base, ".gsd", "milestones", "M008"), { recursive: true });
158
+ openDatabase(join(base, ".gsd", "gsd.db"));
159
+ insertMilestone({ id: "M008", title: "Live Text Search", status: "complete" });
160
+ insertSlice({ id: "S01", milestoneId: "M008", title: "Slice", status: "complete" });
161
+ insertAssessment({
162
+ path: "milestones/M008/M008-VALIDATION.md",
163
+ milestoneId: "M008",
164
+ status: "pass",
165
+ scope: "milestone-validation",
166
+ fullContent: "verdict: pass",
167
+ });
168
+
169
+ const action = await evaluateCompleteMilestoneDispatch(
170
+ makeDispatchCtx(base, "completing-milestone", "M008"),
171
+ );
172
+ assert.equal(action?.action, "skip");
173
+ assert.ok(
174
+ existsSync(join(base, ".gsd", "milestones", "M008", "M008-SUMMARY.md")),
175
+ "repair should write the missing milestone SUMMARY projection",
176
+ );
177
+ });
178
+
179
+ test("repairMissingMilestoneSummaryProjection succeeds when milestone dir does not exist yet", async () => {
180
+ // Regression: resolveExpectedArtifactPath returns null before the milestone
181
+ // directory exists. The post-write success check must use the handler's
182
+ // returned summaryPath (the absolute path it just created), not the
183
+ // pre-write resolver result, otherwise repair always reports failure and
184
+ // dispatch falls back to re-dispatching complete-milestone.
185
+ const base = mkdtempSync(join(tmpdir(), "gsd-repair-summary-new-dir-"));
186
+ tmpDirs.push(base);
187
+ mkdirSync(join(base, ".gsd"), { recursive: true });
188
+ openDatabase(join(base, ".gsd", "gsd.db"));
189
+ insertMilestone({ id: "M042", title: "Done", status: "complete" });
190
+
191
+ const repair = await repairMissingMilestoneSummaryProjection(base, "M042");
192
+ assert.equal(repair.ok, true, "repair should report success when handler creates the SUMMARY");
193
+ assert.ok(
194
+ existsSync(join(base, ".gsd", "milestones", "M042", "M042-SUMMARY.md")),
195
+ "repair should write the SUMMARY artifact to the canonical projection path",
196
+ );
197
+ });
198
+
199
+ test("repairMissingMilestoneSummaryProjection is idempotent when SUMMARY exists", async () => {
200
+ const base = mkdtempSync(join(tmpdir(), "gsd-repair-summary-idempotent-"));
201
+ tmpDirs.push(base);
202
+ const milestoneDir = join(base, ".gsd", "milestones", "M001");
203
+ mkdirSync(milestoneDir, { recursive: true });
204
+ openDatabase(join(base, ".gsd", "gsd.db"));
205
+ insertMilestone({ id: "M001", title: "Done", status: "complete" });
206
+ const summaryPath = join(milestoneDir, "M001-SUMMARY.md");
207
+ writeFileSync(summaryPath, "# Existing summary\n");
208
+
209
+ const repair = await repairMissingMilestoneSummaryProjection(base, "M001");
210
+ assert.equal(repair.ok, true);
211
+ assert.equal(readFileSync(summaryPath, "utf-8"), "# Existing summary\n");
212
+ });
@@ -4,7 +4,7 @@
4
4
  import test from "node:test";
5
5
  import assert from "node:assert/strict";
6
6
 
7
- import { _runMilestoneMergeWithStashRestore } from "../auto/phases.js";
7
+ import { _runMilestoneMergeWithStashRestore } from "../auto/closeout.js";
8
8
  import type { IterationContext } from "../auto/types.js";
9
9
  import { MergeConflictError } from "../git-service.js";
10
10
  import type {
@@ -10,7 +10,7 @@
10
10
  import { describe, test } from "node:test";
11
11
  import assert from "node:assert/strict";
12
12
 
13
- import { _resolveDispatchGuardBasePath, _resolveReportBasePath } from "../auto/phases.ts";
13
+ import { _resolveDispatchGuardBasePath, _resolveReportBasePath } from "../auto/phase-helpers.ts";
14
14
 
15
15
  describe("_resolveReportBasePath", () => {
16
16
  test("uses originalBasePath when set (worktree scenario)", () => {
@@ -0,0 +1,92 @@
1
+ // Project/App: gsd-pi
2
+ // File Purpose: Regression tests for milestone closeout settlement guidance.
3
+
4
+ import test, { afterEach } from "node:test";
5
+ import assert from "node:assert/strict";
6
+ import { execFileSync } from "node:child_process";
7
+ import { mkdirSync, mkdtempSync, rmSync, writeFileSync } from "node:fs";
8
+ import { tmpdir } from "node:os";
9
+ import { dirname, join } from "node:path";
10
+
11
+ import { evaluateAllCompleteSettlement } from "../milestone-settlement.ts";
12
+ import { resolveExpectedArtifactPath } from "../auto-artifact-paths.ts";
13
+ import {
14
+ closeDatabase,
15
+ insertAssessment,
16
+ insertMilestone,
17
+ insertSlice,
18
+ insertTask,
19
+ openDatabase,
20
+ } from "../gsd-db.ts";
21
+
22
+ let base = "";
23
+
24
+ function runGit(cwd: string, args: string[]): void {
25
+ execFileSync("git", args, { cwd, stdio: "ignore" });
26
+ }
27
+
28
+ function initRepo(root: string): void {
29
+ runGit(root, ["init", "-b", "main"]);
30
+ runGit(root, ["config", "user.email", "test@example.com"]);
31
+ runGit(root, ["config", "user.name", "Test User"]);
32
+ writeFileSync(join(root, "README.md"), "# fixture\n");
33
+ runGit(root, ["add", "."]);
34
+ runGit(root, ["commit", "-m", "chore: init"]);
35
+ }
36
+
37
+ function seedClosedMilestone(root: string, worktree: string): void {
38
+ mkdirSync(join(root, ".gsd"), { recursive: true });
39
+ openDatabase(join(root, ".gsd", "gsd.db"));
40
+ insertMilestone({ id: "M001", title: "Milestone One", status: "complete" });
41
+ insertSlice({ id: "S01", milestoneId: "M001", title: "Slice One", status: "complete" });
42
+ insertTask({
43
+ id: "T01",
44
+ sliceId: "S01",
45
+ milestoneId: "M001",
46
+ title: "Task One",
47
+ status: "complete",
48
+ verificationResult: "passed",
49
+ });
50
+ insertAssessment({
51
+ path: ".gsd/milestones/M001/M001-VALIDATION.md",
52
+ milestoneId: "M001",
53
+ status: "pass",
54
+ scope: "milestone-validation",
55
+ fullContent: "verdict: pass\n",
56
+ });
57
+
58
+ mkdirSync(join(worktree, ".gsd", "milestones", "M001"), { recursive: true });
59
+ const summaryPath = resolveExpectedArtifactPath("complete-milestone", "M001", worktree);
60
+ assert.ok(summaryPath, "complete-milestone summary path should resolve");
61
+ mkdirSync(dirname(summaryPath), { recursive: true });
62
+ writeFileSync(summaryPath, "# Milestone One\n\nComplete.\n");
63
+ }
64
+
65
+ afterEach(() => {
66
+ try { closeDatabase(); } catch { /* ignore */ }
67
+ if (base) rmSync(base, { recursive: true, force: true });
68
+ base = "";
69
+ });
70
+
71
+ test("merge-pending settlement routes back to complete-milestone dispatch without manual merge guidance", () => {
72
+ base = mkdtempSync(join(tmpdir(), "gsd-milestone-settlement-"));
73
+ initRepo(base);
74
+ const worktree = join(base, ".gsd", "worktrees", "M001");
75
+ mkdirSync(dirname(worktree), { recursive: true });
76
+ runGit(base, ["worktree", "add", "-b", "milestone/M001", worktree, "HEAD"]);
77
+ seedClosedMilestone(base, worktree);
78
+
79
+ const result = evaluateAllCompleteSettlement({
80
+ milestoneId: "M001",
81
+ statePhase: "complete",
82
+ basePath: worktree,
83
+ originalBasePath: base,
84
+ milestoneMerged: false,
85
+ });
86
+
87
+ assert.equal(result.ok, false);
88
+ assert.equal(result.reason, "merge-pending");
89
+ assert.equal(result.nextAction, "Retry `/gsd dispatch complete-milestone M001`.");
90
+ assert.doesNotMatch(result.message, /merge manually/i);
91
+ assert.doesNotMatch(result.nextAction, /merge manually/i);
92
+ });
@@ -14,7 +14,7 @@ import { readFileSync, mkdtempSync, mkdirSync, writeFileSync, existsSync, rmSync
14
14
  import { join } from "node:path";
15
15
  import { tmpdir } from "node:os";
16
16
  import { AutoSession } from "../auto/session.ts";
17
- import { runPreDispatch } from "../auto/phases.ts";
17
+ import { runPreDispatch } from "../auto/pre-dispatch.ts";
18
18
 
19
19
  test("milestone transition archives completed units and rebuilds state", async () => {
20
20
  const tempDir = realpathSync(mkdtempSync(join(tmpdir(), "gsd-cu-reset-")));
@@ -14,7 +14,7 @@ import { tmpdir } from "node:os";
14
14
  import { resolveExpectedArtifactPath } from "../auto-artifact-paths.ts";
15
15
  import { unitPhaseLabel, unitVerb } from "../auto-dashboard.ts";
16
16
  import { classifyUnitPhase } from "../metrics.ts";
17
- import { resolveModelWithFallbacksForUnit } from "../preferences-models.ts";
17
+ import { resolveDefaultSessionModel, resolveModelWithFallbacksForUnit } from "../preferences-models.ts";
18
18
  import { KNOWN_UNIT_LABELS } from "../preferences-types.ts";
19
19
 
20
20
  function withModelPreferences<T>(fn: () => T): T {
@@ -92,6 +92,37 @@ test("run-uat falls back to completion when uat bucket is not configured", () =>
92
92
  }
93
93
  });
94
94
 
95
+ test("default session model resolves from the explicit project base path", () => {
96
+ const oldHome = process.env.GSD_HOME;
97
+ const originalCwd = process.cwd();
98
+ const home = mkdtempSync(join(tmpdir(), "gsd-model-map-home-"));
99
+ const base = mkdtempSync(join(tmpdir(), "gsd-model-map-project-"));
100
+
101
+ try {
102
+ process.env.GSD_HOME = home;
103
+ mkdirSync(join(base, ".gsd"), { recursive: true });
104
+ writeFileSync(join(base, ".gsd", "PREFERENCES.md"), [
105
+ "---",
106
+ "models:",
107
+ " execution: gpt-5.5",
108
+ "---",
109
+ "",
110
+ ].join("\n"));
111
+ process.chdir(home);
112
+
113
+ assert.deepEqual(resolveDefaultSessionModel("openai-codex", base), {
114
+ provider: "openai-codex",
115
+ id: "gpt-5.5",
116
+ });
117
+ } finally {
118
+ process.chdir(originalCwd);
119
+ if (oldHome === undefined) delete process.env.GSD_HOME;
120
+ else process.env.GSD_HOME = oldHome;
121
+ rmSync(home, { recursive: true, force: true });
122
+ rmSync(base, { recursive: true, force: true });
123
+ }
124
+ });
125
+
95
126
  test("every known unit label with a dispatch phase resolves when all model buckets are configured", () => {
96
127
  withModelPreferences(() => {
97
128
  const missing = KNOWN_UNIT_LABELS.filter((unitType) => !resolveModelWithFallbacksForUnit(unitType));
@@ -1,7 +1,12 @@
1
1
  import test from "node:test";
2
2
  import assert from "node:assert/strict";
3
- import { readFileSync } from "node:fs";
3
+ import { mkdtempSync, mkdirSync, rmSync, writeFileSync } from "node:fs";
4
+ import { tmpdir } from "node:os";
5
+ import { join } from "node:path";
4
6
 
7
+ import { playQuestionBell } from "../../ask-user-questions.js";
8
+ import { stopAuto } from "../auto.js";
9
+ import { autoSession } from "../auto-runtime-state.js";
5
10
  import {
6
11
  buildDesktopNotificationCommand,
7
12
  shouldSendDesktopNotification,
@@ -58,18 +63,68 @@ test("playNotificationBell is silent when disabled", () => {
58
63
  assert.equal(output, "");
59
64
  });
60
65
 
61
- test("ask_user_questions plays local bell before waiting for an answer", () => {
62
- const source = readFileSync(new URL("../../ask-user-questions.ts", import.meta.url), "utf-8");
66
+ test("playQuestionBell writes a terminal bell when local bell is enabled", async () => {
67
+ let output = "";
68
+ const stream = { write: (chunk: string) => { output += chunk; } };
63
69
 
64
- assert.match(source, /playNotificationBell\("question"\)/);
65
- assert.match(source, /await playQuestionBell\(\)/);
70
+ await playQuestionBell({ enabled: true, local_bell: true }, stream);
71
+
72
+ assert.equal(output, "\u0007");
66
73
  });
67
74
 
68
- test("stopAuto plays local bell for auto-mode stop notifications", () => {
69
- const source = readFileSync(new URL("../auto.ts", import.meta.url), "utf-8");
75
+ test("playQuestionBell is silent when local bell is disabled", async () => {
76
+ let output = "";
77
+ const stream = { write: (chunk: string) => { output += chunk; } };
70
78
 
71
- assert.match(source, /import \{[^}]*playNotificationBell[^}]*\} from "\.\/notifications\.js"/);
72
- assert.match(source, /playNotificationBell\("stop", loadedPreferences\?\.notifications\)/);
79
+ await playQuestionBell({ enabled: true, local_bell: false }, stream);
80
+
81
+ assert.equal(output, "");
82
+ });
83
+
84
+ test("stopAuto plays local bell for auto-mode stop notifications", async () => {
85
+ const base = mkdtempSync(join(tmpdir(), "gsd-stop-bell-"));
86
+ const previousCwd = process.cwd();
87
+ const previousStderrWrite = process.stderr.write;
88
+ const previousStderrIsTTY = process.stderr.isTTY;
89
+ let bellOutput = "";
90
+
91
+ autoSession.reset();
92
+ autoSession.active = true;
93
+ autoSession.basePath = base;
94
+
95
+ mkdirSync(join(base, ".gsd"), { recursive: true });
96
+ writeFileSync(
97
+ join(base, ".gsd", "PREFERENCES.md"),
98
+ "---\nnotifications:\n enabled: true\n local_bell: true\n---\n",
99
+ "utf-8",
100
+ );
101
+
102
+ process.stderr.isTTY = true;
103
+ process.stderr.write = ((chunk: string | Uint8Array) => {
104
+ if (typeof chunk === "string") {
105
+ bellOutput += chunk;
106
+ }
107
+ return true;
108
+ }) as typeof process.stderr.write;
109
+
110
+ try {
111
+ await stopAuto(
112
+ { hasUI: false, ui: { notify: () => {}, setStatus: () => {}, setWidget: () => {}, setHeader: () => {} } } as any,
113
+ undefined,
114
+ "test stop",
115
+ );
116
+
117
+ assert.ok(
118
+ bellOutput.includes("\u0007"),
119
+ "stopAuto must write a terminal bell to stderr when the local bell preference is enabled",
120
+ );
121
+ } finally {
122
+ process.stderr.write = previousStderrWrite;
123
+ process.stderr.isTTY = previousStderrIsTTY;
124
+ autoSession.reset();
125
+ process.chdir(previousCwd);
126
+ rmSync(base, { recursive: true, force: true });
127
+ }
73
128
  });
74
129
 
75
130
  test("buildDesktopNotificationCommand falls back to osascript on macOS when terminal-notifier is absent", () => {
@@ -0,0 +1,167 @@
1
+ /**
2
+ * OAuth/subscription vs pay-per-token API routing for bare model IDs.
3
+ *
4
+ * When the same model ID (e.g. gpt-5.5) exists on multiple providers, resolveModelId
5
+ * must prefer subscription/OAuth routes over platform API keys.
6
+ */
7
+
8
+ import test from "node:test";
9
+ import assert from "node:assert/strict";
10
+ import { MODELS } from "../../../../../packages/pi-ai/dist/models.generated.js";
11
+ import {
12
+ BARE_ID_SUBSCRIPTION_PROVIDER_PRECEDENCE,
13
+ resolveModelId,
14
+ } from "../auto-model-selection.js";
15
+
16
+ type ModelRef = { id: string; provider: string };
17
+
18
+ function modelsForProviders(modelId: string, providers: string[]): ModelRef[] {
19
+ return providers.map((provider) => ({ id: modelId, provider }));
20
+ }
21
+
22
+ /** Table-driven precedence cases — one row per conflict shape, not per model ID. */
23
+ const PRECEDENCE_CASES: Array<{
24
+ label: string;
25
+ modelId: string;
26
+ providers: string[];
27
+ expected: string;
28
+ currentProvider?: string;
29
+ }> = [
30
+ {
31
+ label: "ChatGPT OAuth beats OpenAI API (gpt-5.5)",
32
+ modelId: "gpt-5.5",
33
+ providers: ["openai", "openai-codex"],
34
+ expected: "openai-codex",
35
+ },
36
+ {
37
+ label: "Codex beats Copilot beats OpenAI API (gpt-5.5 triple)",
38
+ modelId: "gpt-5.5",
39
+ providers: ["openai", "github-copilot", "openai-codex"],
40
+ expected: "openai-codex",
41
+ },
42
+ {
43
+ label: "Copilot OAuth beats OpenAI API when no Codex (gpt-5.5)",
44
+ modelId: "gpt-5.5",
45
+ providers: ["openai", "github-copilot"],
46
+ expected: "github-copilot",
47
+ },
48
+ {
49
+ label: "Copilot OAuth beats OpenAI API (gpt-5-mini)",
50
+ modelId: "gpt-5-mini",
51
+ providers: ["openai", "github-copilot"],
52
+ expected: "github-copilot",
53
+ },
54
+ {
55
+ label: "Anthropic beats Copilot for Claude (claude-sonnet-4-6)",
56
+ modelId: "claude-sonnet-4-6",
57
+ providers: ["anthropic", "github-copilot"],
58
+ expected: "anthropic",
59
+ },
60
+ {
61
+ label: "Copilot beats Google API for Gemini (gemini-2.5-pro)",
62
+ modelId: "gemini-2.5-pro",
63
+ providers: ["google", "github-copilot"],
64
+ expected: "github-copilot",
65
+ },
66
+ {
67
+ label: "Gemini CLI beats Google API (gemini-2.5-pro)",
68
+ modelId: "gemini-2.5-pro",
69
+ providers: ["google", "google-gemini-cli"],
70
+ expected: "google-gemini-cli",
71
+ },
72
+ {
73
+ label: "Gemini CLI beats Copilot beats Google API",
74
+ modelId: "gemini-2.5-pro",
75
+ providers: ["google", "github-copilot", "google-gemini-cli"],
76
+ expected: "google-gemini-cli",
77
+ },
78
+ {
79
+ label: "Session provider still wins (openai-codex explicit)",
80
+ modelId: "gpt-5.5",
81
+ providers: ["openai", "openai-codex", "github-copilot"],
82
+ expected: "github-copilot",
83
+ currentProvider: "github-copilot",
84
+ },
85
+ {
86
+ label: "claude-code session beats anthropic (#3772)",
87
+ modelId: "claude-sonnet-4-6",
88
+ providers: ["anthropic", "claude-code"],
89
+ expected: "claude-code",
90
+ currentProvider: "claude-code",
91
+ },
92
+ ];
93
+
94
+ for (const row of PRECEDENCE_CASES) {
95
+ test(`resolveModelId precedence: ${row.label}`, () => {
96
+ const available = modelsForProviders(row.modelId, row.providers);
97
+ const result = resolveModelId(row.modelId, available, row.currentProvider);
98
+ assert.ok(result, `expected a match for ${row.modelId}`);
99
+ assert.equal(result.provider, row.expected);
100
+ });
101
+ }
102
+
103
+ test("BARE_ID_SUBSCRIPTION_PROVIDER_PRECEDENCE covers known OAuth/subscription providers", () => {
104
+ const expected = [
105
+ "openai-codex",
106
+ "google-gemini-cli",
107
+ "anthropic",
108
+ "github-copilot",
109
+ "google-antigravity",
110
+ ];
111
+ assert.deepEqual([...BARE_ID_SUBSCRIPTION_PROVIDER_PRECEDENCE], expected);
112
+ });
113
+
114
+ test("every catalog overlap with OAuth/subscription + API resolves to subscription route", () => {
115
+ const oauthProviders = new Set(["anthropic", "github-copilot", "openai-codex"]);
116
+ const subscriptionCli = new Set(["google-gemini-cli", "google-antigravity", "claude-code"]);
117
+ const apiPayPerToken = new Set(["openai", "google", "azure-openai-responses"]);
118
+
119
+ const byId = new Map<string, Set<string>>();
120
+ for (const [provider, models] of Object.entries(MODELS)) {
121
+ for (const id of Object.keys(models)) {
122
+ if (!byId.has(id)) byId.set(id, new Set());
123
+ byId.get(id)!.add(provider);
124
+ }
125
+ }
126
+
127
+ const failures: string[] = [];
128
+
129
+ for (const [modelId, providers] of byId) {
130
+ if (providers.size < 2) continue;
131
+
132
+ const hasApi = [...providers].some((p) => apiPayPerToken.has(p));
133
+ const subscriptionCandidates = [...providers].filter(
134
+ (p) => oauthProviders.has(p) || subscriptionCli.has(p),
135
+ );
136
+ if (!hasApi || subscriptionCandidates.length === 0) continue;
137
+
138
+ const testProviders = new Set<string>(subscriptionCandidates);
139
+ for (const p of providers) {
140
+ if (apiPayPerToken.has(p)) testProviders.add(p);
141
+ }
142
+
143
+ const available = modelsForProviders(modelId, [...testProviders]);
144
+ const result = resolveModelId(modelId, available, undefined);
145
+ if (!result) {
146
+ failures.push(`${modelId}: no resolution among ${[...testProviders].join(", ")}`);
147
+ continue;
148
+ }
149
+
150
+ const winnerIsSubscription =
151
+ oauthProviders.has(result.provider) ||
152
+ subscriptionCli.has(result.provider) ||
153
+ result.provider === "anthropic";
154
+
155
+ if (!winnerIsSubscription) {
156
+ failures.push(
157
+ `${modelId}: got ${result.provider}, expected subscription route among ${[...testProviders].join(", ")}`,
158
+ );
159
+ }
160
+ }
161
+
162
+ assert.equal(
163
+ failures.length,
164
+ 0,
165
+ `catalog overlap routing failures:\n${failures.join("\n")}`,
166
+ );
167
+ });
@@ -41,6 +41,7 @@ after(() => {
41
41
 
42
42
  const { resolveDispatch } = await import("../auto-dispatch.ts");
43
43
  const { buildParallelResearchSlicesPrompt } = await import("../auto-prompts.ts");
44
+ const { openDatabase, closeDatabase, insertMilestone, insertSlice } = await import("../gsd-db.ts");
44
45
 
45
46
  type DispatchState = Parameters<typeof resolveDispatch>[0]["state"];
46
47
 
@@ -51,6 +52,20 @@ function writeRoadmap(
51
52
  ): void {
52
53
  const milestoneDir = join(base, ".gsd", "milestones", mid);
53
54
  mkdirSync(milestoneDir, { recursive: true });
55
+ // The dispatch rule reads slices from the DB (ADR-017), not the ROADMAP
56
+ // projection — seed both so disk-based artifact checks still resolve.
57
+ insertMilestone({ id: mid, title: "Parallel Research Milestone" });
58
+ let sequence = 1;
59
+ for (const s of slices) {
60
+ insertSlice({
61
+ id: s.id,
62
+ milestoneId: mid,
63
+ title: s.title,
64
+ status: s.done ? "complete" : "pending",
65
+ depends: s.depends ?? [],
66
+ sequence: sequence++,
67
+ });
68
+ }
54
69
  const lines = [
55
70
  `# ${mid}: Parallel Research Milestone`,
56
71
  "",
@@ -100,9 +115,12 @@ describe("parallel-research-slices dispatch rule", () => {
100
115
 
101
116
  beforeEach(() => {
102
117
  base = mkdtempSync(join(tmpdir(), "parallel-research-"));
118
+ mkdirSync(join(base, ".gsd"), { recursive: true });
119
+ openDatabase(join(base, ".gsd", "gsd.db"));
103
120
  });
104
121
 
105
122
  afterEach(() => {
123
+ closeDatabase();
106
124
  rmSync(base, { recursive: true, force: true });
107
125
  });
108
126
 
@@ -29,8 +29,8 @@ import {
29
29
 
30
30
  const SKILL_NAME = "testskill";
31
31
  const COMPLETE_SLICE_SKILL_NAME = "complete-slice-policies";
32
- const SKILL_ACTIVATION_SUBSTRING = `Call Skill({ skill: '${SKILL_NAME}' })`;
33
- const COMPLETE_SLICE_SKILL_ACTIVATION_SUBSTRING = `Call Skill({ skill: '${COMPLETE_SLICE_SKILL_NAME}' })`;
32
+ const SKILL_ACTIVATION_SUBSTRING = `Read the installed '${SKILL_NAME}' skill file from <available_skills>`;
33
+ const COMPLETE_SLICE_SKILL_ACTIVATION_SUBSTRING = `Read the installed '${COMPLETE_SLICE_SKILL_NAME}' skill file from <available_skills>`;
34
34
 
35
35
  const tmpDirs: string[] = [];
36
36
  let savedCwd: string | undefined;