@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
@@ -0,0 +1,119 @@
1
+ // Project/App: gsd-pi
2
+ // File Purpose: Tests for shared workflow MCP probe cache.
3
+
4
+ import { describe, test } from "node:test";
5
+ import assert from "node:assert/strict";
6
+ import { mkdirSync, mkdtempSync, rmSync, writeFileSync } from "node:fs";
7
+ import { createRequire } from "node:module";
8
+ import { tmpdir } from "node:os";
9
+ import { join } from "node:path";
10
+ import { pathToFileURL } from "node:url";
11
+
12
+ import {
13
+ cachedWorkflowMcpCoversRequired,
14
+ clearWorkflowMcpProbeCache,
15
+ getCachedWorkflowMcpProbe,
16
+ probeAndCacheWorkflowMcp,
17
+ recordWorkflowMcpProbe,
18
+ beginWorkflowMcpSdkSession,
19
+ endWorkflowMcpSdkSession,
20
+ warmWorkflowMcpProbeInBackground,
21
+ } from "../workflow-mcp-readiness-cache.ts";
22
+
23
+ describe("workflow-mcp-readiness-cache", () => {
24
+ test("returns cached probe without reconnecting", async () => {
25
+ clearWorkflowMcpProbeCache();
26
+ const projectRoot = "/tmp/gsd-cache-project";
27
+ recordWorkflowMcpProbe(projectRoot, "gsd-workflow", ["gsd_status", "gsd_plan_slice"]);
28
+
29
+ const result = await probeAndCacheWorkflowMcp(projectRoot, { timeoutMs: 1000 });
30
+ assert.equal(result.ok, true);
31
+ assert.deepEqual(result.tools, ["gsd_status", "gsd_plan_slice"]);
32
+ assert.equal(result.serverName, "gsd-workflow");
33
+ });
34
+
35
+ test("cachedWorkflowMcpCoversRequired matches required workflow tools", () => {
36
+ clearWorkflowMcpProbeCache();
37
+ const projectRoot = "/tmp/gsd-cache-required";
38
+ recordWorkflowMcpProbe(projectRoot, "gsd-workflow", ["gsd_plan_slice", "gsd_milestone_status"]);
39
+
40
+ assert.equal(
41
+ cachedWorkflowMcpCoversRequired(projectRoot, "gsd-workflow", ["gsd_plan_slice"]),
42
+ true,
43
+ );
44
+ assert.equal(
45
+ cachedWorkflowMcpCoversRequired(projectRoot, "gsd-workflow", ["gsd_uat_exec"]),
46
+ false,
47
+ );
48
+ assert.equal(getCachedWorkflowMcpProbe(projectRoot)?.serverName, "gsd-workflow");
49
+ });
50
+
51
+ test("warmWorkflowMcpProbeInBackground is suppressed during active SDK sessions", async () => {
52
+ clearWorkflowMcpProbeCache();
53
+ beginWorkflowMcpSdkSession();
54
+ try {
55
+ const projectRoot = "/tmp/gsd-sdk-session-guard";
56
+ warmWorkflowMcpProbeInBackground(projectRoot);
57
+ await new Promise((resolve) => setTimeout(resolve, 10));
58
+ assert.equal(getCachedWorkflowMcpProbe(projectRoot), null);
59
+ } finally {
60
+ endWorkflowMcpSdkSession();
61
+ }
62
+ });
63
+
64
+ test("warmWorkflowMcpProbeInBackground uses project root without double cache-keying", async () => {
65
+ clearWorkflowMcpProbeCache();
66
+ const projectRoot = "/tmp/gsd-warm-cache-key";
67
+ recordWorkflowMcpProbe(projectRoot, "gsd-workflow", ["gsd_status", "gsd_plan_slice"]);
68
+ warmWorkflowMcpProbeInBackground(projectRoot);
69
+ await new Promise((resolve) => setTimeout(resolve, 10));
70
+ assert.equal(getCachedWorkflowMcpProbe(projectRoot)?.serverName, "gsd-workflow");
71
+ });
72
+
73
+ test("probeAndCacheWorkflowMcp reads project .mcp.json when no env launch config exists", async () => {
74
+ clearWorkflowMcpProbeCache();
75
+ const previousGsdHome = process.env.GSD_HOME;
76
+ const projectRoot = mkdtempSync(join(tmpdir(), "gsd-mcp-cache-project-"));
77
+ const gsdHomeDir = mkdtempSync(join(tmpdir(), "gsd-mcp-cache-home-"));
78
+ try {
79
+ process.env.GSD_HOME = gsdHomeDir;
80
+ mkdirSync(join(projectRoot, ".gsd"), { recursive: true });
81
+
82
+ const require = createRequire(import.meta.url);
83
+ const mcpModuleUrl = pathToFileURL(require.resolve("@modelcontextprotocol/sdk/server/mcp.js")).href;
84
+ const stdioModuleUrl = pathToFileURL(require.resolve("@modelcontextprotocol/sdk/server/stdio.js")).href;
85
+ const serverPath = join(projectRoot, "fake-workflow-mcp-server.mjs");
86
+ writeFileSync(
87
+ serverPath,
88
+ [
89
+ `const { McpServer } = await import(${JSON.stringify(mcpModuleUrl)});`,
90
+ `const { StdioServerTransport } = await import(${JSON.stringify(stdioModuleUrl)});`,
91
+ 'const server = new McpServer({ name: "fake", version: "1.0.0" }, { capabilities: { tools: {} } });',
92
+ 'server.tool("ask_user_questions", "Ask questions", {}, async () => ({ content: [{ type: "text", text: "ok" }] }));',
93
+ 'await server.connect(new StdioServerTransport());',
94
+ ].join("\n"),
95
+ "utf-8",
96
+ );
97
+ writeFileSync(
98
+ join(projectRoot, ".mcp.json"),
99
+ JSON.stringify({ mcpServers: { "gsd-workflow": { command: process.execPath, args: [serverPath] } } }),
100
+ "utf-8",
101
+ );
102
+
103
+ const result = await probeAndCacheWorkflowMcp(projectRoot, { timeoutMs: 5_000 });
104
+
105
+ assert.equal(result.ok, true);
106
+ assert.equal(result.serverName, "gsd-workflow");
107
+ assert.deepEqual(result.tools, ["ask_user_questions"]);
108
+ assert.deepEqual(getCachedWorkflowMcpProbe(projectRoot)?.tools, ["ask_user_questions"]);
109
+ } finally {
110
+ if (previousGsdHome === undefined) {
111
+ delete process.env.GSD_HOME;
112
+ } else {
113
+ process.env.GSD_HOME = previousGsdHome;
114
+ }
115
+ rmSync(projectRoot, { recursive: true, force: true });
116
+ rmSync(gsdHomeDir, { recursive: true, force: true });
117
+ }
118
+ });
119
+ });
@@ -22,6 +22,7 @@ import {
22
22
  usesWorkflowMcpTransport,
23
23
  } from "../workflow-mcp.ts";
