gsd-pi 2.76.0-dev.fe143342a → 2.77.0-dev.1d17f366c

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 (597) hide show
  1. package/README.md +17 -35
  2. package/dist/claude-cli-check.js +32 -3
  3. package/dist/cli-web-branch.d.ts +1 -0
  4. package/dist/cli-web-branch.js +3 -0
  5. package/dist/cli.js +38 -2
  6. package/dist/extension-discovery.d.ts +6 -0
  7. package/dist/extension-discovery.js +37 -0
  8. package/dist/extension-registry.d.ts +3 -0
  9. package/dist/extension-sort.d.ts +18 -0
  10. package/dist/extension-sort.js +114 -0
  11. package/dist/extension-validator.d.ts +47 -0
  12. package/dist/extension-validator.js +127 -0
  13. package/dist/loader.js +35 -7
  14. package/dist/onboarding.js +45 -0
  15. package/dist/provider-migrations.d.ts +18 -0
  16. package/dist/provider-migrations.js +14 -0
  17. package/dist/resources/extensions/claude-code-cli/readiness.js +4 -3
  18. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +78 -59
  19. package/dist/resources/extensions/cmux/index.js +20 -0
  20. package/dist/resources/extensions/github-sync/templates.js +103 -0
  21. package/dist/resources/extensions/google-search/extension-manifest.json +5 -4
  22. package/dist/resources/extensions/google-search/index.js +3 -375
  23. package/dist/resources/extensions/gsd/abandon-detect.js +44 -0
  24. package/dist/resources/extensions/gsd/auto/loop.js +90 -2
  25. package/dist/resources/extensions/gsd/auto/phases.js +95 -21
  26. package/dist/resources/extensions/gsd/auto/resolve.js +24 -0
  27. package/dist/resources/extensions/gsd/auto/run-unit.js +48 -4
  28. package/dist/resources/extensions/gsd/auto/session.js +18 -1
  29. package/dist/resources/extensions/gsd/auto/turn-epoch.js +95 -0
  30. package/dist/resources/extensions/gsd/auto-dispatch.js +115 -17
  31. package/dist/resources/extensions/gsd/auto-loop.js +1 -1
  32. package/dist/resources/extensions/gsd/auto-model-selection.js +1 -1
  33. package/dist/resources/extensions/gsd/auto-post-unit.js +90 -2
  34. package/dist/resources/extensions/gsd/auto-prompts.js +14 -0
  35. package/dist/resources/extensions/gsd/auto-recovery.js +46 -1
  36. package/dist/resources/extensions/gsd/auto-start.js +45 -39
  37. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +11 -5
  38. package/dist/resources/extensions/gsd/auto-unit-closeout.js +11 -2
  39. package/dist/resources/extensions/gsd/auto-worktree.js +109 -61
  40. package/dist/resources/extensions/gsd/auto.js +97 -31
  41. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +27 -1
  42. package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +4 -2
  43. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +11 -0
  44. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +17 -6
  45. package/dist/resources/extensions/gsd/bootstrap/system-context.js +11 -6
  46. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +34 -2
  47. package/dist/resources/extensions/gsd/clean-root-preflight.js +93 -0
  48. package/dist/resources/extensions/gsd/commands/handlers/workflow.js +31 -4
  49. package/dist/resources/extensions/gsd/commands-cmux.js +9 -6
  50. package/dist/resources/extensions/gsd/commands-extensions.js +634 -43
  51. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +968 -23
  52. package/dist/resources/extensions/gsd/dispatch-guard.js +29 -3
  53. package/dist/resources/extensions/gsd/file-lock.js +49 -9
  54. package/dist/resources/extensions/gsd/git-service.js +1 -0
  55. package/dist/resources/extensions/gsd/gitignore.js +2 -0
  56. package/dist/resources/extensions/gsd/gsd-db.js +90 -30
  57. package/dist/resources/extensions/gsd/guided-flow-queue.js +4 -1
  58. package/dist/resources/extensions/gsd/guided-flow.js +212 -9
  59. package/dist/resources/extensions/gsd/health-widget.js +4 -1
  60. package/dist/resources/extensions/gsd/journal.js +17 -2
  61. package/dist/resources/extensions/gsd/key-manager.js +22 -0
  62. package/dist/resources/extensions/gsd/milestone-actions.js +15 -0
  63. package/dist/resources/extensions/gsd/milestone-summary-classifier.js +37 -0
  64. package/dist/resources/extensions/gsd/model-router.js +36 -3
  65. package/dist/resources/extensions/gsd/notifications.js +30 -16
  66. package/dist/resources/extensions/gsd/pre-execution-checks.js +31 -6
  67. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
  68. package/dist/resources/extensions/gsd/prompts/discuss.md +29 -2
  69. package/dist/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
  70. package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  71. package/dist/resources/extensions/gsd/prompts/system.md +1 -0
  72. package/dist/resources/extensions/gsd/reports.js +5 -4
  73. package/dist/resources/extensions/gsd/safety/evidence-collector.js +96 -0
  74. package/dist/resources/extensions/gsd/safety/file-change-validator.js +12 -4
  75. package/dist/resources/extensions/gsd/safety/safety-harness.js +5 -1
  76. package/dist/resources/extensions/gsd/state-transition-matrix.js +118 -0
  77. package/dist/resources/extensions/gsd/state.js +25 -25
  78. package/dist/resources/extensions/gsd/token-counter.js +22 -5
  79. package/dist/resources/extensions/gsd/tools/complete-milestone.js +16 -10
  80. package/dist/resources/extensions/gsd/tools/complete-slice.js +21 -0
  81. package/dist/resources/extensions/gsd/tools/complete-task.js +31 -0
  82. package/dist/resources/extensions/gsd/uok/audit.js +18 -2
  83. package/dist/resources/extensions/gsd/uok/dispatch-envelope.js +33 -0
  84. package/dist/resources/extensions/gsd/uok/execution-graph.js +10 -0
  85. package/dist/resources/extensions/gsd/uok/gitops.js +2 -1
  86. package/dist/resources/extensions/gsd/uok/loop-adapter.js +37 -10
  87. package/dist/resources/extensions/gsd/uok/parity-report.js +58 -0
  88. package/dist/resources/extensions/gsd/uok/plan-v2.js +30 -7
  89. package/dist/resources/extensions/gsd/uok/writer.js +82 -0
  90. package/dist/resources/extensions/gsd/workflow-logger.js +10 -2
  91. package/dist/resources/extensions/gsd/worktree-manager.js +1 -0
  92. package/dist/resources/extensions/gsd/worktree-resolver.js +50 -10
  93. package/dist/resources/extensions/mcp-client/auth.js +10 -1
  94. package/dist/resources/extensions/mcp-client/index.js +118 -9
  95. package/dist/resources/extensions/shared/cmux-events.js +12 -0
  96. package/dist/resources/extensions/shared/rtk-session-stats.js +1 -2
  97. package/dist/resources/skills/create-skill/SKILL.md +2 -2
  98. package/dist/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
  99. package/dist/resources/skills/create-skill/workflows/audit-skill.md +4 -4
  100. package/dist/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
  101. package/dist/resources/skills/verify-before-complete/SKILL.md +2 -1
  102. package/dist/resources/skills/write-docs/SKILL.md +2 -1
  103. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  104. package/dist/web/standalone/.next/BUILD_ID +1 -1
  105. package/dist/web/standalone/.next/app-path-routes-manifest.json +9 -9
  106. package/dist/web/standalone/.next/build-manifest.json +3 -3
  107. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  108. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  109. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  110. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  111. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  112. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  113. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  114. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  115. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  116. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  117. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  118. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  119. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  120. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  121. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  122. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  123. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  124. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  125. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  126. package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
  127. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  128. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
  129. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  130. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
  131. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +1 -1
  132. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
  133. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  134. package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
  135. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  136. package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
  137. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  138. package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
  139. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  140. package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
  141. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  142. package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
  143. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  144. package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
  145. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  146. package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
  147. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  148. package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
  149. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  150. package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
  151. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  152. package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
  153. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  154. package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
  155. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  156. package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
  157. package/dist/web/standalone/.next/server/app/api/notifications/route.js +1 -1
  158. package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
  159. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  160. package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
  161. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  162. package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
  163. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  164. package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
  165. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  166. package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
  167. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  168. package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
  169. package/dist/web/standalone/.next/server/app/api/session/events/route.js +1 -1
  170. package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
  171. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  172. package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
  173. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  174. package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
  175. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  176. package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
  177. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  178. package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
  179. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  180. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
  181. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
  182. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
  183. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +1 -1
  184. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
  185. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  186. package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
  187. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  188. package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
  189. package/dist/web/standalone/.next/server/app/index.html +1 -1
  190. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  191. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  192. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  193. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  194. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  195. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  196. package/dist/web/standalone/.next/server/app-paths-manifest.json +9 -9
  197. package/dist/web/standalone/.next/server/chunks/1926.js +1 -0
  198. package/dist/web/standalone/.next/server/chunks/6897.js +2 -2
  199. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  200. package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
  201. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  202. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  203. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  204. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  205. package/dist/web/standalone/.next/static/chunks/2826.e9f5195e91f9cad2.js +11 -0
  206. package/dist/web/standalone/.next/static/chunks/{webpack-5fc74f13a25fa1bb.js → webpack-2e68521d7c82f7c2.js} +1 -1
  207. package/dist/welcome-screen.js +6 -1
  208. package/dist/wizard.js +2 -0
  209. package/package.json +16 -14
  210. package/packages/daemon/package.json +2 -2
  211. package/packages/mcp-server/README.md +3 -3
  212. package/packages/mcp-server/dist/env-writer.d.ts +1 -0
  213. package/packages/mcp-server/dist/env-writer.d.ts.map +1 -1
  214. package/packages/mcp-server/dist/env-writer.js +74 -6
  215. package/packages/mcp-server/dist/env-writer.js.map +1 -1
  216. package/packages/mcp-server/dist/remote-questions.d.ts +45 -0
  217. package/packages/mcp-server/dist/remote-questions.d.ts.map +1 -0
  218. package/packages/mcp-server/dist/remote-questions.js +732 -0
  219. package/packages/mcp-server/dist/remote-questions.js.map +1 -0
  220. package/packages/mcp-server/dist/server.d.ts +7 -0
  221. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  222. package/packages/mcp-server/dist/server.js +95 -10
  223. package/packages/mcp-server/dist/server.js.map +1 -1
  224. package/packages/mcp-server/dist/session-manager.d.ts +14 -0
  225. package/packages/mcp-server/dist/session-manager.d.ts.map +1 -1
  226. package/packages/mcp-server/dist/session-manager.js +49 -1
  227. package/packages/mcp-server/dist/session-manager.js.map +1 -1
  228. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  229. package/packages/mcp-server/dist/workflow-tools.js +15 -6
  230. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  231. package/packages/mcp-server/package.json +9 -3
  232. package/packages/mcp-server/src/env-writer.test.ts +79 -1
  233. package/packages/mcp-server/src/env-writer.ts +76 -6
  234. package/packages/mcp-server/src/mcp-server.test.ts +67 -0
  235. package/packages/mcp-server/src/readers/readers.test.ts +5 -1
  236. package/packages/mcp-server/src/remote-questions.test.ts +294 -0
  237. package/packages/mcp-server/src/remote-questions.ts +916 -0
  238. package/packages/mcp-server/src/server.ts +118 -16
  239. package/packages/mcp-server/src/session-manager.ts +43 -1
  240. package/packages/mcp-server/src/workflow-tools.test.ts +44 -0
  241. package/packages/mcp-server/src/workflow-tools.ts +19 -6
  242. package/packages/mcp-server/tsconfig.test.json +19 -0
  243. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  244. package/packages/native/package.json +6 -1
  245. package/packages/native/src/__tests__/clipboard.test.mjs +69 -23
  246. package/packages/native/tsconfig.tsbuildinfo +1 -1
  247. package/packages/pi-agent-core/package.json +6 -1
  248. package/packages/pi-agent-core/src/agent-loop.test.ts +220 -15
  249. package/packages/pi-ai/dist/models/custom.d.ts +38 -0
  250. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -1
  251. package/packages/pi-ai/dist/models/custom.js +41 -0
  252. package/packages/pi-ai/dist/models/custom.js.map +1 -1
  253. package/packages/pi-ai/dist/providers/anthropic-auth.test.js +1 -1
  254. package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
  255. package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
  256. package/packages/pi-ai/dist/providers/anthropic-shared.js +27 -4
  257. package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
  258. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  259. package/packages/pi-ai/dist/providers/anthropic.js +8 -3
  260. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  261. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts +2 -0
  262. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts.map +1 -0
  263. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +80 -0
  264. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -0
  265. package/packages/pi-ai/dist/providers/simple-options.d.ts +10 -0
  266. package/packages/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
  267. package/packages/pi-ai/dist/providers/simple-options.js +16 -1
  268. package/packages/pi-ai/dist/providers/simple-options.js.map +1 -1
  269. package/packages/pi-ai/package.json +6 -1
  270. package/packages/pi-ai/src/models/custom.ts +42 -0
  271. package/packages/pi-ai/src/providers/anthropic-auth.test.ts +1 -1
  272. package/packages/pi-ai/src/providers/anthropic-shared.ts +26 -5
  273. package/packages/pi-ai/src/providers/anthropic.ts +9 -3
  274. package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +98 -0
  275. package/packages/pi-ai/src/providers/simple-options.ts +17 -1
  276. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  277. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +3 -2
  278. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
  279. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -0
  280. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  281. package/packages/pi-coding-agent/dist/core/agent-session.js +7 -0
  282. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  283. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +25 -0
  284. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
  285. package/packages/pi-coding-agent/dist/core/compaction/compaction.js +105 -6
  286. package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
  287. package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js +230 -28
  288. package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js.map +1 -1
  289. package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts +30 -2
  290. package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts.map +1 -1
  291. package/packages/pi-coding-agent/dist/core/compaction/utils.js +113 -12
  292. package/packages/pi-coding-agent/dist/core/compaction/utils.js.map +1 -1
  293. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts +1 -0
  294. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts.map +1 -1
  295. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js +29 -18
  296. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js.map +1 -1
  297. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts +2 -0
  298. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts.map +1 -0
  299. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js +130 -0
  300. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js.map +1 -0
  301. package/packages/pi-coding-agent/dist/core/compaction-utils.test.js +56 -1
  302. package/packages/pi-coding-agent/dist/core/compaction-utils.test.js.map +1 -1
  303. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js +8 -15
  304. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js.map +1 -1
  305. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts +25 -0
  306. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts.map +1 -0
  307. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js +109 -0
  308. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js.map +1 -0
  309. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts +67 -0
  310. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts.map +1 -0
  311. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js +167 -0
  312. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js.map +1 -0
  313. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +3 -2
  314. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  315. package/packages/pi-coding-agent/dist/core/extensions/loader.js +24 -8
  316. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  317. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +2 -0
  318. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
  319. package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
  320. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +14 -0
  321. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  322. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  323. package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js +11 -0
  324. package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js.map +1 -1
  325. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +2 -2
  326. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
  327. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts +2 -0
  328. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts.map +1 -0
  329. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js +203 -0
  330. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js.map +1 -0
  331. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  332. package/packages/pi-coding-agent/dist/core/model-registry.js +14 -0
  333. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  334. package/packages/pi-coding-agent/dist/core/resource-loader.js +1 -1
  335. package/packages/pi-coding-agent/dist/core/resource-loader.js.map +1 -1
  336. package/packages/pi-coding-agent/dist/core/sdk.d.ts +1 -0
  337. package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  338. package/packages/pi-coding-agent/dist/core/sdk.js +4 -1
  339. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  340. package/packages/pi-coding-agent/dist/core/sdk.test.js +19 -1
  341. package/packages/pi-coding-agent/dist/core/sdk.test.js.map +1 -1
  342. package/packages/pi-coding-agent/dist/core/session-manager.js +1 -1
  343. package/packages/pi-coding-agent/dist/core/session-manager.js.map +1 -1
  344. package/packages/pi-coding-agent/dist/core/session-manager.test.js +21 -1
  345. package/packages/pi-coding-agent/dist/core/session-manager.test.js.map +1 -1
  346. package/packages/pi-coding-agent/dist/core/system-prompt.js +3 -3
  347. package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
  348. package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js +2 -1
  349. package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js.map +1 -1
  350. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js +15 -6
  351. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js.map +1 -1
  352. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  353. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +14 -5
  354. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  355. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts +7 -1
  356. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts.map +1 -1
  357. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js +31 -9
  358. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js.map +1 -1
  359. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js +14 -0
  360. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js.map +1 -1
  361. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  362. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +13 -1
  363. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  364. package/packages/pi-coding-agent/package.json +6 -1
  365. package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +3 -2
  366. package/packages/pi-coding-agent/src/core/agent-session.ts +11 -0
  367. package/packages/pi-coding-agent/src/core/compaction/compaction.test.ts +368 -28
  368. package/packages/pi-coding-agent/src/core/compaction/compaction.ts +122 -6
  369. package/packages/pi-coding-agent/src/core/compaction/utils.ts +111 -13
  370. package/packages/pi-coding-agent/src/core/compaction-orchestrator.test.ts +154 -0
  371. package/packages/pi-coding-agent/src/core/compaction-orchestrator.ts +32 -18
  372. package/packages/pi-coding-agent/src/core/compaction-utils.test.ts +68 -1
  373. package/packages/pi-coding-agent/src/core/discovery-cache.test.ts +9 -18
  374. package/packages/pi-coding-agent/src/core/extensions/extension-discovery.ts +119 -0
  375. package/packages/pi-coding-agent/src/core/extensions/extension-registry.ts +222 -0
  376. package/packages/pi-coding-agent/src/core/extensions/loader.ts +24 -11
  377. package/packages/pi-coding-agent/src/core/extensions/runner.ts +2 -0
  378. package/packages/pi-coding-agent/src/core/extensions/types.ts +15 -0
  379. package/packages/pi-coding-agent/src/core/lsp/lsp-integration.test.ts +13 -0
  380. package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +2 -2
  381. package/packages/pi-coding-agent/src/core/model-registry-custom-caps.test.ts +245 -0
  382. package/packages/pi-coding-agent/src/core/model-registry.ts +16 -0
  383. package/packages/pi-coding-agent/src/core/resource-loader.ts +1 -1
  384. package/packages/pi-coding-agent/src/core/sdk.test.ts +25 -1
  385. package/packages/pi-coding-agent/src/core/sdk.ts +10 -3
  386. package/packages/pi-coding-agent/src/core/session-manager.test.ts +30 -1
  387. package/packages/pi-coding-agent/src/core/session-manager.ts +1 -1
  388. package/packages/pi-coding-agent/src/core/system-prompt.ts +3 -3
  389. package/packages/pi-coding-agent/src/core/tools/path-utils.test.ts +2 -1
  390. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/provider-display-name.test.ts +17 -7
  391. package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +14 -5
  392. package/packages/pi-coding-agent/src/modes/interactive/components/model-selector.ts +45 -11
  393. package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.test.ts +14 -0
  394. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +13 -1
  395. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  396. package/packages/pi-tui/dist/__tests__/autocomplete.test.js +12 -5
  397. package/packages/pi-tui/dist/__tests__/autocomplete.test.js.map +1 -1
  398. package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js +21 -0
  399. package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js.map +1 -1
  400. package/packages/pi-tui/dist/stdin-buffer.d.ts +7 -0
  401. package/packages/pi-tui/dist/stdin-buffer.d.ts.map +1 -1
  402. package/packages/pi-tui/dist/stdin-buffer.js +20 -0
  403. package/packages/pi-tui/dist/stdin-buffer.js.map +1 -1
  404. package/packages/pi-tui/package.json +6 -1
  405. package/packages/pi-tui/src/__tests__/autocomplete.test.ts +20 -5
  406. package/packages/pi-tui/src/__tests__/stdin-buffer.test.ts +27 -0
  407. package/packages/pi-tui/src/stdin-buffer.ts +26 -0
  408. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
  409. package/packages/rpc-client/package.json +6 -1
  410. package/pkg/package.json +1 -1
  411. package/scripts/install.js +512 -0
  412. package/scripts/lib/workspace-manifest.cjs +86 -0
  413. package/scripts/link-workspace-packages.cjs +5 -17
  414. package/scripts/postinstall.js +9 -178
  415. package/src/resources/extensions/claude-code-cli/readiness.ts +4 -3
  416. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +91 -63
  417. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +114 -12
  418. package/src/resources/extensions/cmux/index.ts +35 -10
  419. package/src/resources/extensions/github-sync/templates.ts +151 -0
  420. package/src/resources/extensions/github-sync/tests/templates.test.ts +59 -0
  421. package/src/resources/extensions/google-search/extension-manifest.json +5 -4
  422. package/src/resources/extensions/google-search/index.ts +9 -470
  423. package/src/resources/extensions/gsd/abandon-detect.ts +62 -0
  424. package/src/resources/extensions/gsd/auto/loop-deps.ts +14 -1
  425. package/src/resources/extensions/gsd/auto/loop.ts +104 -2
  426. package/src/resources/extensions/gsd/auto/phases.ts +123 -21
  427. package/src/resources/extensions/gsd/auto/resolve.ts +29 -0
  428. package/src/resources/extensions/gsd/auto/run-unit.ts +56 -4
  429. package/src/resources/extensions/gsd/auto/session.ts +28 -1
  430. package/src/resources/extensions/gsd/auto/turn-epoch.ts +108 -0
  431. package/src/resources/extensions/gsd/auto/types.ts +1 -1
  432. package/src/resources/extensions/gsd/auto-dispatch.ts +117 -16
  433. package/src/resources/extensions/gsd/auto-loop.ts +1 -1
  434. package/src/resources/extensions/gsd/auto-model-selection.ts +1 -1
  435. package/src/resources/extensions/gsd/auto-post-unit.ts +92 -3
  436. package/src/resources/extensions/gsd/auto-prompts.ts +28 -1
  437. package/src/resources/extensions/gsd/auto-recovery.ts +40 -1
  438. package/src/resources/extensions/gsd/auto-start.ts +48 -52
  439. package/src/resources/extensions/gsd/auto-timeout-recovery.ts +12 -5
  440. package/src/resources/extensions/gsd/auto-unit-closeout.ts +14 -3
  441. package/src/resources/extensions/gsd/auto-worktree.ts +122 -68
  442. package/src/resources/extensions/gsd/auto.ts +105 -35
  443. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +34 -1
  444. package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +6 -2
  445. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +11 -0
  446. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +18 -6
  447. package/src/resources/extensions/gsd/bootstrap/system-context.ts +13 -9
  448. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +35 -2
  449. package/src/resources/extensions/gsd/clean-root-preflight.ts +111 -0
  450. package/src/resources/extensions/gsd/commands/handlers/workflow.ts +27 -8
  451. package/src/resources/extensions/gsd/commands-cmux.ts +10 -6
  452. package/src/resources/extensions/gsd/commands-extensions.ts +747 -41
  453. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +898 -32
  454. package/src/resources/extensions/gsd/dispatch-guard.ts +26 -2
  455. package/src/resources/extensions/gsd/file-lock.ts +84 -11
  456. package/src/resources/extensions/gsd/git-service.ts +1 -0
  457. package/src/resources/extensions/gsd/gitignore.ts +2 -1
  458. package/src/resources/extensions/gsd/gsd-db.ts +92 -32
  459. package/src/resources/extensions/gsd/guided-flow-queue.ts +4 -1
  460. package/src/resources/extensions/gsd/guided-flow.ts +259 -10
  461. package/src/resources/extensions/gsd/health-widget.ts +3 -1
  462. package/src/resources/extensions/gsd/journal.ts +29 -3
  463. package/src/resources/extensions/gsd/key-manager.ts +22 -0
  464. package/src/resources/extensions/gsd/milestone-actions.ts +18 -0
  465. package/src/resources/extensions/gsd/milestone-summary-classifier.ts +42 -0
  466. package/src/resources/extensions/gsd/model-router.ts +42 -1
  467. package/src/resources/extensions/gsd/notifications.ts +27 -15
  468. package/src/resources/extensions/gsd/pre-execution-checks.ts +33 -7
  469. package/src/resources/extensions/gsd/preferences-types.ts +8 -0
  470. package/src/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
  471. package/src/resources/extensions/gsd/prompts/discuss.md +29 -2
  472. package/src/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
  473. package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  474. package/src/resources/extensions/gsd/prompts/system.md +1 -0
  475. package/src/resources/extensions/gsd/reports.ts +5 -4
  476. package/src/resources/extensions/gsd/safety/evidence-collector.ts +119 -0
  477. package/src/resources/extensions/gsd/safety/file-change-validator.ts +16 -3
  478. package/src/resources/extensions/gsd/safety/safety-harness.ts +9 -0
  479. package/src/resources/extensions/gsd/state-transition-matrix.ts +152 -0
  480. package/src/resources/extensions/gsd/state.ts +35 -30
  481. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +238 -4
  482. package/src/resources/extensions/gsd/tests/auto-mode-guards.test.ts +79 -0
  483. package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +12 -0
  484. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +122 -0
  485. package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +141 -0
  486. package/src/resources/extensions/gsd/tests/auto-start-clean-runtime-db-gated.test.ts +63 -0
  487. package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +23 -0
  488. package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +186 -0
  489. package/src/resources/extensions/gsd/tests/cmux.test.ts +5 -9
  490. package/src/resources/extensions/gsd/tests/complete-milestone-false-merge.test.ts +15 -0
  491. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +61 -1
  492. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  493. package/src/resources/extensions/gsd/tests/complete-task.test.ts +2 -2
  494. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +161 -0
  495. package/src/resources/extensions/gsd/tests/db-access-guardrails.test.ts +1 -0
  496. package/src/resources/extensions/gsd/tests/derive-state.test.ts +1 -2
  497. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +14 -9
  498. package/src/resources/extensions/gsd/tests/dispatch-guard-summary-db-mismatch.test.ts +77 -0
  499. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +25 -0
  500. package/src/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +14 -0
  501. package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +31 -0
  502. package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +1 -1
  503. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +1 -1
  504. package/src/resources/extensions/gsd/tests/escalation.test.ts +1 -1
  505. package/src/resources/extensions/gsd/tests/exec-history.test.ts +113 -0
  506. package/src/resources/extensions/gsd/tests/execution-entry-missing-context-4671.test.ts +173 -0
  507. package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +38 -0
  508. package/src/resources/extensions/gsd/tests/file-lock.test.ts +86 -12
  509. package/src/resources/extensions/gsd/tests/google-search-stub.test.ts +131 -0
  510. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +296 -1
  511. package/src/resources/extensions/gsd/tests/headless-milestone-parity.test.ts +117 -0
  512. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +30 -0
  513. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +4 -2
  514. package/src/resources/extensions/gsd/tests/integration/gitignore-tracked-gsd.test.ts +1 -0
  515. package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +30 -0
  516. package/src/resources/extensions/gsd/tests/integration/worktree-e2e.test.ts +11 -0
  517. package/src/resources/extensions/gsd/tests/issue-4540-regressions.test.ts +288 -0
  518. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +66 -0
  519. package/src/resources/extensions/gsd/tests/key-manager.test.ts +2 -0
  520. package/src/resources/extensions/gsd/tests/mcp-client-security.test.ts +76 -0
  521. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
  522. package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +12 -0
  523. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  524. package/src/resources/extensions/gsd/tests/milestone-status-authoritative.test.ts +3 -3
  525. package/src/resources/extensions/gsd/tests/milestone-summary-classifier.test.ts +30 -0
  526. package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +4 -2
  527. package/src/resources/extensions/gsd/tests/parallel-commit-scope.test.ts +5 -0
  528. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +19 -0
  529. package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +150 -0
  530. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +37 -0
  531. package/src/resources/extensions/gsd/tests/pre-exec-gate-loop.test.ts +272 -0
  532. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +337 -0
  533. package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +44 -0
  534. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +39 -25
  535. package/src/resources/extensions/gsd/tests/queue-auto-guard.test.ts +181 -0
  536. package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +13 -7
  537. package/src/resources/extensions/gsd/tests/ready-phrase-no-files-4573.test.ts +388 -0
  538. package/src/resources/extensions/gsd/tests/require-slice-discussion-dispatch.test.ts +170 -0
  539. package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +9 -3
  540. package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +230 -0
  541. package/src/resources/extensions/gsd/tests/rewrite-docs-abandon-detect.test.ts +195 -0
  542. package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +205 -0
  543. package/src/resources/extensions/gsd/tests/schema-v21-sequence.test.ts +413 -0
  544. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +32 -40
  545. package/src/resources/extensions/gsd/tests/stale-dirlistcache-4648.test.ts +112 -0
  546. package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +56 -0
  547. package/src/resources/extensions/gsd/tests/state-machine-full-walkthrough.test.ts +24 -0
  548. package/src/resources/extensions/gsd/tests/state-transition-matrix.test.ts +44 -0
  549. package/src/resources/extensions/gsd/tests/stuck-detection-coverage.test.ts +2 -2
  550. package/src/resources/extensions/gsd/tests/token-counter.test.ts +105 -1
  551. package/src/resources/extensions/gsd/tests/tool-compatibility.test.ts +107 -0
  552. package/src/resources/extensions/gsd/tests/triage-resolution.test.ts +50 -2
  553. package/src/resources/extensions/gsd/tests/turn-epoch.test.ts +162 -0
  554. package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +51 -0
  555. package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +16 -0
  556. package/src/resources/extensions/gsd/tests/uok-loop-adapter-writer.test.ts +65 -0
  557. package/src/resources/extensions/gsd/tests/uok-parity-report.test.ts +42 -0
  558. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +42 -2
  559. package/src/resources/extensions/gsd/tests/uok-writer.test.ts +75 -0
  560. package/src/resources/extensions/gsd/tests/validate-extension-package.test.ts +168 -0
  561. package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +138 -5
  562. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +25 -2
  563. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +65 -2
  564. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +35 -0
  565. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +6 -1
  566. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +78 -5
  567. package/src/resources/extensions/gsd/tests/write-gate.test.ts +64 -0
  568. package/src/resources/extensions/gsd/token-counter.ts +22 -5
  569. package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
  570. package/src/resources/extensions/gsd/tools/complete-slice.ts +38 -0
  571. package/src/resources/extensions/gsd/tools/complete-task.ts +49 -0
  572. package/src/resources/extensions/gsd/uok/audit.ts +20 -2
  573. package/src/resources/extensions/gsd/uok/contracts.ts +65 -0
  574. package/src/resources/extensions/gsd/uok/dispatch-envelope.ts +56 -0
  575. package/src/resources/extensions/gsd/uok/execution-graph.ts +22 -0
  576. package/src/resources/extensions/gsd/uok/gitops.ts +6 -1
  577. package/src/resources/extensions/gsd/uok/loop-adapter.ts +45 -10
  578. package/src/resources/extensions/gsd/uok/parity-report.ts +84 -0
  579. package/src/resources/extensions/gsd/uok/plan-v2.ts +39 -8
  580. package/src/resources/extensions/gsd/uok/writer.ts +113 -0
  581. package/src/resources/extensions/gsd/workflow-logger.ts +23 -3
  582. package/src/resources/extensions/gsd/worktree-manager.ts +1 -0
  583. package/src/resources/extensions/gsd/worktree-resolver.ts +54 -9
  584. package/src/resources/extensions/mcp-client/auth.ts +12 -1
  585. package/src/resources/extensions/mcp-client/index.ts +129 -10
  586. package/src/resources/extensions/shared/cmux-events.ts +59 -0
  587. package/src/resources/extensions/shared/rtk-session-stats.ts +1 -2
  588. package/src/resources/skills/create-skill/SKILL.md +2 -2
  589. package/src/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
  590. package/src/resources/skills/create-skill/workflows/audit-skill.md +4 -4
  591. package/src/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
  592. package/src/resources/skills/verify-before-complete/SKILL.md +2 -1
  593. package/src/resources/skills/write-docs/SKILL.md +2 -1
  594. package/dist/web/standalone/.next/server/chunks/7461.js +0 -1
  595. package/dist/web/standalone/.next/static/chunks/2826.e59e8578e2e28639.js +0 -9
  596. /package/dist/web/standalone/.next/static/{n21VtX2hZlkpdEUO_nU4z → vidAVJkURvTJ0_V2-64ro}/_buildManifest.js +0 -0
  597. /package/dist/web/standalone/.next/static/{n21VtX2hZlkpdEUO_nU4z → vidAVJkURvTJ0_V2-64ro}/_ssgManifest.js +0 -0