24
24
  import { DB_WORKFLOW_TOOL_NAMES } from "../workflow-tool-surface.ts";
25
+ import { UNIT_TOOL_CONTRACTS } from "../unit-tool-contracts.ts";
25
26
 
26
27
  const MCP_STDIO_TIMEOUT_MS = 90_000;
27
28
 
@@ -43,11 +44,25 @@ test("resolveWorkflowMcpProjectRoot maps milestone worktree cwd to project root"
43
44
  });
44
45
 
45
46
  test("guided execute-task requires canonical task completion tool", () => {
46
- assert.deepEqual(getRequiredWorkflowToolsForGuidedUnit("execute-task"), ["gsd_task_complete"]);
47
+ const expected = [
48
+ "gsd_task_complete",
49
+ "gsd_exec",
50
+ "gsd_exec_search",
51
+ "gsd_resume",
52
+ "gsd_capture_thought",
53
+ ];
54
+ assert.deepEqual(getRequiredWorkflowToolsForGuidedUnit("execute-task"), expected);
47
55
  });
48
56
 
49
57
  test("auto execute-task requires canonical task completion tool", () => {
50
- assert.deepEqual(getRequiredWorkflowToolsForAutoUnit("execute-task"), ["gsd_task_complete"]);
58
+ const expected = [
59
+ "gsd_task_complete",
60
+ "gsd_exec",
61
+ "gsd_exec_search",
62
+ "gsd_resume",
63
+ "gsd_capture_thought",
64
+ ];
65
+ assert.deepEqual(getRequiredWorkflowToolsForAutoUnit("execute-task"), expected);
51
66
  });
52
67
 