@@ -1599,6 +1599,221 @@ describe("checkTaskOrdering directory inputs (#4446)", () => {
1599
1599
  });
1600
1600
  });
1601
1601
 
1602
+ // ─── Regression Tests: checkTaskOrdering false positive for pre-execution refs (#4071) ──
1603
+
1604
+ describe("checkTaskOrdering false positive for pre-execution refs (#4071)", () => {
1605
+ test("completed task at higher index does not trigger ordering violation for its outputs", () => {
1606
+ // Scenario: after a replan, a completed task at higher array index has already
1607
+ // created a file. A new earlier-sequence task reads that file. Since the
1608
+ // completed task already ran, its output is available regardless of disk state.
1609
+ // checkTaskOrdering must not flag this as a sequence violation.
1610
+ const tasks = [
1611
+ createTask({
1612
+ id: "T_NEW",
1613
+ sequence: 1,
1614
+ status: "pending",
1615
+ inputs: ["artifacts/setup.json"],
1616
+ expected_output: [],
1617
+ }),
1618
+ createTask({
1619
+ id: "T_SETUP",
1620
+ sequence: 5,
1621
+ status: "completed",
1622
+ inputs: [],
1623
+ expected_output: ["artifacts/setup.json"],
1624
+ }),
1625
+ ];
1626
+
1627
+ const results = checkTaskOrdering(tasks, "/tmp");
1628
+ assert.equal(
1629
+ results.length,
1630
+ 0,
1631
+ "completed task outputs must not trigger ordering violations for earlier-sequence tasks that read them",
1632
+ );
1633
+ });
1634
+
1635
+ test("pending task at higher index still triggers ordering violation", () => {
1636
+ // A PENDING task at higher index creating a file is a real violation.
1637
+ // Only completed tasks get the exemption.
1638
+ const tasks = [
1639
+ createTask({
1640
+ id: "T01",
1641
+ sequence: 1,
1642
+ status: "pending",
1643
+ inputs: ["artifacts/output.json"],
1644
+ expected_output: [],
1645
+ }),
1646
+ createTask({
1647
+ id: "T02",
1648
+ sequence: 5,
1649
+ status: "pending",
1650
+ inputs: [],
1651
+ expected_output: ["artifacts/output.json"],
1652
+ }),
1653
+ ];
1654
+
1655
+ const results = checkTaskOrdering(tasks, "/tmp");
1656
+ assert.equal(
1657
+ results.length,
1658
+ 1,
1659
+ "pending task at higher index must still be flagged as ordering violation",
1660
+ );
1661
+ assert.equal(results[0].blocking, true);
1662
+ assert.ok(results[0].message.includes("T01"));
1663
+ assert.ok(results[0].message.includes("T02"));
1664
+ assert.ok(results[0].message.includes("sequence violation"));
1665
+ });
1666
+
1667
+ test("pending-first then completed-later: completed replaces pending in fileCreators (#4572)", () => {
1668
+ // Regression for CodeRabbit Major finding on PR #4572:
1669
+ // fileCreators only stored the FIRST task for a given path. If a PENDING task at
1670
+ // array index 1 was registered first, and a COMPLETED task at array index 2 also
1671
+ // declared the same output path, the completed entry was discarded. Line ~529 then
1672
+ // saw a pending creator with index > i and incorrectly fired a sequence violation
1673
+ // for the reader at array index 0.
1674
+ //
1675
+ // Scenario: path first declared by pending task (index 1), then by completed task
1676
+ // (index 2). Reader is at index 0. Without the fix a violation fires; with the fix
1677
+ // the completed entry replaces the pending entry and grants the exemption.
1678
+ const tasks = [
1679
+ // array index 0 — reads the shared path
1680
+ createTask({
1681
+ id: "T_READER",
1682
+ sequence: 1,
1683
+ status: "pending",
1684
+ inputs: ["shared/artifact.json"],
1685
+ expected_output: [],
1686
+ }),
1687
+ // array index 1 — pending producer (visited first during map build)
1688
+ createTask({
1689
+ id: "T_PENDING_PRODUCER",
1690
+ sequence: 5,
1691
+ status: "pending",
1692
+ inputs: [],
1693
+ expected_output: ["shared/artifact.json"],
1694
+ }),
1695
+ // array index 2 — completed producer (visited second; must replace pending entry)
1696
+ createTask({
1697
+ id: "T_COMPLETED_PRODUCER",
1698
+ sequence: 2,
1699
+ status: "completed",
1700
+ inputs: [],
1701
+ expected_output: ["shared/artifact.json"],
1702
+ }),
1703
+ ];
1704
+
1705
+ // Without the fix: creator = T_PENDING_PRODUCER (index 1), !creator.completed && 1 > 0 → violation.
1706
+ // With the fix: creator = T_COMPLETED_PRODUCER (index 2), creator.completed → no violation.
1707
+ const results = checkTaskOrdering(tasks, "/tmp");
1708
+ assert.equal(
1709
+ results.length,
1710
+ 0,
1711
+ "completed producer must replace pending producer in fileCreators and suppress false violation",
1712
+ );
1713
+ });
1714
+
1715
+ test("completed task output exemption applies regardless of whether file exists on disk", (t) => {
1716
+ // The completed-task exemption must work even when the file is not on disk
1717
+ // (e.g., the file was a temporary artifact that was cleaned up after the task ran).
1718
+ const tempDir = join(tmpdir(), `pre-exec-completed-task-${Date.now()}`);
1719
+ mkdirSync(tempDir, { recursive: true });
1720
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1721
+
1722
+ // File deliberately NOT created on disk — completed task ran in a prior session
1723
+ const tasks = [
1724
+ createTask({
1725
+ id: "T_MAIN",
1726
+ sequence: 0,
1727
+ status: "pending",
1728
+ inputs: ["generated/config.json"],
1729
+ expected_output: [],
1730
+ }),
1731
+ createTask({
1732
+ id: "T_INIT",
1733
+ sequence: 10,
1734
+ status: "completed",
1735
+ inputs: [],
1736
+ expected_output: ["generated/config.json"],
1737
+ }),
1738
+ ];
1739
+
1740
+ const results = checkTaskOrdering(tasks, tempDir);
1741
+ assert.equal(
1742
+ results.length,
1743
+ 0,
1744
+ "completed task exemption must apply even when file is absent from disk",
1745
+ );
1746
+ });
1747
+ });
1748
+
1749
+ describe("checkFilePathConsistency completed-task output exemption (#4071)", () => {
1750
+ test("completed task at higher index does not cause false positive for file it produced", (t) => {
1751
+ // Parallel to the checkTaskOrdering fix: checkFilePathConsistency also uses
1752
+ // getExpectedOutputsUpTo which historically only looked at prior-index tasks.
1753
+ // A completed task at a higher index has already run and its outputs are available.
1754
+ const tempDir = join(tmpdir(), `pre-exec-fc-completed-${Date.now()}`);
1755
+ mkdirSync(tempDir, { recursive: true });
1756
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1757
+
1758
+ // File is NOT on disk — completed task ran in a prior session and file was cleaned
1759
+ const tasks = [
1760
+ createTask({
1761
+ id: "T_MAIN",
1762
+ sequence: 1,
1763
+ status: "pending",
1764
+ inputs: ["artifacts/config.json"],
1765
+ expected_output: [],
1766
+ }),
1767
+ createTask({
1768
+ id: "T_SETUP",
1769
+ sequence: 10,
1770
+ status: "completed",
1771
+ inputs: [],
1772
+ expected_output: ["artifacts/config.json"],
1773
+ }),
1774
+ ];
1775
+
1776
+ const results = checkFilePathConsistency(tasks, tempDir);
1777
+ assert.equal(
1778
+ results.length,
1779
+ 0,
1780
+ "completed task at higher index should satisfy inputs of pending tasks that read its outputs",
1781
+ );
1782
+ });
1783
+
1784
+ test("pending task at higher index still causes a missing-file error", (t) => {
1785
+ const tempDir = join(tmpdir(), `pre-exec-fc-pending-${Date.now()}`);
1786
+ mkdirSync(tempDir, { recursive: true });
1787
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1788
+
1789
+ const tasks = [
1790
+ createTask({
1791
+ id: "T01",
1792
+ sequence: 1,
1793
+ status: "pending",
1794
+ inputs: ["artifacts/output.json"],
1795
+ expected_output: [],
1796
+ }),
1797
+ createTask({
1798
+ id: "T02",
1799
+ sequence: 10,
1800
+ status: "pending",
1801
+ inputs: [],
1802
+ expected_output: ["artifacts/output.json"],
1803
+ }),
1804
+ ];
1805
+
1806
+ const results = checkFilePathConsistency(tasks, tempDir);
1807
+ assert.equal(
1808
+ results.length,
1809
+ 1,
1810
+ "pending task at higher index must still be flagged — the file is not available yet",
1811
+ );
1812
+ assert.equal(results[0].blocking, true);
1813
+ assert.equal(results[0].target, "artifacts/output.json");
1814
+ });
1815
+ });
1816
+
1602
1817
  describe("checkFilePathConsistency self-referential inputs (#4459)", () => {
1603
1818
  test("input that is also in the same task's expected_output is not blocking when missing on disk", (t) => {
1604
1819
  const tempDir = join(tmpdir(), `pre-exec-self-output-${Date.now()}`);
@@ -1664,3 +1879,125 @@ describe("checkFilePathConsistency self-referential inputs (#4459)", () => {
1664
1879
  );
1665
1880
  });
1666
1881
  });
1882
+
1883
+ // ─── Regression Tests: quote-wrapped inputs treated as literal paths (#3747) ──
1884
+
1885
+ describe("checkFilePathConsistency quote-wrapped annotation (#3747)", () => {
1886
+ test("double-quoted path annotation is stripped before path check", (t) => {
1887
+ // Plan documents sometimes emit `"src/foo.ts"` (double-quote wrapped) as an
1888
+ // input value. The checker must strip the quotes before checking existence so
1889
+ // it doesn't produce a false-positive "file not found" error.
1890
+ const tempDir = join(tmpdir(), `pre-exec-quote-${Date.now()}`);
1891
+ mkdirSync(join(tempDir, "src"), { recursive: true });
1892
+ writeFileSync(join(tempDir, "src/foo.ts"), "// content");
1893
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1894
+
1895
+ const tasks = [
1896
+ createTask({
1897
+ id: "T01",
1898
+ inputs: ['"src/foo.ts"'],
1899
+ expected_output: [],
1900
+ }),
1901
+ ];
1902
+
1903
+ const results = checkFilePathConsistency(tasks, tempDir);
1904
+ assert.equal(
1905
+ results.length,
1906
+ 0,
1907
+ "Double-quoted path should be stripped and resolved to the real file",
1908
+ );
1909
+ });
1910
+
1911
+ test("single-quoted path annotation is stripped before path check", (t) => {
1912
+ const tempDir = join(tmpdir(), `pre-exec-squote-${Date.now()}`);
1913
+ mkdirSync(join(tempDir, "src"), { recursive: true });
1914
+ writeFileSync(join(tempDir, "src/bar.ts"), "// content");
1915
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1916
+
1917
+ const tasks = [
1918
+ createTask({
1919
+ id: "T01",
1920
+ inputs: ["'src/bar.ts'"],
1921
+ expected_output: [],
1922
+ }),
1923
+ ];
1924
+
1925
+ const results = checkFilePathConsistency(tasks, tempDir);
1926
+ assert.equal(
1927
+ results.length,
1928
+ 0,
1929
+ "Single-quoted path should be stripped and resolved to the real file",
1930
+ );
1931
+ });
1932
+
1933
+ test("backtick-only wrapped path without annotation resolves correctly", (t) => {
1934
+ // The bare form `src/foo.ts` (no dash annotation) must also work
1935
+ const tempDir = join(tmpdir(), `pre-exec-backtick-bare-${Date.now()}`);
1936
+ mkdirSync(join(tempDir, "src"), { recursive: true });
1937
+ writeFileSync(join(tempDir, "src/baz.ts"), "// content");
1938
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1939
+
1940
+ const tasks = [
1941
+ createTask({
1942
+ id: "T01",
1943
+ inputs: ["`src/baz.ts`"],
1944
+ expected_output: [],
1945
+ }),
1946
+ ];
1947
+
1948
+ const results = checkFilePathConsistency(tasks, tempDir);
1949
+ assert.equal(
1950
+ results.length,
1951
+ 0,
1952
+ "Bare backtick-wrapped path should resolve to the real file",
1953
+ );
1954
+ });
1955
+
1956
+ test("prose value with spaces inside quotes is skipped (not a path)", () => {
1957
+ // "some description text" contains spaces — should not be checked as a path
1958
+ const tasks = [
1959
+ createTask({
1960
+ id: "T01",
1961
+ inputs: ['"some description text"'],
1962
+ expected_output: [],
1963
+ }),
1964
+ ];
1965
+
1966
+ const results = checkFilePathConsistency(tasks, "/tmp");
1967
+ assert.equal(
1968
+ results.length,
1969
+ 0,
1970
+ "Quoted prose with spaces should not be treated as a file path",
1971
+ );
1972
+ });
1973
+
1974
+ test("17-error scenario: mixed annotated inputs produce 0 blocking errors", (t) => {
1975
+ // Reproduces the M004-ej6j88/S07 scenario from issue #3747 where a plan with
1976
+ // multiple backtick- and quote-wrapped input strings causes 17 false blocking errors.
1977
+ const tempDir = join(tmpdir(), `pre-exec-3747-scenario-${Date.now()}`);
1978
+ mkdirSync(join(tempDir, "src"), { recursive: true });
1979
+ writeFileSync(join(tempDir, "src/foo.ts"), "// content");
1980
+ writeFileSync(join(tempDir, "src/bar.ts"), "// content");
1981
+ t.after(() => rmSync(tempDir, { recursive: true, force: true }));
1982
+
1983
+ const tasks = [
1984
+ createTask({
1985
+ id: "T01",
1986
+ inputs: [
1987
+ "`src/foo.ts`",
1988
+ '"src/bar.ts"',
1989
+ "some description text",
1990
+ "Existing enum definition",
1991
+ ],
1992
+ expected_output: [],
1993
+ }),
1994
+ ];
1995
+
1996
+ const results = checkFilePathConsistency(tasks, tempDir);
1997
+ assert.equal(
1998
+ results.length,
1999
+ 0,
2000
+ "Annotated file paths and prose inputs should produce zero blocking errors",
2001
+ );
2002
+ });
2003
+ });
@@ -0,0 +1,44 @@
1
+ // Guard test — every key in KNOWN_PREFERENCE_KEYS must be reachable from the
2
+ // /gsd prefs wizard. Without this guard, a new preference can be added to the
3
+ // schema without anyone wiring it into the TUI, silently re-creating the gap
4
+ // this test exists to prevent.
5
+
6
+ import test from "node:test";
7
+ import assert from "node:assert/strict";
8
+ import { readFileSync } from "node:fs";
9
+
10
+ import { KNOWN_PREFERENCE_KEYS } from "../preferences-types.ts";
11
+
12
+ // Keys exposed via a dedicated command rather than the wizard. They're still
13
+ // reachable by the user, just not inside the category menu flow. If you add a
14
+ // new key here, add a comment explaining where it lives.
15
+ const EXPOSED_OUTSIDE_WIZARD = new Set<string>([
16
+ "version", // auto-managed by writePreferencesFile
17
+ "modelOverrides", // advanced routing — edit PREFERENCES.md directly (not in KNOWN_PREFERENCE_KEYS)
18
+ "context_mode", // advanced sandbox config (gsd_exec + compaction) — enabled by default; edit PREFERENCES.md directly to tune timeouts/caps. Wizard coverage tracked separately.
19
+ ]);
20
+
21
+ test("every KNOWN_PREFERENCE_KEYS entry is reachable from the wizard source", () => {
22
+ const src = readFileSync(
23
+ new URL("../commands-prefs-wizard.ts", import.meta.url),
24
+ "utf-8",
25
+ );
26
+
27
+ const missing: string[] = [];
28
+ for (const key of KNOWN_PREFERENCE_KEYS) {
29
+ if (EXPOSED_OUTSIDE_WIZARD.has(key)) continue;
30
+ // The key must appear somewhere in the wizard — either as a direct
31
+ // prefs[...] / pref reference, or in the orderedKeys serialization list.
32
+ // A plain substring match is enough because all prefs-wizard references
33
+ // use the exact key name.
34
+ if (!src.includes(`"${key}"`) && !src.includes(`.${key}`)) {
35
+ missing.push(key);
36
+ }
37
+ }
38
+
39
+ assert.deepEqual(
40
+ missing,
41
+ [],
42
+ `These preference keys are in KNOWN_PREFERENCE_KEYS but are not referenced anywhere in the /gsd prefs wizard — they cannot be configured through the UI. Either add wizard coverage or add them to EXPOSED_OUTSIDE_WIZARD with an explanatory comment:\n${missing.join("\n")}`,
43
+ );
44
+ });
@@ -404,6 +404,8 @@ test("resumeAutoAfterProviderDelay restarts paused auto-mode from the recorded b
404
404
  stepMode: true,
405
405
  basePath: "/tmp/project",
406
406
  }),
407
+ resetTransientRetryState: () => {},
408
+ resetSessionTimeoutState: () => {},
407
409
  startAuto: async (_ctx, _pi, base, verboseMode, options) => {
408
410
  startCalls.push({ base, verboseMode, step: options?.step });
409
411
  },
@@ -428,6 +430,8 @@ test("resumeAutoAfterProviderDelay does not double-start when auto-mode is alrea
428
430
  stepMode: false,
429
431
  basePath: "/tmp/project",
430
432
  }),
433
+ resetTransientRetryState: () => {},
434
+ resetSessionTimeoutState: () => {},
431
435
  startAuto: async () => {
432
436
  startCalls += 1;
433
437
  },
@@ -458,6 +462,8 @@ test("resumeAutoAfterProviderDelay leaves auto paused when no base path is avail
458
462
  stepMode: false,
459
463
  basePath: "",
460
464
  }),
465
+ resetTransientRetryState: () => {},
466
+ resetSessionTimeoutState: () => {},
461
467
  startAuto: async () => {
462
468
  startCalls += 1;
463
469
  },
@@ -474,6 +480,39 @@ test("resumeAutoAfterProviderDelay leaves auto paused when no base path is avail
474
480
  ]);
475
481
  });
476
482
 
483
+ test("resumeAutoAfterProviderDelay resets provider retry state before restarting auto-mode", async () => {
484
+ const calls: string[] = [];
485
+
486
+ const result = await resumeAutoAfterProviderDelay(
487
+ {} as any,
488
+ { ui: { notify() {} } } as any,
489
+ {
490
+ getSnapshot: () => ({
491
+ active: false,
492
+ paused: true,
493
+ stepMode: false,
494
+ basePath: "/tmp/project",
495
+ }),
496
+ resetTransientRetryState: () => {
497
+ calls.push("reset-transient");
498
+ },
499
+ resetSessionTimeoutState: () => {
500
+ calls.push("reset-session-timeout");
501
+ },
502
+ startAuto: async () => {
503
+ calls.push("start-auto");
504
+ },
505
+ },
506
+ );
507
+
508
+ assert.equal(result, "resumed");
509
+ assert.deepEqual(calls, [
510
+ "reset-transient",
511
+ "reset-session-timeout",
512
+ "start-auto",
513
+ ]);
514
+ });
515
+
477
516
  // ── Escalating backoff for transient errors (#1166) ─────────────────────────