53
68
  test("plan-slice requires planning and roadmap reassessment tools", () => {
@@ -69,6 +84,8 @@ test("refine-slice requires canonical slice planning tool", () => {
69
84
 
70
85
  test("complete-slice requires closeout and execution handoff tools", () => {
71
86
  const expected = [
87
+ "gsd_exec",
88
+ "gsd_capture_thought",
72
89
  "gsd_slice_complete",
73
90
  "gsd_task_reopen",
74
91
  "gsd_replan_slice",
@@ -526,6 +543,52 @@ test("workflow MCP launch config reaches mutation tools over stdio", async () =>
526
543
  }
527
544
  });
528
545
 
546
+ test("workflow MCP stdio surface exposes every unit's required workflow tool", async () => {
547
+ const projectRoot = mkdtempSync(join(tmpdir(), "gsd-workflow-all-unit-tools-"));
548
+ const isolatedGsdHome = mkdtempSync(join(tmpdir(), "gsd-workflow-all-unit-home-"));
549
+ mkdirSync(join(projectRoot, ".gsd"), { recursive: true });
550
+
551
+ const launch = detectWorkflowMcpLaunchConfig(projectRoot, {});
552
+ assert.ok(launch, "expected a workflow MCP launch config");
553
+
554
+ const client = new Client({ name: "workflow-mcp-contract-test", version: "1.0.0" });
555
+ const transport = new StdioClientTransport({
556
+ command: launch.command,
557
+ args: launch.args,
558
+ env: {
559
+ ...process.env,
560
+ ...launch.env,
561
+ GSD_HOME: isolatedGsdHome,
562
+ DISCORD_BOT_TOKEN: "",
563
+ SLACK_BOT_TOKEN: "",
564
+ TELEGRAM_BOT_TOKEN: "",
565
+ } as Record<string, string>,
566
+ cwd: launch.cwd,
567
+ stderr: "pipe",
568
+ });
569
+
570
+ try {
571
+ await client.connect(transport, { timeout: MCP_STDIO_TIMEOUT_MS });
572
+ const listed = await client.listTools(undefined, { timeout: MCP_STDIO_TIMEOUT_MS });
573
+ const exposedTools = new Set((listed.tools ?? []).map((tool) => tool.name));
574
+
575
+ for (const [unitType, contract] of Object.entries(UNIT_TOOL_CONTRACTS)) {
576
+ for (const toolName of contract.requiredWorkflowTools) {
577
+ if (!toolName.startsWith("gsd_") && toolName !== "ask_user_questions") continue;
578
+ assert.ok(
579
+ exposedTools.has(toolName),
580
+ `${unitType} requires ${toolName}, but workflow MCP exposed ${JSON.stringify([...exposedTools].sort())}`,
581
+ );
582
+ }
583
+ }
584
+ } finally {
585
+ await client.close().catch(() => undefined);
586
+ await transport.close().catch(() => undefined);
587
+ rmSync(projectRoot, { recursive: true, force: true });
588
+ rmSync(isolatedGsdHome, { recursive: true, force: true });
589
+ }
590
+ });
591
+
529
592
  test("workflow MCP ask_user_questions uses stdio elicitation round-trip", async () => {
530
593
  const projectRoot = mkdtempSync(join(tmpdir(), "gsd-workflow-elicit-"));
531
594
  mkdirSync(join(projectRoot, ".gsd"), { recursive: true });
@@ -0,0 +1,332 @@
1
+ // Project/App: gsd-pi
2
+ // File Purpose: Cross-walk matrix — every unit phase, workflow tool contract, transport
3
+ // registration, availability gate, and forbidden-tool boundary.
4
+
5
+ import test from "node:test";
6
+ import assert from "node:assert/strict";
7
+
8
+ import { WORKFLOW_TOOL_CONTRACTS } from "@opengsd/contracts";
9
+ import { registerDbTools } from "../bootstrap/db-tools.ts";
10
+ import { registerExecTools } from "../bootstrap/exec-tools.ts";
11
+ import { registerJournalTools } from "../bootstrap/journal-tools.ts";
12
+ import { registerMemoryTools } from "../bootstrap/memory-tools.ts";
13
+ import { registerQueryTools } from "../bootstrap/query-tools.ts";
14
+ import {
15
+ buildMinimalAutoGsdToolSet,
16
+ MINIMAL_AUTO_BASE_TOOL_NAMES,
17
+ MINIMAL_GSD_TOOL_NAMES,
18
+ } from "../bootstrap/register-hooks.ts";
19
+ import { shouldBlockAutoUnitToolCall } from "../auto-unit-tool-scope.ts";
20
+ import { canonicalWorkflowToolName } from "../engine-hook-contract.ts";
21
+ import { resolveToolPresentationPlan } from "../tool-presentation-plan.ts";
22
+ import { getToolSurfaceReadinessError } from "../tool-surface-readiness.ts";
23
+ import {
24
+ compileUnitContextContract,
25
+ compileUnitToolContract,
26
+ getUnitWorkflowDispatchReadinessError,
27
+ } from "../tool-contract.ts";
28
+ import {
29
+ getRequiredWorkflowToolsForUnit,
30
+ getUnitToolSurfaceContract,
31
+ UNIT_TOOL_CONTRACTS,
32
+ } from "../unit-tool-contracts.ts";
33
+ import { UNIT_MANIFESTS } from "../unit-context-manifest.ts";
34
+ import { UNIT_REGISTRY, type UnitTypeOrVariant } from "../unit-registry.ts";
35
+ import {
36
+ isWorkflowToolSurfaceName,
37
+ WORKFLOW_MCP_ADAPTER_TOOL_NAMES,
38
+ WORKFLOW_TOOL_SURFACE_NAMES,
39
+ } from "../workflow-tool-surface.ts";
40
+
41
+ const WORKFLOW_SERVER = "gsd-workflow";
42
+
43
+ const MCP_TRANSPORT = {
44
+ provider: "claude-code-cli",
45
+ projectRoot: "/tmp/gsd-matrix-project",
46
+ env: { GSD_WORKFLOW_MCP_COMMAND: "node" } as NodeJS.ProcessEnv,
47
+ surface: "contract-matrix",
48
+ authMode: "externalCli" as const,
49
+ baseUrl: "local://claude-code",
50
+ };
51
+
52
+ /** Native Pi registers some contract names under legacy aliases. */
53
+ const NATIVE_TOOL_EQUIVALENTS: Readonly<Record<string, readonly string[]>> = {
54
+ gsd_capture_thought: ["capture_thought", "gsd_capture_thought"],
55
+ gsd_memory_query: ["memory_query", "gsd_memory_query"],
56
+ gsd_memory_graph: ["gsd_graph", "gsd_memory_graph"],
57
+ };
58
+
59
+ const REGISTERED_SURFACE_TOOL_NAMES = [
60
+ ...new Set([
61
+ ...MINIMAL_AUTO_BASE_TOOL_NAMES,
62
+ ...MINIMAL_GSD_TOOL_NAMES,
63
+ ...Object.values(UNIT_TOOL_CONTRACTS).flatMap((contract) => contract.allowedGsdTools),
64
+ ...WORKFLOW_TOOL_SURFACE_NAMES,
65
+ ]),
66
+ ];
67
+
68
+ function makeMockPi() {
69
+ const tools: Array<{ name: string }> = [];
70
+ return {
71
+ registerTool(tool: { name: string }) {
72
+ tools.push(tool);
73
+ },
74
+ tools,
75
+ } as const;
76
+ }
77
+
78
+ function collectNativeRegisteredToolNames(): Set<string> {
79
+ const pi = makeMockPi();
80
+ registerDbTools(pi as never);
81
+ registerExecTools(pi as never);
82
+ registerQueryTools(pi as never);
83
+ registerJournalTools(pi as never);
84
+ registerMemoryTools(pi as never);
85
+ return new Set(pi.tools.map((tool) => tool.name));
86
+ }
87
+
88
+ function workflowToolsForUnit(unitType: string): string[] {
89
+ return getRequiredWorkflowToolsForUnit(unitType).filter(
90
+ (tool) => tool.startsWith("gsd_") || tool === "ask_user_questions",
91
+ );
92
+ }
93
+
94
+ function mockConnectedObservation(requiredTools: readonly string[]) {
95
+ return {
96
+ tools: requiredTools.map((tool) => `mcp__${WORKFLOW_SERVER}__${tool}`),
97
+ mcpServers: [{ name: WORKFLOW_SERVER, status: "connected" }],
98
+ };
99
+ }
100
+
101
+ function assertNativeToolRegistered(
102
+ registered: Set<string>,
103
+ contractName: string,
104
+ label: string,
105
+ ): void {
106
+ const candidates = [contractName, ...(NATIVE_TOOL_EQUIVALENTS[contractName] ?? [])];
107
+ assert.ok(
108
+ candidates.some((name) => registered.has(name)),
109
+ `${label}: native transport missing ${contractName} (candidates: ${candidates.join(", ")})`,
110
+ );
111
+ }
112
+
113
+ function unitHasManifest(unitType: string): boolean {
114
+ return unitType in UNIT_MANIFESTS;
115
+ }
116
+
117
+ function unitTypesWithContracts(): Array<[UnitTypeOrVariant, (typeof UNIT_REGISTRY)[UnitTypeOrVariant]]> {
118
+ return Object.entries(UNIT_REGISTRY).filter(
119
+ (entry): entry is [UnitTypeOrVariant, (typeof UNIT_REGISTRY)[UnitTypeOrVariant]] =>
120
+ entry[1].toolContract !== null,
121
+ );
122
+ }
123
+
124
+ // ─── Unit phase × contract integrity ───────────────────────────────────────
125
+
126
+ test("every manifest-backed unit with a tool contract compiles Tool Contract and Context Contract", () => {
127
+ for (const [unitType] of unitTypesWithContracts()) {
128
+ if (!unitHasManifest(unitType)) continue;
129
+ const toolResult = compileUnitToolContract(unitType);
130
+ assert.equal(toolResult.ok, true, `${unitType} must compile Tool Contract`);
131
+
132
+ const contextResult = compileUnitContextContract(unitType);
133
+ assert.equal(contextResult.ok, true, `${unitType} must compile Context Contract`);
134
+ }
135
+ });
136
+
137
+ for (const [unitType, descriptor] of unitTypesWithContracts()) {
138
+ test(`${unitType}: required workflow tools are declared, on-surface, and allowed`, () => {
139
+ const contract = descriptor.toolContract!;
140
+ const allowed = new Set(contract.allowedGsdTools.map((tool) => String(tool)));
141
+
142
+ for (const required of contract.requiredWorkflowTools) {
143
+ const name = String(required);
144
+ if (name === "subagent") {
145
+ assert.ok(allowed.has("subagent"), `${unitType}: subagent required but not allowed`);
146
+ continue;
147
+ }
148
+ assert.ok(
149
+ allowed.has(name) || name === "ask_user_questions",
150
+ `${unitType}: required ${name} must be allowed or be ask_user_questions`,
151
+ );
152
+ if (name.startsWith("gsd_")) {
153
+ assert.ok(
154
+ isWorkflowToolSurfaceName(name),
155
+ `${unitType}: required ${name} must be on WORKFLOW_TOOL_SURFACE_NAMES`,
156
+ );
157
+ } else if (name === "ask_user_questions") {
158
+ assert.ok(
159
+ (WORKFLOW_MCP_ADAPTER_TOOL_NAMES as readonly string[]).includes(name),
160
+ `${unitType}: ask_user_questions must be on the MCP adapter surface`,
161
+ );
162
+ }
163
+ }
164
+ });
165
+ }
166
+
167
+ for (const [unitType, descriptor] of unitTypesWithContracts()) {
168
+ const requiredTools = workflowToolsForUnit(unitType);
169
+ if (requiredTools.length === 0) continue;
170
+
171
+ test(`${unitType}: static dispatch gate passes when workflow MCP is configured`, () => {
172
+ const error = getUnitWorkflowDispatchReadinessError({
173
+ ...MCP_TRANSPORT,
174
+ unitType,
175
+ activeTools: REGISTERED_SURFACE_TOOL_NAMES,
176
+ });
177
+ assert.equal(error, null, `${unitType} static gate: ${error ?? "ok"}`);
178
+ });
179
+
180
+ test(`${unitType}: runtime tool-surface readiness passes when MCP tools are connected`, () => {
181
+ const error = getToolSurfaceReadinessError({
182
+ unitType,
183
+ workflowServerName: WORKFLOW_SERVER,
184
+ observation: mockConnectedObservation(requiredTools),
185
+ });
186
+ assert.equal(error, null, `${unitType} runtime readiness: ${error ?? "ok"}`);
187
+ });
188
+
189
+ test(`${unitType}: runtime readiness fails when a required workflow tool is missing`, () => {
190
+ if (requiredTools.length === 0) return;
191
+ const missing = requiredTools[0];
192
+ const partial = requiredTools.filter((tool) => tool !== missing);
193
+ const error = getToolSurfaceReadinessError({
194
+ unitType,
195
+ workflowServerName: WORKFLOW_SERVER,
196
+ observation: mockConnectedObservation(partial),
197
+ });
198
+ assert.ok(error, `${unitType} should fail readiness when ${missing} is absent`);
199
+ assert.match(error!, new RegExp(missing.replace(/[.*+?^${}()|[\]\\]/g, "\\$&")));
200
+ });
201
+
202
+ test(`${unitType}: native auto scoping exposes every required workflow tool`, () => {
203
+ const scoped = buildMinimalAutoGsdToolSet(
204
+ REGISTERED_SURFACE_TOOL_NAMES,
205
+ unitType,
206
+ REGISTERED_SURFACE_TOOL_NAMES,
207
+ );
208
+ for (const required of contractRequiredNames(unitType)) {
209
+ const canonical = canonicalWorkflowToolName(required);
210
+ const nativeCandidates = NATIVE_TOOL_EQUIVALENTS[canonical] ?? [canonical];
211
+ assert.ok(
212
+ scoped.some((tool) => nativeCandidates.includes(tool) || tool === canonical),
213
+ `${unitType}: scoped tools missing ${required}; got ${scoped.join(", ")}`,
214
+ );
215
+ }
216
+ });
217
+
218
+ test(`${unitType}: MCP presentation plan exposes every required workflow tool`, () => {
219
+ const requested = [
220
+ ...new Set([
221
+ ...(descriptor.toolContract?.allowedGsdTools ?? []),
222
+ ...requiredTools,
223
+ ]),
224
+ ].filter((tool) => String(tool).startsWith("gsd_") || tool === "ask_user_questions");
225
+ const plan = resolveToolPresentationPlan({
226
+ phase: unitType,
227
+ surface: "claude-code-sdk",
228
+ workflowMcpServerName: WORKFLOW_SERVER,
229
+ requestedToolNames: requested.map(String),
230
+ availableToolNames: REGISTERED_SURFACE_TOOL_NAMES,
231
+ });
232
+ for (const required of requiredTools) {
233
+ const presented = `mcp__${WORKFLOW_SERVER}__${required}`;
234
+ assert.ok(
235
+ plan.presentedToolNames.includes(presented),
236
+ `${unitType}: presentation plan missing ${presented}; got ${plan.presentedToolNames.join(", ")}`,
237
+ );
238
+ }
239
+ });
240
+ }
241
+
242
+ function contractRequiredNames(unitType: string): string[] {
243
+ return getRequiredWorkflowToolsForUnit(unitType).filter((tool) => tool !== "ask_user_questions");
244
+ }
245
+
246
+ for (const [unitType, descriptor] of unitTypesWithContracts()) {
247
+ const contract = descriptor.toolContract;
248
+ if (!contract || !("forbiddenGsdTools" in contract) || !contract.forbiddenGsdTools) continue;
249
+ const forbidden = Object.entries(contract.forbiddenGsdTools);
250
+
251
+ for (const [toolName, reason] of forbidden) {
252
+ test(`${unitType}: forbids ${toolName} — ${reason}`, () => {
253
+ const block = shouldBlockAutoUnitToolCall(unitType, toolName);
254
+ assert.equal(block.block, true, `${unitType} must block ${toolName}`);
255
+ assert.ok(block.reason, `${unitType} block reason for ${toolName}`);
256
+ });
257
+ }
258
+ }
259
+
260
+ // ─── Workflow tool contract × transports ───────────────────────────────────
261
+
262
+ test("every canonical workflow contract tool is on the compiled MCP surface list", () => {
263
+ for (const contract of WORKFLOW_TOOL_CONTRACTS) {
264
+ assert.ok(
265
+ isWorkflowToolSurfaceName(contract.canonicalName),
266
+ `${contract.canonicalName} missing from WORKFLOW_TOOL_SURFACE_NAMES`,
267
+ );
268
+ for (const alias of contract.aliases) {
269
+ assert.ok(
270
+ isWorkflowToolSurfaceName(alias),
271
+ `alias ${alias} for ${contract.canonicalName} missing from surface`,
272
+ );
273
+ }
274
+ }
275
+ });
276
+
277
+ test("every unit-required workflow tool resolves to a registered contract canonical name", () => {
278
+ const canonicalNames = new Set<string>(WORKFLOW_TOOL_CONTRACTS.map((tool) => tool.canonicalName));
279
+ const adapterNames = new Set(WORKFLOW_MCP_ADAPTER_TOOL_NAMES as readonly string[]);
280
+
281
+ for (const [unitType] of unitTypesWithContracts()) {
282
+ for (const required of getRequiredWorkflowToolsForUnit(unitType)) {
283
+ const name = String(required);
284
+ if (name === "ask_user_questions") {
285
+ assert.ok(adapterNames.has(name), `${unitType}: ${name} must be adapter-registered`);
286
+ continue;
287
+ }
288
+ if (name === "subagent") continue;
289
+ const canonical = canonicalWorkflowToolName(name);
290
+ assert.ok(
291
+ canonicalNames.has(canonical),
292
+ `${unitType}: required ${name} canonicalizes to unknown contract ${canonical}`,
293
+ );
294
+ }
295
+ }
296
+ });
297
+
298
+ test("native bootstrap registers every contract canonical tool (or documented equivalent)", () => {
299
+ const registered = collectNativeRegisteredToolNames();
300
+ for (const contract of WORKFLOW_TOOL_CONTRACTS) {
301
+ assertNativeToolRegistered(registered, contract.canonicalName, "native bootstrap");
302
+ }
303
+ });
304
+
305
+ test("every write-policy workflow contract declares schema and audit metadata", () => {
306
+ for (const contract of WORKFLOW_TOOL_CONTRACTS) {
307
+ assert.match(contract.schemaId, /^workflow\./, `${contract.canonicalName} schemaId`);
308
+ assert.match(contract.auditEvent, /^workflow\./, `${contract.canonicalName} auditEvent`);
309
+ assert.ok(contract.executorId.length > 0, `${contract.canonicalName} executorId`);
310
+ if (contract.writePolicy === "write") {
311
+ assert.notEqual(
312
+ contract.executorId,
313
+ "executeMilestoneStatus",
314
+ `${contract.canonicalName} write tool must not use read executor`,
315
+ );
316
+ }
317
+ }
318
+ });
319
+
320
+ test("registry tool contracts stay aligned with UNIT_TOOL_CONTRACTS view", () => {
321
+ for (const [unitType, descriptor] of Object.entries(UNIT_REGISTRY)) {
322
+ if (!descriptor.toolContract) {
323
+ assert.equal(getUnitToolSurfaceContract(unitType), undefined);
324
+ continue;
325
+ }
326
+ assert.deepEqual(
327
+ getUnitToolSurfaceContract(unitType),
328
+ descriptor.toolContract,
329
+ `${unitType} derived contract drift`,
330
+ );
331
+ }
332
+ });
@@ -89,3 +89,23 @@ test("resolveConflict(pick=main) rewrites the worktree log durably", () => {
89
89
  const second = reconcileWorktreeLogs(main, worktree);
90
90
  assert.equal(second.conflicts.length, 0, "reconcile should stay clean after choosing main");
91
91
  });
92
+
93
+ test("reconcileWorktreeLogs treats canonical worktree project-ledger appends as already durable", () => {
94
+ const root = mkdtempSync(join(tmpdir(), "workflow-reconcile-canonical-"));
95
+ const main = join(root, "main");
96
+ const worktree = join(main, ".gsd-worktrees", "M001");
97
+ mkdirSync(worktree, { recursive: true });
98
+ tmpDirs.push(root);
99
+
100
+ appendEvent(worktree, {
101
+ cmd: "complete-task",
102
+ params: { milestoneId: "M001", sliceId: "S01", taskId: "T01" },
103
+ ts: "2026-01-01T00:00:00.000Z",
104
+ actor: "agent",
105
+ });
106
+
107
+ const result = reconcileWorktreeLogs(main, worktree);
108
+
109
+ assert.equal(result.autoMerged, 0, "project-ledger append should not replay the root log");
110
+ assert.equal(result.conflicts.length, 0, "missing worktree shard is not a conflict");
111
+ });
@@ -7,6 +7,9 @@
7
7
 
8
8
  import { test } from 'node:test';
9
9
  import assert from 'node:assert/strict';
10
+ import { mkdtempSync, mkdirSync, rmSync, writeFileSync } from 'node:fs';
11
+ import { tmpdir } from 'node:os';
12
+ import { join } from 'node:path';
10
13
  import {
11
14
  loadRegistry,
12
15
  resolveByName,
@@ -16,6 +19,11 @@ import {
16
19
  getTemplateInfo,
17
20
  loadWorkflowTemplate,
18
21
  } from '../workflow-templates.ts';
22
+ import {
23
+ findInProgressWorkflows,
24
+ isWorkflowStateComplete,
25
+ type WorkflowState,
26
+ } from '../commands-workflow-templates.ts';
19
27
 
20
28
 
21
29
  // ═══════════════════════════════════════════════════════════════════════════
@@ -196,3 +204,87 @@ console.log('\n── Load Workflow Template ──');
196
204
  }
197
205
 
198
206
  // ═══════════════════════════════════════════════════════════════════════════
207
+
208
+ console.log('\n── Workflow Resume State ──');
209
+
210
+ {
211
+ const started: WorkflowState = {
212
+ template: 'bugfix',
213
+ templateName: 'Bug Fix',
214
+ description: 'fix resume drift',
215
+ branch: 'gsd/bugfix/fix-resume-drift',
216
+ phases: [
217
+ { name: 'triage', index: 0, status: 'completed' },
218
+ { name: 'fix', index: 1, status: 'active' },
219
+ { name: 'verify', index: 2, status: 'pending' },
220
+ ],
221
+ currentPhase: 1,
222
+ startedAt: '2026-06-15T00:00:00.000Z',
223
+ updatedAt: '2026-06-15T00:01:00.000Z',
224
+ artifactDir: 'workflows/bugfixes/260615-1-fix-resume-drift',
225
+ };
226
+
227
+ assert.equal(isWorkflowStateComplete(started), false, 'active phase should be resumable');
228
+ assert.equal(
229
+ isWorkflowStateComplete({
230
+ ...started,
231
+ phases: started.phases.map((phase) => ({ ...phase, status: 'completed' })),
232
+ currentPhase: 2,
233
+ updatedAt: '2026-06-15T00:02:00.000Z',
234
+ }),
235
+ true,
236
+ 'all completed phases should be treated as complete even when completedAt is absent',
237
+ );
238
+ assert.equal(
239
+ isWorkflowStateComplete({ ...started, completedAt: '2026-06-15T00:03:00.000Z' }),
240
+ true,
241
+ 'completedAt should mark the workflow complete',
242
+ );
243
+ }
244
+
245
+ test('findInProgressWorkflows ignores completed phase-only STATE files', (t) => {
246
+ const base = mkdtempSync(join(tmpdir(), 'gsd-workflow-resume-'));
247
+ t.after(() => rmSync(base, { recursive: true, force: true }));
248
+
249
+ const workflowsRoot = join(base, '.gsd', 'workflows', 'bugfixes');
250
+ mkdirSync(join(workflowsRoot, '260615-1-complete'), { recursive: true });
251
+ mkdirSync(join(workflowsRoot, '260615-2-active'), { recursive: true });
252
+
253
+ const common = {
254
+ template: 'bugfix',
255
+ templateName: 'Bug Fix',
256
+ description: 'fix resume drift',
257
+ branch: 'gsd/bugfix/fix-resume-drift',
258
+ startedAt: '2026-06-15T00:00:00.000Z',
259
+ artifactDir: 'workflows/bugfixes/260615-1-complete',
260
+ };
261
+
262
+ writeFileSync(join(workflowsRoot, '260615-1-complete', 'STATE.json'), JSON.stringify({
263
+ ...common,
264
+ phases: [
265
+ { name: 'triage', index: 0, status: 'completed' },
266
+ { name: 'fix', index: 1, status: 'completed' },
267
+ { name: 'verify', index: 2, status: 'completed' },
268
+ ],
269
+ currentPhase: 2,
270
+ updatedAt: '2026-06-15T00:02:00.000Z',
271
+ }), 'utf-8');
272
+
273
+ writeFileSync(join(workflowsRoot, '260615-2-active', 'STATE.json'), JSON.stringify({
274
+ ...common,
275
+ artifactDir: 'workflows/bugfixes/260615-2-active',
276
+ phases: [
277
+ { name: 'triage', index: 0, status: 'completed' },
278
+ { name: 'fix', index: 1, status: 'active' },
279
+ { name: 'verify', index: 2, status: 'pending' },
280
+ ],
281
+ currentPhase: 1,
282
+ updatedAt: '2026-06-15T00:03:00.000Z',
283
+ }), 'utf-8');
284
+
285
+ const inProgress = findInProgressWorkflows(base);
286
+ assert.equal(inProgress.length, 1);
287
+ assert.equal(inProgress[0]?.artifactDir, 'workflows/bugfixes/260615-2-active');
288
+ });
289
+
290
+ // ═══════════════════════════════════════════════════════════════════════════