478
517
 
479
518
  test("agent-end-recovery.ts tracks consecutive transient errors for escalating backoff", () => {
@@ -567,31 +606,6 @@ test("resetTransientRetryState is exported from agent-end-recovery.ts", () => {
567
606
  );
568
607
  });
569
608
 
570
- test("provider-error-resume.ts calls resetTransientRetryState before startAuto", () => {
571
- const src = readFileSync(join(__dirname, "..", "bootstrap", "provider-error-resume.ts"), "utf-8");
572
- assert.ok(
573
- src.includes("resetTransientRetryState"),
574
- "provider-error-resume.ts must import and call resetTransientRetryState",
575
- );
576
- // Ensure reset is called BEFORE startAuto — order matters
577
- const resetIdx = src.indexOf("resetTransientRetryState()");
578
- const startIdx = src.indexOf("await deps.startAuto(");
579
- assert.ok(
580
- resetIdx !== -1 && startIdx !== -1 && resetIdx < startIdx,
581
- "resetTransientRetryState() must be called before deps.startAuto()",
582
- );
583
- // Session timeout counter must also be reset before startAuto
584
- assert.ok(
585
- src.includes("resetSessionTimeoutState"),
586
- "provider-error-resume.ts must import and call resetSessionTimeoutState",
587
- );
588
- const sessionResetIdx = src.indexOf("resetSessionTimeoutState()");
589
- assert.ok(
590
- sessionResetIdx !== -1 && startIdx !== -1 && sessionResetIdx < startIdx,
591
- "resetSessionTimeoutState() must be called before deps.startAuto()",
592
- );
593
- });
594
-
595
609
  // ── Fix 2: Session creation timeout treated as transient in phases.ts ───────
596
610
 
597
611
  test("phases.ts handles timeout session-creation failures with pause instead of stopAuto", () => {
@@ -0,0 +1,181 @@
1
+ /**
2
+ * Tests that /gsd queue is blocked when auto-mode is active.
3
+ *
4
+ * Relates to #4704: /gsd queue writes .gsd/PROJECT.md + QUEUE-ORDER.json
5
+ * directly into the project-root worktree, racing with auto-mode's
6
+ * pre-merge dirty-tree check and causing __dirty_working_tree__ failures.
7
+ *
8
+ * The fix adds an isAutoActive() guard in handleWorkflowCommand before
9
+ * delegating to showQueue, mirroring the existing /gsd quick guard (#2417).
10
+ */
11
+
12
+ import { describe, it } from "node:test";
13
+ import assert from "node:assert/strict";
14
+ import { readFileSync } from "node:fs";
15
+ import { join } from "node:path";
16
+
17
+ // ─── Structural test: verify the guard exists in source ──────────────────────
18
+
19
+ describe("/gsd queue auto-mode guard (#4704)", () => {
20
+ it("handleWorkflowCommand checks isAutoActive() before calling showQueue", () => {
21
+ const src = readFileSync(
22
+ join(
23
+ import.meta.dirname,
24
+ "..",
25
+ "commands",
26
+ "handlers",
27
+ "workflow.ts",
28
+ ),
29
+ "utf-8",
30
+ );
31
+
32
+ // Find the queue command block
33
+ const queueBlockMatch = src.match(
34
+ /if\s*\(\s*trimmed\s*===\s*"queue"\s*\)\s*\{([\s\S]*?)\n \}/,
35
+ );
36
+ assert.ok(queueBlockMatch, "queue command block exists in handleWorkflowCommand");
37
+
38
+ const queueBlock = queueBlockMatch[1];
39
+
40
+ // Verify auto-mode guard comes BEFORE showQueue call. Accepts either the
41
+ // inline isAutoActive() check (Tier 1) or the shared requireNotAutoActive()
42
+ // helper (Tier 2 / #4712).
43
+ const guardIndex = Math.max(
44
+ queueBlock.indexOf("isAutoActive()"),
45
+ queueBlock.indexOf("requireNotAutoActive("),
46
+ );
47
+ const showQueueIndex = queueBlock.indexOf("showQueue(");
48
+
49
+ assert.ok(guardIndex !== -1, "auto-mode guard exists in queue command block");
50
+ assert.ok(showQueueIndex !== -1, "showQueue() call exists in queue command block");
51
+ assert.ok(
52
+ guardIndex < showQueueIndex,
53
+ "auto-mode guard appears before showQueue() call",
54
+ );
55
+ });
56
+
57
+ it("guard shows error message mentioning /gsd stop", () => {
58
+ const src = readFileSync(
59
+ join(
60
+ import.meta.dirname,
61
+ "..",
62
+ "commands",
63
+ "handlers",
64
+ "workflow.ts",
65
+ ),
66
+ "utf-8",
67
+ );
68
+
69
+ assert.ok(
70
+ src.includes("cannot run while auto-mode is active"),
71
+ "error message explains that the command cannot run during auto-mode",
72
+ );
73
+ assert.ok(
74
+ src.includes("/gsd stop"),
75
+ "error message mentions /gsd stop as the resolution",
76
+ );
77
+ });
78
+
79
+ it("guard returns true (handled) to prevent falling through", () => {
80
+ const src = readFileSync(
81
+ join(
82
+ import.meta.dirname,
83
+ "..",
84
+ "commands",
85
+ "handlers",
86
+ "workflow.ts",
87
+ ),
88
+ "utf-8",
89
+ );
90
+
91
+ const queueBlockMatch = src.match(
92
+ /if\s*\(\s*trimmed\s*===\s*"queue"\s*\)\s*\{([\s\S]*?)\n \}/,
93
+ );
94
+ assert.ok(queueBlockMatch);
95
+ const queueBlock = queueBlockMatch[1];
96
+
97
+ // The guard block should have its own return true before showQueue
98
+ const guardBlock = queueBlock.slice(0, queueBlock.indexOf("showQueue("));
99
+ assert.ok(
100
+ guardBlock.includes("return true"),
101
+ "guard block returns true before showQueue is reached",
102
+ );
103
+ });
104
+ });
105
+
106
+ // ─── .gsd/audit/ runtime classification regression ──────────────────────────
107
+
108
+ describe(".gsd/audit/ runtime classification (#4704)", () => {
109
+ it("GSD_RUNTIME_PATTERNS in gitignore.ts includes .gsd/audit/", () => {
110
+ const src = readFileSync(
111
+ join(import.meta.dirname, "..", "gitignore.ts"),
112
+ "utf-8",
113
+ );
114
+ assert.ok(
115
+ src.includes('".gsd/audit/"'),
116
+ ".gsd/audit/ listed in GSD_RUNTIME_PATTERNS",
117
+ );
118
+ });
119
+
120
+ it("RUNTIME_EXCLUSION_PATHS in git-service.ts includes .gsd/audit/", () => {
121
+ const src = readFileSync(
122
+ join(import.meta.dirname, "..", "git-service.ts"),
123
+ "utf-8",
124
+ );
125
+ assert.ok(
126
+ src.includes('".gsd/audit/"'),
127
+ ".gsd/audit/ listed in RUNTIME_EXCLUSION_PATHS",
128
+ );
129
+ });
130
+
131
+ it("SKIP_PATHS in worktree-manager.ts includes .gsd/audit/", () => {
132
+ const src = readFileSync(
133
+ join(import.meta.dirname, "..", "worktree-manager.ts"),
134
+ "utf-8",
135
+ );
136
+ assert.ok(
137
+ src.includes('".gsd/audit/"'),
138
+ ".gsd/audit/ listed in SKIP_PATHS",
139
+ );
140
+ });
141
+ });
142
+
143
+ // ─── Windows gsd.db close+reopen around pre-merge stash ─────────────────────
144
+
145
+ describe("Windows pre-merge DB release (#4704)", () => {
146
+ it("mergeMilestoneToMain closes gsd.db on win32 before git stash", () => {
147
+ const src = readFileSync(
148
+ join(import.meta.dirname, "..", "auto-worktree.ts"),
149
+ "utf-8",
150
+ );
151
+
152
+ // Locate the stash push line and ensure a win32-gated closeDatabase()
153
+ // call precedes it in the same function scope.
154
+ const stashIndex = src.indexOf('"stash", "push", "--include-untracked"');
155
+ assert.ok(stashIndex !== -1, "pre-merge stash push exists");
156
+
157
+ const beforeStash = src.slice(0, stashIndex);
158
+ const win32Index = beforeStash.lastIndexOf('process.platform === "win32"');
159
+ const closeIndex = beforeStash.lastIndexOf("closeDatabase()");
160
+
161
+ assert.ok(win32Index !== -1, "win32 platform guard appears before stash");
162
+ assert.ok(closeIndex !== -1, "closeDatabase() invoked before stash");
163
+ assert.ok(
164
+ win32Index < closeIndex && closeIndex < stashIndex,
165
+ "platform guard wraps the closeDatabase() call before the stash",
166
+ );
167
+ });
168
+
169
+ it("openDatabase is called after the stash to reopen the connection", () => {
170
+ const src = readFileSync(
171
+ join(import.meta.dirname, "..", "auto-worktree.ts"),
172
+ "utf-8",
173
+ );
174
+ const stashIndex = src.indexOf('"stash", "push", "--include-untracked"');
175
+ const afterStash = src.slice(stashIndex);
176
+ assert.ok(
177
+ afterStash.includes("openDatabase("),
178
+ "openDatabase() called after the pre-merge stash",
179
+ );
180
+ });
181
+ });