gsd-pi 2.76.0-dev.fe143342a → 2.77.0-dev.1594b263e

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 (925) hide show
  1. package/README.md +18 -36
  2. package/dist/claude-cli-check.js +36 -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/headless.js +49 -4
  14. package/dist/loader.js +35 -7
  15. package/dist/onboarding.js +45 -0
  16. package/dist/provider-migrations.d.ts +18 -0
  17. package/dist/provider-migrations.js +14 -0
  18. package/dist/resource-loader.d.ts +40 -0
  19. package/dist/resource-loader.js +32 -13
  20. package/dist/resources/extensions/browser-tools/capture.js +9 -0
  21. package/dist/resources/extensions/browser-tools/tests/browser-tools-integration.test.mjs +8 -59
  22. package/dist/resources/extensions/browser-tools/tests/browser-tools-unit.test.cjs +36 -24
  23. package/dist/resources/extensions/browser-tools/tests/capture-sharp-optional.test.cjs +69 -71
  24. package/dist/resources/extensions/browser-tools/tools/forms.js +5 -1
  25. package/dist/resources/extensions/browser-tools/tools/intent.js +5 -1
  26. package/dist/resources/extensions/claude-code-cli/readiness.js +9 -4
  27. package/dist/resources/extensions/claude-code-cli/stream-adapter.js +559 -76
  28. package/dist/resources/extensions/cmux/index.js +20 -0
  29. package/dist/resources/extensions/github-sync/templates.js +103 -0
  30. package/dist/resources/extensions/google-search/extension-manifest.json +5 -4
  31. package/dist/resources/extensions/google-search/index.js +3 -375
  32. package/dist/resources/extensions/gsd/abandon-detect.js +44 -0
  33. package/dist/resources/extensions/gsd/auto/loop.js +133 -2
  34. package/dist/resources/extensions/gsd/auto/phases.js +110 -42
  35. package/dist/resources/extensions/gsd/auto/resolve.js +24 -0
  36. package/dist/resources/extensions/gsd/auto/run-unit.js +48 -4
  37. package/dist/resources/extensions/gsd/auto/session.js +24 -3
  38. package/dist/resources/extensions/gsd/auto/turn-epoch.js +95 -0
  39. package/dist/resources/extensions/gsd/auto-dispatch.js +216 -40
  40. package/dist/resources/extensions/gsd/auto-loop.js +1 -1
  41. package/dist/resources/extensions/gsd/auto-model-selection.js +125 -5
  42. package/dist/resources/extensions/gsd/auto-post-unit.js +240 -66
  43. package/dist/resources/extensions/gsd/auto-prompts.js +386 -104
  44. package/dist/resources/extensions/gsd/auto-recovery.js +124 -4
  45. package/dist/resources/extensions/gsd/auto-start.js +141 -66
  46. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +11 -5
  47. package/dist/resources/extensions/gsd/auto-tool-tracking.js +47 -7
  48. package/dist/resources/extensions/gsd/auto-unit-closeout.js +11 -2
  49. package/dist/resources/extensions/gsd/auto-worktree.js +230 -86
  50. package/dist/resources/extensions/gsd/auto.js +159 -48
  51. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +36 -2
  52. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +209 -0
  53. package/dist/resources/extensions/gsd/bootstrap/provider-error-resume.js +5 -6
  54. package/dist/resources/extensions/gsd/bootstrap/register-extension.js +11 -0
  55. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +24 -9
  56. package/dist/resources/extensions/gsd/bootstrap/system-context.js +11 -6
  57. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +161 -11
  58. package/dist/resources/extensions/gsd/clean-root-preflight.js +93 -0
  59. package/dist/resources/extensions/gsd/commands/handlers/workflow.js +31 -4
  60. package/dist/resources/extensions/gsd/commands-cmux.js +9 -6
  61. package/dist/resources/extensions/gsd/commands-extensions.js +634 -43
  62. package/dist/resources/extensions/gsd/commands-prefs-wizard.js +968 -23
  63. package/dist/resources/extensions/gsd/component-loader.js +447 -0
  64. package/dist/resources/extensions/gsd/component-types.js +69 -0
  65. package/dist/resources/extensions/gsd/context-store.js +23 -7
  66. package/dist/resources/extensions/gsd/detection.js +49 -1
  67. package/dist/resources/extensions/gsd/dispatch-guard.js +29 -3
  68. package/dist/resources/extensions/gsd/docs/preferences-reference.md +1 -1
  69. package/dist/resources/extensions/gsd/file-lock.js +49 -9
  70. package/dist/resources/extensions/gsd/forensics.js +106 -0
  71. package/dist/resources/extensions/gsd/gate-registry.js +2 -2
  72. package/dist/resources/extensions/gsd/git-constants.js +28 -1
  73. package/dist/resources/extensions/gsd/git-self-heal.js +27 -0
  74. package/dist/resources/extensions/gsd/git-service.js +127 -2
  75. package/dist/resources/extensions/gsd/gitignore.js +2 -0
  76. package/dist/resources/extensions/gsd/gsd-db.js +95 -32
  77. package/dist/resources/extensions/gsd/guided-flow-queue.js +4 -1
  78. package/dist/resources/extensions/gsd/guided-flow.js +214 -13
  79. package/dist/resources/extensions/gsd/health-widget.js +4 -1
  80. package/dist/resources/extensions/gsd/journal.js +17 -2
  81. package/dist/resources/extensions/gsd/key-manager.js +22 -0
  82. package/dist/resources/extensions/gsd/memory-extractor.js +7 -1
  83. package/dist/resources/extensions/gsd/milestone-actions.js +15 -0
  84. package/dist/resources/extensions/gsd/milestone-scope-classifier.js +299 -0
  85. package/dist/resources/extensions/gsd/milestone-summary-classifier.js +37 -0
  86. package/dist/resources/extensions/gsd/model-cost-table.js +3 -0
  87. package/dist/resources/extensions/gsd/model-router.js +42 -3
  88. package/dist/resources/extensions/gsd/native-git-bridge.js +34 -4
  89. package/dist/resources/extensions/gsd/notifications.js +30 -16
  90. package/dist/resources/extensions/gsd/pre-execution-checks.js +31 -6
  91. package/dist/resources/extensions/gsd/preferences-validation.js +23 -0
  92. package/dist/resources/extensions/gsd/prompt-cache-optimizer.js +4 -0
  93. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +5 -1
  94. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
  95. package/dist/resources/extensions/gsd/prompts/discuss.md +29 -2
  96. package/dist/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
  97. package/dist/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  98. package/dist/resources/extensions/gsd/prompts/plan-slice.md +15 -2
  99. package/dist/resources/extensions/gsd/prompts/system.md +1 -0
  100. package/dist/resources/extensions/gsd/reports.js +5 -4
  101. package/dist/resources/extensions/gsd/safety/evidence-collector.js +96 -0
  102. package/dist/resources/extensions/gsd/safety/file-change-validator.js +12 -4
  103. package/dist/resources/extensions/gsd/safety/git-checkpoint.js +11 -0
  104. package/dist/resources/extensions/gsd/safety/safety-harness.js +5 -1
  105. package/dist/resources/extensions/gsd/service-tier.js +5 -2
  106. package/dist/resources/extensions/gsd/session-lock.js +19 -10
  107. package/dist/resources/extensions/gsd/skill-manifest.js +168 -0
  108. package/dist/resources/extensions/gsd/slice-cadence.js +238 -0
  109. package/dist/resources/extensions/gsd/slice-parallel-orchestrator.js +278 -8
  110. package/dist/resources/extensions/gsd/state-transition-matrix.js +118 -0
  111. package/dist/resources/extensions/gsd/state.js +69 -58
  112. package/dist/resources/extensions/gsd/sync-lock.js +98 -42
  113. package/dist/resources/extensions/gsd/token-counter.js +22 -5
  114. package/dist/resources/extensions/gsd/tools/complete-milestone.js +16 -10
  115. package/dist/resources/extensions/gsd/tools/complete-slice.js +21 -0
  116. package/dist/resources/extensions/gsd/tools/complete-task.js +31 -0
  117. package/dist/resources/extensions/gsd/tools/validate-milestone.js +7 -2
  118. package/dist/resources/extensions/gsd/unit-context-composer.js +147 -0
  119. package/dist/resources/extensions/gsd/unit-context-manifest.js +370 -0
  120. package/dist/resources/extensions/gsd/uok/audit.js +18 -2
  121. package/dist/resources/extensions/gsd/uok/dispatch-envelope.js +33 -0
  122. package/dist/resources/extensions/gsd/uok/execution-graph.js +10 -0
  123. package/dist/resources/extensions/gsd/uok/gate-runner.js +53 -5
  124. package/dist/resources/extensions/gsd/uok/gitops.js +2 -1
  125. package/dist/resources/extensions/gsd/uok/loop-adapter.js +37 -10
  126. package/dist/resources/extensions/gsd/uok/parity-report.js +58 -0
  127. package/dist/resources/extensions/gsd/uok/plan-v2.js +30 -7
  128. package/dist/resources/extensions/gsd/uok/writer.js +82 -0
  129. package/dist/resources/extensions/gsd/workflow-logger.js +10 -2
  130. package/dist/resources/extensions/gsd/workflow-mcp.js +6 -0
  131. package/dist/resources/extensions/gsd/worktree-manager.js +86 -8
  132. package/dist/resources/extensions/gsd/worktree-resolver.js +136 -17
  133. package/dist/resources/extensions/gsd/worktree-telemetry.js +198 -0
  134. package/dist/resources/extensions/mcp-client/auth.js +10 -1
  135. package/dist/resources/extensions/mcp-client/index.js +121 -10
  136. package/dist/resources/extensions/ollama/index.js +5 -1
  137. package/dist/resources/extensions/remote-questions/manager.js +11 -5
  138. package/dist/resources/extensions/shared/cmux-events.js +12 -0
  139. package/dist/resources/extensions/shared/rtk-session-stats.js +1 -2
  140. package/dist/resources/skills/create-skill/SKILL.md +2 -2
  141. package/dist/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
  142. package/dist/resources/skills/create-skill/workflows/audit-skill.md +4 -4
  143. package/dist/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
  144. package/dist/resources/skills/verify-before-complete/SKILL.md +2 -1
  145. package/dist/resources/skills/write-docs/SKILL.md +2 -1
  146. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  147. package/dist/web/standalone/.next/BUILD_ID +1 -1
  148. package/dist/web/standalone/.next/app-path-routes-manifest.json +10 -10
  149. package/dist/web/standalone/.next/build-manifest.json +3 -3
  150. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  151. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  152. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  153. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  154. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  155. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  156. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  157. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  158. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  159. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  160. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  161. package/dist/web/standalone/.next/server/app/_not-found.rsc +1 -1
  162. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  163. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  164. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  165. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  166. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  167. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  168. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  169. package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
  170. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  171. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
  172. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  173. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
  174. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +1 -1
  175. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
  176. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  177. package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
  178. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  179. package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
  180. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  181. package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
  182. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  183. package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
  184. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  185. package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
  186. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  187. package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
  188. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  189. package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
  190. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  191. package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
  192. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  193. package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
  194. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  195. package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
  196. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  197. package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
  198. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  199. package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
  200. package/dist/web/standalone/.next/server/app/api/notifications/route.js +1 -1
  201. package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
  202. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  203. package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
  204. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  205. package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
  206. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  207. package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
  208. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  209. package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
  210. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  211. package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
  212. package/dist/web/standalone/.next/server/app/api/session/events/route.js +1 -1
  213. package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
  214. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  215. package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
  216. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  217. package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
  218. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  219. package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
  220. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  221. package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
  222. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  223. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
  224. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +1 -1
  225. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
  226. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +1 -1
  227. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
  228. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  229. package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
  230. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  231. package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
  232. package/dist/web/standalone/.next/server/app/index.html +1 -1
  233. package/dist/web/standalone/.next/server/app/index.rsc +1 -1
  234. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  235. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +1 -1
  236. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  237. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +1 -1
  238. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  239. package/dist/web/standalone/.next/server/app-paths-manifest.json +10 -10
  240. package/dist/web/standalone/.next/server/chunks/1926.js +1 -0
  241. package/dist/web/standalone/.next/server/chunks/6897.js +2 -2
  242. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  243. package/dist/web/standalone/.next/server/middleware-manifest.json +5 -5
  244. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  245. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  246. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  247. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  248. package/dist/web/standalone/.next/static/chunks/2826.e9f5195e91f9cad2.js +11 -0
  249. package/dist/web/standalone/.next/static/chunks/{webpack-5fc74f13a25fa1bb.js → webpack-2e68521d7c82f7c2.js} +1 -1
  250. package/dist/welcome-screen.js +6 -1
  251. package/dist/wizard.js +2 -0
  252. package/package.json +17 -16
  253. package/packages/daemon/package.json +2 -2
  254. package/packages/daemon/src/logger.ts +4 -3
  255. package/packages/mcp-server/README.md +3 -3
  256. package/packages/mcp-server/dist/env-writer.d.ts +1 -0
  257. package/packages/mcp-server/dist/env-writer.d.ts.map +1 -1
  258. package/packages/mcp-server/dist/env-writer.js +74 -6
  259. package/packages/mcp-server/dist/env-writer.js.map +1 -1
  260. package/packages/mcp-server/dist/remote-questions.d.ts +45 -0
  261. package/packages/mcp-server/dist/remote-questions.d.ts.map +1 -0
  262. package/packages/mcp-server/dist/remote-questions.js +732 -0
  263. package/packages/mcp-server/dist/remote-questions.js.map +1 -0
  264. package/packages/mcp-server/dist/server.d.ts +31 -0
  265. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  266. package/packages/mcp-server/dist/server.js +179 -93
  267. package/packages/mcp-server/dist/server.js.map +1 -1
  268. package/packages/mcp-server/dist/session-manager.d.ts +14 -0
  269. package/packages/mcp-server/dist/session-manager.d.ts.map +1 -1
  270. package/packages/mcp-server/dist/session-manager.js +49 -1
  271. package/packages/mcp-server/dist/session-manager.js.map +1 -1
  272. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  273. package/packages/mcp-server/dist/workflow-tools.js +15 -6
  274. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  275. package/packages/mcp-server/package.json +9 -3
  276. package/packages/mcp-server/src/env-writer.test.ts +79 -1
  277. package/packages/mcp-server/src/env-writer.ts +76 -6
  278. package/packages/mcp-server/src/mcp-server.test.ts +89 -0
  279. package/packages/mcp-server/src/readers/graph.test.ts +87 -15
  280. package/packages/mcp-server/src/readers/readers.test.ts +5 -1
  281. package/packages/mcp-server/src/remote-questions.test.ts +294 -0
  282. package/packages/mcp-server/src/remote-questions.ts +916 -0
  283. package/packages/mcp-server/src/secure-env-collect.test.ts +232 -237
  284. package/packages/mcp-server/src/server.ts +236 -108
  285. package/packages/mcp-server/src/session-manager.ts +43 -1
  286. package/packages/mcp-server/src/workflow-tools.test.ts +85 -0
  287. package/packages/mcp-server/src/workflow-tools.ts +19 -6
  288. package/packages/mcp-server/tsconfig.test.json +19 -0
  289. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  290. package/packages/native/package.json +7 -2
  291. package/packages/native/src/__tests__/_test-coverage-guard.test.mjs +98 -0
  292. package/packages/native/src/__tests__/clipboard.test.mjs +69 -23
  293. package/packages/native/src/__tests__/module-compat.test.mjs +59 -27
  294. package/packages/native/src/__tests__/ps.test.mjs +14 -8
  295. package/packages/native/src/__tests__/stream-process.test.mjs +23 -2
  296. package/packages/native/src/__tests__/truncate.test.mjs +17 -2
  297. package/packages/native/tsconfig.tsbuildinfo +1 -1
  298. package/packages/pi-agent-core/package.json +6 -1
  299. package/packages/pi-agent-core/src/agent-loop.test.ts +226 -31
  300. package/packages/pi-agent-core/src/agent.test.ts +96 -102
  301. package/packages/pi-agent-core/tsconfig.tsbuildinfo +1 -1
  302. package/packages/pi-ai/dist/models/capability-patches.d.ts.map +1 -1
  303. package/packages/pi-ai/dist/models/capability-patches.js +9 -2
  304. package/packages/pi-ai/dist/models/capability-patches.js.map +1 -1
  305. package/packages/pi-ai/dist/models/custom.d.ts +38 -0
  306. package/packages/pi-ai/dist/models/custom.d.ts.map +1 -1
  307. package/packages/pi-ai/dist/models/custom.js +41 -0
  308. package/packages/pi-ai/dist/models/custom.js.map +1 -1
  309. package/packages/pi-ai/dist/models/generated/index.d.ts +34 -0
  310. package/packages/pi-ai/dist/models/generated/index.d.ts.map +1 -1
  311. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts +17 -0
  312. package/packages/pi-ai/dist/models/generated/openai-codex.d.ts.map +1 -1
  313. package/packages/pi-ai/dist/models/generated/openai-codex.js +17 -0
  314. package/packages/pi-ai/dist/models/generated/openai-codex.js.map +1 -1
  315. package/packages/pi-ai/dist/models/generated/openai.d.ts +17 -0
  316. package/packages/pi-ai/dist/models/generated/openai.d.ts.map +1 -1
  317. package/packages/pi-ai/dist/models/generated/openai.js +17 -0
  318. package/packages/pi-ai/dist/models/generated/openai.js.map +1 -1
  319. package/packages/pi-ai/dist/models.generated.test.js +43 -70
  320. package/packages/pi-ai/dist/models.generated.test.js.map +1 -1
  321. package/packages/pi-ai/dist/models.test.js +36 -11
  322. package/packages/pi-ai/dist/models.test.js.map +1 -1
  323. package/packages/pi-ai/dist/providers/anthropic-auth.test.js +1 -1
  324. package/packages/pi-ai/dist/providers/anthropic-auth.test.js.map +1 -1
  325. package/packages/pi-ai/dist/providers/anthropic-shared.d.ts.map +1 -1
  326. package/packages/pi-ai/dist/providers/anthropic-shared.js +27 -4
  327. package/packages/pi-ai/dist/providers/anthropic-shared.js.map +1 -1
  328. package/packages/pi-ai/dist/providers/anthropic.d.ts.map +1 -1
  329. package/packages/pi-ai/dist/providers/anthropic.js +8 -3
  330. package/packages/pi-ai/dist/providers/anthropic.js.map +1 -1
  331. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts +2 -0
  332. package/packages/pi-ai/dist/providers/minimax-tool-name.test.d.ts.map +1 -0
  333. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js +80 -0
  334. package/packages/pi-ai/dist/providers/minimax-tool-name.test.js.map +1 -0
  335. package/packages/pi-ai/dist/providers/simple-options.d.ts +10 -0
  336. package/packages/pi-ai/dist/providers/simple-options.d.ts.map +1 -1
  337. package/packages/pi-ai/dist/providers/simple-options.js +16 -1
  338. package/packages/pi-ai/dist/providers/simple-options.js.map +1 -1
  339. package/packages/pi-ai/package.json +6 -1
  340. package/packages/pi-ai/scripts/generate-models.ts +44 -0
  341. package/packages/pi-ai/src/models/capability-patches.ts +10 -2
  342. package/packages/pi-ai/src/models/custom.ts +42 -0
  343. package/packages/pi-ai/src/models/generated/openai-codex.ts +17 -0
  344. package/packages/pi-ai/src/models/generated/openai.ts +17 -0
  345. package/packages/pi-ai/src/models.generated.test.ts +46 -73
  346. package/packages/pi-ai/src/models.test.ts +48 -11
  347. package/packages/pi-ai/src/providers/anthropic-auth.test.ts +1 -1
  348. package/packages/pi-ai/src/providers/anthropic-shared.ts +26 -5
  349. package/packages/pi-ai/src/providers/anthropic.ts +9 -3
  350. package/packages/pi-ai/src/providers/minimax-tool-name.test.ts +98 -0
  351. package/packages/pi-ai/src/providers/simple-options.ts +17 -1
  352. package/packages/pi-ai/tsconfig.tsbuildinfo +1 -1
  353. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js +96 -31
  354. package/packages/pi-coding-agent/dist/core/agent-session-abort-order.test.js.map +1 -1
  355. package/packages/pi-coding-agent/dist/core/agent-session-model-switch.test.js +75 -12
  356. package/packages/pi-coding-agent/dist/core/agent-session-model-switch.test.js.map +1 -1
  357. package/packages/pi-coding-agent/dist/core/agent-session-tool-refresh.test.js +99 -31
  358. package/packages/pi-coding-agent/dist/core/agent-session-tool-refresh.test.js.map +1 -1
  359. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +2 -0
  360. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  361. package/packages/pi-coding-agent/dist/core/agent-session.js +7 -0
  362. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  363. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +25 -0
  364. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
  365. package/packages/pi-coding-agent/dist/core/compaction/compaction.js +105 -6
  366. package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
  367. package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js +230 -28
  368. package/packages/pi-coding-agent/dist/core/compaction/compaction.test.js.map +1 -1
  369. package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts +30 -2
  370. package/packages/pi-coding-agent/dist/core/compaction/utils.d.ts.map +1 -1
  371. package/packages/pi-coding-agent/dist/core/compaction/utils.js +113 -12
  372. package/packages/pi-coding-agent/dist/core/compaction/utils.js.map +1 -1
  373. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts +1 -0
  374. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.d.ts.map +1 -1
  375. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js +29 -18
  376. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js.map +1 -1
  377. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts +2 -0
  378. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.d.ts.map +1 -0
  379. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js +130 -0
  380. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.test.js.map +1 -0
  381. package/packages/pi-coding-agent/dist/core/compaction-utils.test.js +56 -1
  382. package/packages/pi-coding-agent/dist/core/compaction-utils.test.js.map +1 -1
  383. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js +8 -15
  384. package/packages/pi-coding-agent/dist/core/discovery-cache.test.js.map +1 -1
  385. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts +25 -0
  386. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.d.ts.map +1 -0
  387. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js +109 -0
  388. package/packages/pi-coding-agent/dist/core/extensions/extension-discovery.js.map +1 -0
  389. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts +67 -0
  390. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.d.ts.map +1 -0
  391. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js +167 -0
  392. package/packages/pi-coding-agent/dist/core/extensions/extension-registry.js.map +1 -0
  393. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +8 -2
  394. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  395. package/packages/pi-coding-agent/dist/core/extensions/loader.js +85 -8
  396. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  397. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts +2 -0
  398. package/packages/pi-coding-agent/dist/core/extensions/runner.d.ts.map +1 -1
  399. package/packages/pi-coding-agent/dist/core/extensions/runner.js.map +1 -1
  400. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +14 -0
  401. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  402. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  403. package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js +41 -4
  404. package/packages/pi-coding-agent/dist/core/lsp/lsp-integration.test.js.map +1 -1
  405. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +19 -2
  406. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -1
  407. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts +2 -0
  408. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.d.ts.map +1 -0
  409. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js +203 -0
  410. package/packages/pi-coding-agent/dist/core/model-registry-custom-caps.test.js.map +1 -0
  411. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  412. package/packages/pi-coding-agent/dist/core/model-registry.js +14 -0
  413. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  414. package/packages/pi-coding-agent/dist/core/resource-loader-cache-reset.test.js +76 -18
  415. package/packages/pi-coding-agent/dist/core/resource-loader-cache-reset.test.js.map +1 -1
  416. package/packages/pi-coding-agent/dist/core/resource-loader.js +1 -1
  417. package/packages/pi-coding-agent/dist/core/resource-loader.js.map +1 -1
  418. package/packages/pi-coding-agent/dist/core/retry-handler.d.ts.map +1 -1
  419. package/packages/pi-coding-agent/dist/core/retry-handler.js +2 -6
  420. package/packages/pi-coding-agent/dist/core/retry-handler.js.map +1 -1
  421. package/packages/pi-coding-agent/dist/core/retry-handler.test.js +5 -1
  422. package/packages/pi-coding-agent/dist/core/retry-handler.test.js.map +1 -1
  423. package/packages/pi-coding-agent/dist/core/retryable-error-regex.d.ts +18 -0
  424. package/packages/pi-coding-agent/dist/core/retryable-error-regex.d.ts.map +1 -0
  425. package/packages/pi-coding-agent/dist/core/retryable-error-regex.js +18 -0
  426. package/packages/pi-coding-agent/dist/core/retryable-error-regex.js.map +1 -0
  427. package/packages/pi-coding-agent/dist/core/sdk.d.ts +1 -0
  428. package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  429. package/packages/pi-coding-agent/dist/core/sdk.js +4 -1
  430. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  431. package/packages/pi-coding-agent/dist/core/sdk.test.js +19 -1
  432. package/packages/pi-coding-agent/dist/core/sdk.test.js.map +1 -1
  433. package/packages/pi-coding-agent/dist/core/session-manager.js +1 -1
  434. package/packages/pi-coding-agent/dist/core/session-manager.js.map +1 -1
  435. package/packages/pi-coding-agent/dist/core/session-manager.test.js +21 -1
  436. package/packages/pi-coding-agent/dist/core/session-manager.test.js.map +1 -1
  437. package/packages/pi-coding-agent/dist/core/system-prompt.d.ts +20 -0
  438. package/packages/pi-coding-agent/dist/core/system-prompt.d.ts.map +1 -1
  439. package/packages/pi-coding-agent/dist/core/system-prompt.js +19 -5
  440. package/packages/pi-coding-agent/dist/core/system-prompt.js.map +1 -1
  441. package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js +2 -1
  442. package/packages/pi-coding-agent/dist/core/tools/path-utils.test.js.map +1 -1
  443. package/packages/pi-coding-agent/dist/index.d.ts +1 -0
  444. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  445. package/packages/pi-coding-agent/dist/index.js +1 -0
  446. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  447. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js +15 -6
  448. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/provider-display-name.test.js.map +1 -1
  449. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +36 -5
  450. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
  451. package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.test.js +20 -13
  452. package/packages/pi-coding-agent/dist/modes/interactive/components/dynamic-border.test.js.map +1 -1
  453. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  454. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +14 -5
  455. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  456. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts +7 -1
  457. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.d.ts.map +1 -1
  458. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js +31 -9
  459. package/packages/pi-coding-agent/dist/modes/interactive/components/model-selector.js.map +1 -1
  460. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  461. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +30 -12
  462. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  463. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.d.ts.map +1 -1
  464. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.js +18 -3
  465. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.js.map +1 -1
  466. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js +139 -0
  467. package/packages/pi-coding-agent/dist/modes/interactive/controllers/input-controller.test.js.map +1 -1
  468. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.d.ts +2 -0
  469. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.d.ts.map +1 -1
  470. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode-state.js.map +1 -1
  471. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +4 -0
  472. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  473. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +118 -14
  474. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  475. package/packages/pi-coding-agent/dist/tests/system-prompt-skill-filter.test.d.ts +2 -0
  476. package/packages/pi-coding-agent/dist/tests/system-prompt-skill-filter.test.d.ts.map +1 -0
  477. package/packages/pi-coding-agent/dist/tests/system-prompt-skill-filter.test.js +130 -0
  478. package/packages/pi-coding-agent/dist/tests/system-prompt-skill-filter.test.js.map +1 -0
  479. package/packages/pi-coding-agent/package.json +6 -1
  480. package/packages/pi-coding-agent/src/core/agent-session-abort-order.test.ts +113 -36
  481. package/packages/pi-coding-agent/src/core/agent-session-model-switch.test.ts +89 -17
  482. package/packages/pi-coding-agent/src/core/agent-session-tool-refresh.test.ts +112 -43
  483. package/packages/pi-coding-agent/src/core/agent-session.ts +11 -0
  484. package/packages/pi-coding-agent/src/core/compaction/compaction.test.ts +368 -28
  485. package/packages/pi-coding-agent/src/core/compaction/compaction.ts +122 -6
  486. package/packages/pi-coding-agent/src/core/compaction/utils.ts +111 -13
  487. package/packages/pi-coding-agent/src/core/compaction-orchestrator.test.ts +154 -0
  488. package/packages/pi-coding-agent/src/core/compaction-orchestrator.ts +32 -18
  489. package/packages/pi-coding-agent/src/core/compaction-utils.test.ts +68 -1
  490. package/packages/pi-coding-agent/src/core/discovery-cache.test.ts +9 -18
  491. package/packages/pi-coding-agent/src/core/extensions/extension-discovery.ts +119 -0
  492. package/packages/pi-coding-agent/src/core/extensions/extension-registry.ts +222 -0
  493. package/packages/pi-coding-agent/src/core/extensions/loader.ts +82 -11
  494. package/packages/pi-coding-agent/src/core/extensions/runner.ts +2 -0
  495. package/packages/pi-coding-agent/src/core/extensions/types.ts +15 -0
  496. package/packages/pi-coding-agent/src/core/lsp/lsp-integration.test.ts +48 -4
  497. package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +22 -2
  498. package/packages/pi-coding-agent/src/core/model-registry-custom-caps.test.ts +245 -0
  499. package/packages/pi-coding-agent/src/core/model-registry.ts +16 -0
  500. package/packages/pi-coding-agent/src/core/resource-loader-cache-reset.test.ts +93 -28
  501. package/packages/pi-coding-agent/src/core/resource-loader.ts +1 -1
  502. package/packages/pi-coding-agent/src/core/retry-handler.test.ts +5 -1
  503. package/packages/pi-coding-agent/src/core/retry-handler.ts +2 -8
  504. package/packages/pi-coding-agent/src/core/retryable-error-regex.ts +18 -0
  505. package/packages/pi-coding-agent/src/core/sdk.test.ts +25 -1
  506. package/packages/pi-coding-agent/src/core/sdk.ts +10 -3
  507. package/packages/pi-coding-agent/src/core/session-manager.test.ts +30 -1
  508. package/packages/pi-coding-agent/src/core/session-manager.ts +1 -1
  509. package/packages/pi-coding-agent/src/core/system-prompt.ts +38 -4
  510. package/packages/pi-coding-agent/src/core/tools/path-utils.test.ts +2 -1
  511. package/packages/pi-coding-agent/src/index.ts +1 -0
  512. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/provider-display-name.test.ts +17 -7
  513. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +49 -3
  514. package/packages/pi-coding-agent/src/modes/interactive/components/dynamic-border.test.ts +26 -20
  515. package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +14 -5
  516. package/packages/pi-coding-agent/src/modes/interactive/components/model-selector.ts +45 -11
  517. package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +48 -9
  518. package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.test.ts +160 -1
  519. package/packages/pi-coding-agent/src/modes/interactive/controllers/input-controller.ts +20 -3
  520. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode-state.ts +2 -0
  521. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +132 -14
  522. package/packages/pi-coding-agent/src/tests/system-prompt-skill-filter.test.ts +157 -0
  523. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  524. package/packages/pi-tui/dist/__tests__/autocomplete.test.js +31 -14
  525. package/packages/pi-tui/dist/__tests__/autocomplete.test.js.map +1 -1
  526. package/packages/pi-tui/dist/__tests__/overlay-layout.test.js +128 -17
  527. package/packages/pi-tui/dist/__tests__/overlay-layout.test.js.map +1 -1
  528. package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js +51 -6
  529. package/packages/pi-tui/dist/__tests__/stdin-buffer.test.js.map +1 -1
  530. package/packages/pi-tui/dist/__tests__/tui.test.js +18 -30
  531. package/packages/pi-tui/dist/__tests__/tui.test.js.map +1 -1
  532. package/packages/pi-tui/dist/components/__tests__/input.test.js +10 -3
  533. package/packages/pi-tui/dist/components/__tests__/input.test.js.map +1 -1
  534. package/packages/pi-tui/dist/components/__tests__/loader.test.js +53 -9
  535. package/packages/pi-tui/dist/components/__tests__/loader.test.js.map +1 -1
  536. package/packages/pi-tui/dist/components/__tests__/markdown-maxlines.test.js +6 -2
  537. package/packages/pi-tui/dist/components/__tests__/markdown-maxlines.test.js.map +1 -1
  538. package/packages/pi-tui/dist/components/editor.d.ts +14 -0
  539. package/packages/pi-tui/dist/components/editor.d.ts.map +1 -1
  540. package/packages/pi-tui/dist/components/editor.js +19 -0
  541. package/packages/pi-tui/dist/components/editor.js.map +1 -1
  542. package/packages/pi-tui/dist/components/image.test.js +6 -5
  543. package/packages/pi-tui/dist/components/image.test.js.map +1 -1
  544. package/packages/pi-tui/dist/editor-component.d.ts +2 -0
  545. package/packages/pi-tui/dist/editor-component.d.ts.map +1 -1
  546. package/packages/pi-tui/dist/editor-component.js.map +1 -1
  547. package/packages/pi-tui/dist/stdin-buffer.d.ts +7 -0
  548. package/packages/pi-tui/dist/stdin-buffer.d.ts.map +1 -1
  549. package/packages/pi-tui/dist/stdin-buffer.js +20 -0
  550. package/packages/pi-tui/dist/stdin-buffer.js.map +1 -1
  551. package/packages/pi-tui/package.json +6 -1
  552. package/packages/pi-tui/src/__tests__/autocomplete.test.ts +46 -15
  553. package/packages/pi-tui/src/__tests__/overlay-layout.test.ts +140 -17
  554. package/packages/pi-tui/src/__tests__/stdin-buffer.test.ts +62 -6
  555. package/packages/pi-tui/src/__tests__/tui.test.ts +18 -37
  556. package/packages/pi-tui/src/components/__tests__/input.test.ts +19 -3
  557. package/packages/pi-tui/src/components/__tests__/loader.test.ts +112 -35
  558. package/packages/pi-tui/src/components/__tests__/markdown-maxlines.test.ts +9 -2
  559. package/packages/pi-tui/src/components/editor.ts +22 -0
  560. package/packages/pi-tui/src/components/image.test.ts +10 -5
  561. package/packages/pi-tui/src/editor-component.ts +3 -0
  562. package/packages/pi-tui/src/stdin-buffer.ts +26 -0
  563. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
  564. package/packages/rpc-client/dist/rpc-client.test.js +101 -51
  565. package/packages/rpc-client/dist/rpc-client.test.js.map +1 -1
  566. package/packages/rpc-client/package.json +6 -1
  567. package/packages/rpc-client/src/rpc-client.test.ts +109 -52
  568. package/packages/rpc-client/tsconfig.tsbuildinfo +1 -1
  569. package/pkg/package.json +1 -1
  570. package/scripts/install.js +526 -0
  571. package/scripts/lib/workspace-manifest.cjs +86 -0
  572. package/scripts/link-workspace-packages.cjs +5 -17
  573. package/scripts/postinstall.js +9 -178
  574. package/src/resources/extensions/browser-tools/capture.ts +12 -0
  575. package/src/resources/extensions/browser-tools/tests/browser-tools-integration.test.mjs +8 -59
  576. package/src/resources/extensions/browser-tools/tests/browser-tools-unit.test.cjs +36 -24
  577. package/src/resources/extensions/browser-tools/tests/capture-sharp-optional.test.cjs +69 -71
  578. package/src/resources/extensions/browser-tools/tools/forms.ts +5 -1
  579. package/src/resources/extensions/browser-tools/tools/intent.ts +5 -1
  580. package/src/resources/extensions/claude-code-cli/readiness.ts +9 -4
  581. package/src/resources/extensions/claude-code-cli/stream-adapter.ts +609 -82
  582. package/src/resources/extensions/claude-code-cli/tests/stream-adapter.test.ts +1033 -87
  583. package/src/resources/extensions/cmux/index.ts +35 -10
  584. package/src/resources/extensions/github-sync/templates.ts +151 -0
  585. package/src/resources/extensions/github-sync/tests/cli.test.ts +76 -7
  586. package/src/resources/extensions/github-sync/tests/templates.test.ts +92 -1
  587. package/src/resources/extensions/google-search/extension-manifest.json +5 -4
  588. package/src/resources/extensions/google-search/index.ts +9 -470
  589. package/src/resources/extensions/gsd/abandon-detect.ts +62 -0
  590. package/src/resources/extensions/gsd/auto/loop-deps.ts +14 -1
  591. package/src/resources/extensions/gsd/auto/loop.ts +151 -2
  592. package/src/resources/extensions/gsd/auto/phases.ts +139 -41
  593. package/src/resources/extensions/gsd/auto/resolve.ts +29 -0
  594. package/src/resources/extensions/gsd/auto/run-unit.ts +56 -4
  595. package/src/resources/extensions/gsd/auto/session.ts +35 -3
  596. package/src/resources/extensions/gsd/auto/turn-epoch.ts +108 -0
  597. package/src/resources/extensions/gsd/auto/types.ts +1 -1
  598. package/src/resources/extensions/gsd/auto-dispatch.ts +229 -39
  599. package/src/resources/extensions/gsd/auto-loop.ts +1 -1
  600. package/src/resources/extensions/gsd/auto-model-selection.ts +132 -5
  601. package/src/resources/extensions/gsd/auto-post-unit.ts +255 -76
  602. package/src/resources/extensions/gsd/auto-prompts.ts +413 -94
  603. package/src/resources/extensions/gsd/auto-recovery.ts +125 -2
  604. package/src/resources/extensions/gsd/auto-start.ts +166 -60
  605. package/src/resources/extensions/gsd/auto-timeout-recovery.ts +12 -5
  606. package/src/resources/extensions/gsd/auto-tool-tracking.ts +51 -7
  607. package/src/resources/extensions/gsd/auto-unit-closeout.ts +14 -3
  608. package/src/resources/extensions/gsd/auto-worktree.ts +251 -93
  609. package/src/resources/extensions/gsd/auto.ts +182 -54
  610. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +43 -2
  611. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +221 -0
  612. package/src/resources/extensions/gsd/bootstrap/provider-error-resume.ts +6 -6
  613. package/src/resources/extensions/gsd/bootstrap/register-extension.ts +11 -0
  614. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +25 -9
  615. package/src/resources/extensions/gsd/bootstrap/system-context.ts +13 -9
  616. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +193 -11
  617. package/src/resources/extensions/gsd/clean-root-preflight.ts +111 -0
  618. package/src/resources/extensions/gsd/commands/handlers/workflow.ts +27 -8
  619. package/src/resources/extensions/gsd/commands-cmux.ts +10 -6
  620. package/src/resources/extensions/gsd/commands-extensions.ts +747 -41
  621. package/src/resources/extensions/gsd/commands-prefs-wizard.ts +898 -32
  622. package/src/resources/extensions/gsd/component-loader.ts +598 -0
  623. package/src/resources/extensions/gsd/component-types.ts +362 -0
  624. package/src/resources/extensions/gsd/context-store.ts +25 -8
  625. package/src/resources/extensions/gsd/detection.ts +58 -1
  626. package/src/resources/extensions/gsd/dispatch-guard.ts +26 -2
  627. package/src/resources/extensions/gsd/docs/preferences-reference.md +1 -1
  628. package/src/resources/extensions/gsd/file-lock.ts +84 -11
  629. package/src/resources/extensions/gsd/forensics.ts +118 -1
  630. package/src/resources/extensions/gsd/gate-registry.ts +2 -2
  631. package/src/resources/extensions/gsd/git-constants.ts +30 -1
  632. package/src/resources/extensions/gsd/git-self-heal.ts +31 -0
  633. package/src/resources/extensions/gsd/git-service.ts +150 -2
  634. package/src/resources/extensions/gsd/gitignore.ts +2 -1
  635. package/src/resources/extensions/gsd/gsd-db.ts +97 -34
  636. package/src/resources/extensions/gsd/guided-flow-queue.ts +4 -1
  637. package/src/resources/extensions/gsd/guided-flow.ts +261 -14
  638. package/src/resources/extensions/gsd/health-widget.ts +3 -1
  639. package/src/resources/extensions/gsd/journal.ts +39 -3
  640. package/src/resources/extensions/gsd/key-manager.ts +22 -0
  641. package/src/resources/extensions/gsd/memory-extractor.ts +11 -3
  642. package/src/resources/extensions/gsd/milestone-actions.ts +18 -0
  643. package/src/resources/extensions/gsd/milestone-scope-classifier.ts +366 -0
  644. package/src/resources/extensions/gsd/milestone-summary-classifier.ts +42 -0
  645. package/src/resources/extensions/gsd/model-cost-table.ts +3 -0
  646. package/src/resources/extensions/gsd/model-router.ts +48 -1
  647. package/src/resources/extensions/gsd/native-git-bridge.ts +34 -4
  648. package/src/resources/extensions/gsd/notifications.ts +27 -15
  649. package/src/resources/extensions/gsd/pre-execution-checks.ts +33 -7
  650. package/src/resources/extensions/gsd/preferences-types.ts +8 -0
  651. package/src/resources/extensions/gsd/preferences-validation.ts +21 -0
  652. package/src/resources/extensions/gsd/prompt-cache-optimizer.ts +4 -0
  653. package/src/resources/extensions/gsd/prompts/complete-milestone.md +5 -1
  654. package/src/resources/extensions/gsd/prompts/discuss-headless.md +29 -2
  655. package/src/resources/extensions/gsd/prompts/discuss.md +29 -2
  656. package/src/resources/extensions/gsd/prompts/doctor-heal.md +5 -4
  657. package/src/resources/extensions/gsd/prompts/parallel-research-slices.md +5 -2
  658. package/src/resources/extensions/gsd/prompts/plan-slice.md +15 -2
  659. package/src/resources/extensions/gsd/prompts/system.md +1 -0
  660. package/src/resources/extensions/gsd/reports.ts +5 -4
  661. package/src/resources/extensions/gsd/safety/evidence-collector.ts +119 -0
  662. package/src/resources/extensions/gsd/safety/file-change-validator.ts +16 -3
  663. package/src/resources/extensions/gsd/safety/git-checkpoint.ts +15 -0
  664. package/src/resources/extensions/gsd/safety/safety-harness.ts +9 -0
  665. package/src/resources/extensions/gsd/service-tier.ts +5 -2
  666. package/src/resources/extensions/gsd/session-lock.ts +20 -10
  667. package/src/resources/extensions/gsd/skill-manifest.ts +175 -0
  668. package/src/resources/extensions/gsd/slice-cadence.ts +299 -0
  669. package/src/resources/extensions/gsd/slice-parallel-orchestrator.ts +309 -8
  670. package/src/resources/extensions/gsd/state-transition-matrix.ts +152 -0
  671. package/src/resources/extensions/gsd/state.ts +76 -66
  672. package/src/resources/extensions/gsd/sync-lock.ts +97 -39
  673. package/src/resources/extensions/gsd/tests/artifact-retry-cap.test.ts +270 -0
  674. package/src/resources/extensions/gsd/tests/artifacts-table-preserved-on-cache-invalidate.test.ts +2 -1
  675. package/src/resources/extensions/gsd/tests/auto-deterministic-error-classification-4973.test.ts +341 -0
  676. package/src/resources/extensions/gsd/tests/auto-discuss-milestone-deadlock-4973.test.ts +264 -0
  677. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +322 -286
  678. package/src/resources/extensions/gsd/tests/auto-mode-guards.test.ts +79 -0
  679. package/src/resources/extensions/gsd/tests/auto-model-selection-tool-poisoning.test.ts +742 -0
  680. package/src/resources/extensions/gsd/tests/auto-model-selection.test.ts +78 -0
  681. package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +12 -0
  682. package/src/resources/extensions/gsd/tests/auto-phases-lifecycle.test.ts +61 -0
  683. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +122 -0
  684. package/src/resources/extensions/gsd/tests/auto-remediate-slice-status.test.ts +4 -1
  685. package/src/resources/extensions/gsd/tests/auto-retry-mcp-churn-fixes.test.ts +8 -194
  686. package/src/resources/extensions/gsd/tests/auto-start-bootstrap-await-3420.test.ts +141 -0
  687. package/src/resources/extensions/gsd/tests/auto-start-clean-runtime-db-gated.test.ts +64 -0
  688. package/src/resources/extensions/gsd/tests/auto-start-cold-db-bootstrap.test.ts +2 -2
  689. package/src/resources/extensions/gsd/tests/auto-start-needs-discussion.test.ts +15 -58
  690. package/src/resources/extensions/gsd/tests/auto-start-worktree-db-path.test.ts +2 -2
  691. package/src/resources/extensions/gsd/tests/auto-thinking-restore.test.ts +3 -2
  692. package/src/resources/extensions/gsd/tests/auto-warning-noise-regression.test.ts +3 -2
  693. package/src/resources/extensions/gsd/tests/auto-wrapup-inflight-guard.test.ts +23 -0
  694. package/src/resources/extensions/gsd/tests/bootstrap-derive-state-db-open.test.ts +2 -1
  695. package/src/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +17 -21
  696. package/src/resources/extensions/gsd/tests/canonical-milestone-root.test.ts +108 -0
  697. package/src/resources/extensions/gsd/tests/clean-root-preflight.test.ts +186 -0
  698. package/src/resources/extensions/gsd/tests/cmux.test.ts +5 -9
  699. package/src/resources/extensions/gsd/tests/complete-milestone-excerpt.test.ts +263 -0
  700. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +61 -1
  701. package/src/resources/extensions/gsd/tests/complete-slice-composer.test.ts +192 -0
  702. package/src/resources/extensions/gsd/tests/complete-slice-verification-gate.test.ts +2 -1
  703. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +2 -2
  704. package/src/resources/extensions/gsd/tests/complete-task.test.ts +16 -8
  705. package/src/resources/extensions/gsd/tests/component-loader.test.ts +589 -0
  706. package/src/resources/extensions/gsd/tests/component-types.test.ts +127 -0
  707. package/src/resources/extensions/gsd/tests/context-store.test.ts +79 -0
  708. package/src/resources/extensions/gsd/tests/copy-planning-artifacts-samepath.test.ts +2 -1
  709. package/src/resources/extensions/gsd/tests/crash-recovery.test.ts +50 -1
  710. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +161 -0
  711. package/src/resources/extensions/gsd/tests/db-access-guardrails.test.ts +1 -0
  712. package/src/resources/extensions/gsd/tests/derive-state-crossval.test.ts +3 -3
  713. package/src/resources/extensions/gsd/tests/derive-state-db-disk-reconcile.test.ts +40 -0
  714. package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +91 -3
  715. package/src/resources/extensions/gsd/tests/derive-state.test.ts +4 -4
  716. package/src/resources/extensions/gsd/tests/discuss-slice-structured-questions.test.ts +2 -1
  717. package/src/resources/extensions/gsd/tests/discuss-tool-scope-leak.test.ts +2 -1
  718. package/src/resources/extensions/gsd/tests/dispatch-complete-milestone-guard.test.ts +14 -9
  719. package/src/resources/extensions/gsd/tests/dispatch-guard-summary-db-mismatch.test.ts +77 -0
  720. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +25 -0
  721. package/src/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +14 -0
  722. package/src/resources/extensions/gsd/tests/dispatcher-stuck-planning.test.ts +3 -2
  723. package/src/resources/extensions/gsd/tests/doctor-providers.test.ts +31 -0
  724. package/src/resources/extensions/gsd/tests/double-merge-guard.test.ts +4 -3
  725. package/src/resources/extensions/gsd/tests/empty-content-abort-loop.test.ts +4 -3
  726. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +1 -1
  727. package/src/resources/extensions/gsd/tests/escalation.test.ts +1 -1
  728. package/src/resources/extensions/gsd/tests/exec-history.test.ts +113 -0
  729. package/src/resources/extensions/gsd/tests/execution-entry-missing-context-4671.test.ts +173 -0
  730. package/src/resources/extensions/gsd/tests/extension-bootstrap-isolation.test.ts +139 -129
  731. package/src/resources/extensions/gsd/tests/file-change-validator.test.ts +38 -0
  732. package/src/resources/extensions/gsd/tests/file-lock.test.ts +86 -12
  733. package/src/resources/extensions/gsd/tests/finalize-timeout-guard.test.ts +8 -104
  734. package/src/resources/extensions/gsd/tests/gate-state-canonicalization.test.ts +102 -0
  735. package/src/resources/extensions/gsd/tests/gate-storage.test.ts +1 -1
  736. package/src/resources/extensions/gsd/tests/google-search-stub.test.ts +131 -0
  737. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +296 -1
  738. package/src/resources/extensions/gsd/tests/headless-milestone-parity.test.ts +117 -0
  739. package/src/resources/extensions/gsd/tests/hook-key-parsing.test.ts +4 -55
  740. package/src/resources/extensions/gsd/tests/integration/all-milestones-complete-merge.test.ts +7 -56
  741. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +30 -0
  742. package/src/resources/extensions/gsd/tests/integration/doctor-proactive.test.ts +18 -2
  743. package/src/resources/extensions/gsd/tests/integration/git-service.test.ts +4 -2
  744. package/src/resources/extensions/gsd/tests/integration/gitignore-tracked-gsd.test.ts +1 -0
  745. package/src/resources/extensions/gsd/tests/integration/idle-recovery.test.ts +30 -0
  746. package/src/resources/extensions/gsd/tests/integration/queue-completed-milestone-perf.test.ts +10 -4
  747. package/src/resources/extensions/gsd/tests/integration/state-machine-edge-cases.test.ts +144 -7
  748. package/src/resources/extensions/gsd/tests/integration/state-machine-live-validation.test.ts +4 -0
  749. package/src/resources/extensions/gsd/tests/integration/state-machine-runtime-failures.test.ts +2 -16
  750. package/src/resources/extensions/gsd/tests/integration/worktree-e2e.test.ts +11 -0
  751. package/src/resources/extensions/gsd/tests/interactive-routing-bypass.test.ts +9 -3
  752. package/src/resources/extensions/gsd/tests/interrupted-session-ui.test.ts +6 -9
  753. package/src/resources/extensions/gsd/tests/issue-4540-regressions.test.ts +288 -0
  754. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +66 -0
  755. package/src/resources/extensions/gsd/tests/key-manager.test.ts +2 -0
  756. package/src/resources/extensions/gsd/tests/knowledge.test.ts +93 -1
  757. package/src/resources/extensions/gsd/tests/mcp-client-security.test.ts +47 -0
  758. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
  759. package/src/resources/extensions/gsd/tests/memory-extractor.test.ts +5 -15
  760. package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +12 -0
  761. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  762. package/src/resources/extensions/gsd/tests/merge-conflict-stops-loop.test.ts +227 -55
  763. package/src/resources/extensions/gsd/tests/milestone-scope-classifier.test.ts +187 -0
  764. package/src/resources/extensions/gsd/tests/milestone-status-authoritative.test.ts +3 -3
  765. package/src/resources/extensions/gsd/tests/milestone-summary-classifier.test.ts +30 -0
  766. package/src/resources/extensions/gsd/tests/milestone-transition-state-rebuild.test.ts +4 -2
  767. package/src/resources/extensions/gsd/tests/model-cost-table.test.ts +9 -1
  768. package/src/resources/extensions/gsd/tests/model-router.test.ts +1 -1
  769. package/src/resources/extensions/gsd/tests/native-git-bridge-exec-fallback.test.ts +6 -48
  770. package/src/resources/extensions/gsd/tests/notification-widget.test.ts +6 -3
  771. package/src/resources/extensions/gsd/tests/orphaned-worktree-audit.test.ts +59 -2
  772. package/src/resources/extensions/gsd/tests/parallel-commit-scope.test.ts +5 -0
  773. package/src/resources/extensions/gsd/tests/parallel-research-dispatch.test.ts +274 -112
  774. package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +150 -0
  775. package/src/resources/extensions/gsd/tests/pipeline-variant-dispatch.test.ts +301 -0
  776. package/src/resources/extensions/gsd/tests/plan-gate-failed-doctor-heal-hint.test.ts +37 -0
  777. package/src/resources/extensions/gsd/tests/pre-exec-gate-loop.test.ts +272 -0
  778. package/src/resources/extensions/gsd/tests/pre-execution-checks.test.ts +337 -0
  779. package/src/resources/extensions/gsd/tests/pre-execution-pause-wiring.test.ts +32 -1
  780. package/src/resources/extensions/gsd/tests/preferences-worktree-sync.test.ts +2 -1
  781. package/src/resources/extensions/gsd/tests/prefs-wizard-coverage.test.ts +44 -0
  782. package/src/resources/extensions/gsd/tests/prompt-cache-optimizer.test.ts +12 -0
  783. package/src/resources/extensions/gsd/tests/prompt-step-ordering.test.ts +15 -4
  784. package/src/resources/extensions/gsd/tests/provider-errors.test.ts +54 -41
  785. package/src/resources/extensions/gsd/tests/queue-auto-guard.test.ts +213 -0
  786. package/src/resources/extensions/gsd/tests/queue-draft-detection.test.ts +3 -2
  787. package/src/resources/extensions/gsd/tests/queued-discuss-fast-path.test.ts +4 -5
  788. package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +13 -7
  789. package/src/resources/extensions/gsd/tests/ready-phrase-no-files-4573.test.ts +388 -0
  790. package/src/resources/extensions/gsd/tests/reassess-default-optin.test.ts +132 -0
  791. package/src/resources/extensions/gsd/tests/recovery-attempts-reset.test.ts +8 -40
  792. package/src/resources/extensions/gsd/tests/regex-hardening.test.ts +136 -256
  793. package/src/resources/extensions/gsd/tests/require-slice-discussion-dispatch.test.ts +170 -0
  794. package/src/resources/extensions/gsd/tests/research-milestone-composer.test.ts +114 -0
  795. package/src/resources/extensions/gsd/tests/restore-tools-after-discuss.test.ts +15 -6
  796. package/src/resources/extensions/gsd/tests/resume-dispatch-worktree.test.ts +230 -0
  797. package/src/resources/extensions/gsd/tests/rewrite-docs-abandon-detect.test.ts +195 -0
  798. package/src/resources/extensions/gsd/tests/run-uat-composer.test.ts +148 -0
  799. package/src/resources/extensions/gsd/tests/safety-harness-false-positives.test.ts +205 -0
  800. package/src/resources/extensions/gsd/tests/schema-v21-sequence.test.ts +413 -0
  801. package/src/resources/extensions/gsd/tests/service-tier.test.ts +4 -0
  802. package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +29 -0
  803. package/src/resources/extensions/gsd/tests/session-start-footer.test.ts +32 -40
  804. package/src/resources/extensions/gsd/tests/sidecar-queue.test.ts +3 -2
  805. package/src/resources/extensions/gsd/tests/silent-catch-diagnostics.test.ts +55 -95
  806. package/src/resources/extensions/gsd/tests/single-writer-v3-tool-surface.test.ts +158 -0
  807. package/src/resources/extensions/gsd/tests/skill-activation.test.ts +120 -1
  808. package/src/resources/extensions/gsd/tests/skill-manifest.test.ts +112 -0
  809. package/src/resources/extensions/gsd/tests/slice-cadence.test.ts +242 -0
  810. package/src/resources/extensions/gsd/tests/slice-context-injection.test.ts +3 -2
  811. package/src/resources/extensions/gsd/tests/slice-parallel-orchestrator.test.ts +164 -1
  812. package/src/resources/extensions/gsd/tests/smart-entry-draft.test.ts +2 -1
  813. package/src/resources/extensions/gsd/tests/stale-dirlistcache-4648.test.ts +112 -0
  814. package/src/resources/extensions/gsd/tests/stash-queued-context-files.test.ts +56 -0
  815. package/src/resources/extensions/gsd/tests/state-machine-full-walkthrough.test.ts +29 -5
  816. package/src/resources/extensions/gsd/tests/state-transition-matrix.test.ts +44 -0
  817. package/src/resources/extensions/gsd/tests/stop-auto-race-null-unit.test.ts +3 -3
  818. package/src/resources/extensions/gsd/tests/structured-data-formatter.test.ts +11 -92
  819. package/src/resources/extensions/gsd/tests/stuck-detection-coverage.test.ts +2 -2
  820. package/src/resources/extensions/gsd/tests/subagent-model-dispatch.test.ts +7 -6
  821. package/src/resources/extensions/gsd/tests/survivor-branch-complete.test.ts +102 -101
  822. package/src/resources/extensions/gsd/tests/sync-lock.test.ts +31 -0
  823. package/src/resources/extensions/gsd/tests/sync-worktree-skip-current.test.ts +4 -3
  824. package/src/resources/extensions/gsd/tests/test-helpers.test.ts +98 -0
  825. package/src/resources/extensions/gsd/tests/test-helpers.ts +153 -0
  826. package/src/resources/extensions/gsd/tests/token-counter.test.ts +105 -1
  827. package/src/resources/extensions/gsd/tests/token-profile.test.ts +8 -1
  828. package/src/resources/extensions/gsd/tests/tool-compatibility.test.ts +107 -0
  829. package/src/resources/extensions/gsd/tests/tool-invocation-error-loop-break.test.ts +61 -1
  830. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +8 -1
  831. package/src/resources/extensions/gsd/tests/triage-resolution.test.ts +50 -2
  832. package/src/resources/extensions/gsd/tests/turn-epoch.test.ts +162 -0
  833. package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +355 -0
  834. package/src/resources/extensions/gsd/tests/unit-context-manifest.test.ts +258 -0
  835. package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +51 -0
  836. package/src/resources/extensions/gsd/tests/uok-execution-graph.test.ts +16 -0
  837. package/src/resources/extensions/gsd/tests/uok-gate-runner.test.ts +75 -0
  838. package/src/resources/extensions/gsd/tests/uok-gitops-wiring.test.ts +49 -26
  839. package/src/resources/extensions/gsd/tests/uok-loop-adapter-writer.test.ts +65 -0
  840. package/src/resources/extensions/gsd/tests/uok-parity-report.test.ts +42 -0
  841. package/src/resources/extensions/gsd/tests/uok-plan-v2-wiring.test.ts +42 -2
  842. package/src/resources/extensions/gsd/tests/uok-writer.test.ts +75 -0
  843. package/src/resources/extensions/gsd/tests/validate-extension-package.test.ts +168 -0
  844. package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +139 -5
  845. package/src/resources/extensions/gsd/tests/verify-artifact-tightened.test.ts +144 -80
  846. package/src/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +20 -54
  847. package/src/resources/extensions/gsd/tests/visualizer-overlay.test.ts +342 -277
  848. package/src/resources/extensions/gsd/tests/worker-model-override.test.ts +37 -29
  849. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +25 -2
  850. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +65 -2
  851. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +242 -247
  852. package/src/resources/extensions/gsd/tests/worktree-health-monorepo.test.ts +103 -67
  853. package/src/resources/extensions/gsd/tests/worktree-journal-events.test.ts +6 -1
  854. package/src/resources/extensions/gsd/tests/worktree-nested-git-safety.test.ts +92 -90
  855. package/src/resources/extensions/gsd/tests/worktree-resolver.test.ts +78 -5
  856. package/src/resources/extensions/gsd/tests/worktree-submodule-safety.test.ts +238 -59
  857. package/src/resources/extensions/gsd/tests/worktree-sync-overwrite-loop.test.ts +113 -161
  858. package/src/resources/extensions/gsd/tests/worktree-telemetry.test.ts +210 -0
  859. package/src/resources/extensions/gsd/tests/write-gate-planning-unit.test.ts +262 -0
  860. package/src/resources/extensions/gsd/tests/write-gate-predicates.test.ts +186 -0
  861. package/src/resources/extensions/gsd/tests/write-gate.test.ts +71 -5
  862. package/src/resources/extensions/gsd/tests/zombie-gsd-state.test.ts +80 -96
  863. package/src/resources/extensions/gsd/token-counter.ts +22 -5
  864. package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
  865. package/src/resources/extensions/gsd/tools/complete-slice.ts +38 -0
  866. package/src/resources/extensions/gsd/tools/complete-task.ts +49 -0
  867. package/src/resources/extensions/gsd/tools/validate-milestone.ts +8 -2
  868. package/src/resources/extensions/gsd/types.ts +3 -3
  869. package/src/resources/extensions/gsd/unit-context-composer.ts +218 -0
  870. package/src/resources/extensions/gsd/unit-context-manifest.ts +574 -0
  871. package/src/resources/extensions/gsd/uok/audit.ts +20 -2
  872. package/src/resources/extensions/gsd/uok/contracts.ts +65 -0
  873. package/src/resources/extensions/gsd/uok/dispatch-envelope.ts +56 -0
  874. package/src/resources/extensions/gsd/uok/execution-graph.ts +22 -0
  875. package/src/resources/extensions/gsd/uok/gate-runner.ts +65 -5
  876. package/src/resources/extensions/gsd/uok/gitops.ts +6 -1
  877. package/src/resources/extensions/gsd/uok/loop-adapter.ts +45 -10
  878. package/src/resources/extensions/gsd/uok/parity-report.ts +84 -0
  879. package/src/resources/extensions/gsd/uok/plan-v2.ts +39 -8
  880. package/src/resources/extensions/gsd/uok/writer.ts +113 -0
  881. package/src/resources/extensions/gsd/workflow-logger.ts +23 -3
  882. package/src/resources/extensions/gsd/workflow-mcp.ts +6 -0
  883. package/src/resources/extensions/gsd/worktree-manager.ts +109 -7
  884. package/src/resources/extensions/gsd/worktree-resolver.ts +150 -18
  885. package/src/resources/extensions/gsd/worktree-telemetry.ts +322 -0
  886. package/src/resources/extensions/mcp-client/auth.ts +12 -1
  887. package/src/resources/extensions/mcp-client/index.ts +132 -11
  888. package/src/resources/extensions/mcp-client/tests/server-name-spaces.test.ts +70 -36
  889. package/src/resources/extensions/ollama/index.ts +5 -1
  890. package/src/resources/extensions/ollama/ollama-auth-mode.test.ts +123 -15
  891. package/src/resources/extensions/ollama/ollama-status-indicator.test.ts +206 -19
  892. package/src/resources/extensions/remote-questions/manager.ts +36 -4
  893. package/src/resources/extensions/remote-questions/tests/command-polling.test.ts +200 -190
  894. package/src/resources/extensions/shared/cmux-events.ts +59 -0
  895. package/src/resources/extensions/shared/rtk-session-stats.ts +1 -2
  896. package/src/resources/extensions/shared/tests/interview-preview.test.ts +11 -3
  897. package/src/resources/extensions/voice/tests/linux-ready.test.ts +129 -113
  898. package/src/resources/skills/create-skill/SKILL.md +2 -2
  899. package/src/resources/skills/create-skill/references/gsd-skill-ecosystem.md +4 -4
  900. package/src/resources/skills/create-skill/workflows/audit-skill.md +4 -4
  901. package/src/resources/skills/create-skill/workflows/create-new-skill.md +5 -5
  902. package/src/resources/skills/verify-before-complete/SKILL.md +2 -1
  903. package/src/resources/skills/write-docs/SKILL.md +2 -1
  904. package/dist/web/standalone/.next/server/chunks/7461.js +0 -1
  905. package/dist/web/standalone/.next/static/chunks/2826.e59e8578e2e28639.js +0 -9
  906. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts +0 -2
  907. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.d.ts.map +0 -1
  908. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js +0 -289
  909. package/packages/pi-ai/dist/utils/oauth/oauth-providers.test.js.map +0 -1
  910. package/packages/pi-ai/src/utils/oauth/oauth-providers.test.ts +0 -363
  911. package/src/resources/extensions/gsd/tests/auto-start-model-capture.test.ts +0 -143
  912. package/src/resources/extensions/gsd/tests/complete-milestone-false-merge.test.ts +0 -142
  913. package/src/resources/extensions/gsd/tests/dashboard-model-label-ordering.test.ts +0 -107
  914. package/src/resources/extensions/gsd/tests/find-missing-summaries-closed.test.ts +0 -48
  915. package/src/resources/extensions/gsd/tests/forensics-context-persist.test.ts +0 -159
  916. package/src/resources/extensions/gsd/tests/forensics-db-completion.test.ts +0 -96
  917. package/src/resources/extensions/gsd/tests/forensics-dedup.test.ts +0 -79
  918. package/src/resources/extensions/gsd/tests/forensics-hook-key-parse.test.ts +0 -74
  919. package/src/resources/extensions/gsd/tests/forensics-journal.test.ts +0 -162
  920. package/src/resources/extensions/gsd/tests/gitignore-bg-shell.test.ts +0 -38
  921. package/src/resources/extensions/gsd/tests/gsd-no-project-error.test.ts +0 -73
  922. package/src/resources/extensions/gsd/tests/idle-watchdog-stall-override.test.ts +0 -125
  923. package/src/resources/extensions/gsd/tests/import-done-milestones.test.ts +0 -42
  924. /package/dist/web/standalone/.next/static/{n21VtX2hZlkpdEUO_nU4z → MdwvuQQLlBY6wwiSO1Tgv}/_buildManifest.js +0 -0
  925. /package/dist/web/standalone/.next/static/{n21VtX2hZlkpdEUO_nU4z → MdwvuQQLlBY6wwiSO1Tgv}/_ssgManifest.js +0 -0
@@ -0,0 +1,141 @@
1
+ /**
2
+ * auto-start-bootstrap-await-3420.test.ts — Regression test for #3420.
3
+ *
4
+ * Bug: In bootstrapAutoSession, when state.phase === "pre-planning" and no
5
+ * context file exists, showSmartEntry is called to dispatch a discuss workflow.
6
+ * showSmartEntry calls dispatchWorkflow which calls pi.sendMessage() — a
7
+ * fire-and-forget call that returns immediately. The LLM discussion runs
8
+ * asynchronously in a separate turn.
9
+ *
10
+ * The bug: after showSmartEntry returns (before the LLM has run), the code
11
+ * immediately calls invalidateAllCaches() + deriveState() + checks postState.
12
+ * Since the discussion hasn't run yet, postState.phase is still "pre-planning"
13
+ * and the context check fails, producing the warning:
14
+ * "Discussion completed but milestone context is still missing. Run /gsd to try again."
15
+ *
16
+ * The discussion never ran — the warning fires immediately.
17
+ *
18
+ * Fix: bootstrapAutoSession must return false (release lock) after showSmartEntry
19
+ * dispatches the workflow. The checkAutoStartAfterDiscuss callback in guided-flow.ts
20
+ * already handles re-entering auto-mode when the discussion completes.
21
+ *
22
+ * This test verifies the fix by asserting that the pre-planning !hasContext block
23
+ * does NOT contain a postState phase check after showSmartEntry — it must
24
+ * return false immediately to let the async dispatch complete.
25
+ */
26
+
27
+ import test from "node:test";
28
+ import assert from "node:assert/strict";
29
+ import { readFileSync } from "node:fs";
30
+ import { join } from "node:path";
31
+
32
+ const sourcePath = join(import.meta.dirname, "..", "auto-start.ts");
33
+ const source = readFileSync(sourcePath, "utf-8");
34
+
35
+ test("bootstrapAutoSession: pre-planning no-context path does NOT check postState immediately after showSmartEntry (#3420)", () => {
36
+ // Find the pre-planning block that handles the case where context is missing.
37
+ // This block dispatches showSmartEntry which is async (fire-and-forget via pi.sendMessage).
38
+ // After the dispatch, checking postState.phase immediately is premature — the
39
+ // LLM discussion hasn't run yet. The block should return false instead.
40
+ const prePlanningNoContextBlock = source.match(
41
+ /\/\/ Active milestone exists but has no roadmap\s*\n\s*if\s*\(\s*state\.phase\s*===\s*"pre-planning"\s*\)([\s\S]*?)\/\/ Active milestone has CONTEXT-DRAFT/,
42
+ );
43
+ assert.ok(
44
+ !!prePlanningNoContextBlock,
45
+ "auto-start.ts must have the pre-planning handler block before needs-discussion",
46
+ );
47
+
48
+ const block = prePlanningNoContextBlock![1];
49
+
50
+ // The block must call showSmartEntry when !hasContext
51
+ assert.ok(
52
+ block.includes("showSmartEntry"),
53
+ "pre-planning !hasContext block must call showSmartEntry to dispatch the discuss workflow",
54
+ );
55
+
56
+ // FAILING ASSERTION (before fix): after showSmartEntry, the block must NOT
57
+ // immediately check postState.phase — that check fires before the LLM runs.
58
+ // Instead, it must return false (release lock) so the async dispatch can complete.
59
+ // The warning "Discussion completed but milestone context is still missing"
60
+ // fires prematurely when this postState check exists.
61
+ assert.ok(
62
+ !block.includes("Discussion completed but milestone context is still missing"),
63
+ "pre-planning !hasContext block must NOT check postState.phase immediately after showSmartEntry — " +
64
+ "the dispatch is async (pi.sendMessage is fire-and-forget) and the discussion hasn't run yet; " +
65
+ "return false instead so checkAutoStartAfterDiscuss can re-enter auto-mode after discussion completes (#3420)",
66
+ );
67
+ });
68
+
69
+ test("bootstrapAutoSession: complete/no-milestone path does NOT check postState immediately after showSmartEntry (#3420)", () => {
70
+ // Find the complete/no-milestone block
71
+ const completeBlock = source.match(
72
+ /\/\/ No active work — start a new milestone via discuss flow\s*\n\s*if\s*\(!state\.activeMilestone\s*\|\|\s*state\.phase\s*===\s*"complete"\s*\)([\s\S]*?)\/\/ Active milestone exists but has no roadmap/,
73
+ );
74
+ assert.ok(
75
+ !!completeBlock,
76
+ "auto-start.ts must have the complete/no-milestone handler block",
77
+ );
78
+
79
+ const block = completeBlock![1];
80
+
81
+ // The block must call showSmartEntry
82
+ assert.ok(
83
+ block.includes("showSmartEntry"),
84
+ "complete/no-milestone block must call showSmartEntry",
85
+ );
86
+
87
+ // After showSmartEntry dispatches, checking postState.phase is premature —
88
+ // the LLM hasn't had a turn yet. The block should return false.
89
+ // Specifically, the "no milestone context was written" warning fires too early.
90
+ assert.ok(
91
+ !block.includes("Discussion completed but no milestone context was written"),
92
+ "complete/no-milestone block must NOT check postState.phase immediately after showSmartEntry dispatch — " +
93
+ "return false instead so the async LLM turn can complete (#3420)",
94
+ );
95
+ });
96
+
97
+ test("bootstrapAutoSession: showSmartEntry in pre-planning path is followed by releaseLockAndReturn, not postState check (#3420)", () => {
98
+ // After the fix, the pre-planning !hasContext branch should call showSmartEntry
99
+ // and then immediately return releaseLockAndReturn() — not check postState.
100
+ const prePlanningNoContextBlock = source.match(
101
+ /\/\/ Active milestone exists but has no roadmap\s*\n\s*if\s*\(\s*state\.phase\s*===\s*"pre-planning"\s*\)([\s\S]*?)\/\/ Active milestone has CONTEXT-DRAFT/,
102
+ );
103
+ assert.ok(!!prePlanningNoContextBlock, "pre-planning handler block found");
104
+
105
+ const block = prePlanningNoContextBlock![1];
106
+
107
+ // After the fix, the !hasContext branch ends with releaseLockAndReturn
108
+ assert.ok(
109
+ block.includes("releaseLockAndReturn"),
110
+ "pre-planning !hasContext block must call releaseLockAndReturn() after showSmartEntry dispatch (#3420)",
111
+ );
112
+
113
+ // The showSmartEntry call must appear before releaseLockAndReturn
114
+ const showSmartEntryIdx = block.indexOf("showSmartEntry");
115
+ const releaseLockIdx = block.indexOf("releaseLockAndReturn");
116
+ assert.ok(
117
+ showSmartEntryIdx > -1 && releaseLockIdx > -1,
118
+ "both showSmartEntry and releaseLockAndReturn must appear in the block",
119
+ );
120
+ assert.ok(
121
+ showSmartEntryIdx < releaseLockIdx,
122
+ "showSmartEntry must appear before releaseLockAndReturn in pre-planning !hasContext block",
123
+ );
124
+
125
+ // There must be NO invalidateAllCaches between showSmartEntry and releaseLockAndReturn
126
+ // (invalidateAllCaches + deriveState after showSmartEntry is the buggy premature check)
127
+ const afterShowSmartEntry = block.substring(showSmartEntryIdx);
128
+ const cacheInvalidateIdx = afterShowSmartEntry.indexOf("invalidateAllCaches");
129
+ const releaseFromShowIdx = afterShowSmartEntry.indexOf("releaseLockAndReturn");
130
+
131
+ // If invalidateAllCaches appears, it must appear AFTER releaseLockAndReturn
132
+ // (which is impossible since releaseLockAndReturn returns) — so invalidateAllCaches
133
+ // must not appear at all between showSmartEntry and the end of the !hasContext block.
134
+ if (cacheInvalidateIdx !== -1) {
135
+ assert.ok(
136
+ cacheInvalidateIdx > releaseFromShowIdx,
137
+ "invalidateAllCaches must NOT appear between showSmartEntry and releaseLockAndReturn — " +
138
+ "this is the premature postState check that causes #3420",
139
+ );
140
+ }
141
+ });
@@ -0,0 +1,64 @@
1
+ // GSD-2 auto-start regression test: cleanStaleRuntimeUnits is DB-gated (#4663)
2
+ //
3
+ // Source-level structural check that the stale-runtime-cleanup predicate in
4
+ // auto-start.ts consults DB status when available instead of treating a
5
+ // SUMMARY-file on disk as proof of milestone completion. Pairs with #4658 /
6
+ // PR #4660 fix in auto-dispatch + auto-recovery.
7
+
8
+ import { describe, test } from "node:test";
9
+ import assert from "node:assert/strict";
10
+ import { readFileSync } from "node:fs";
11
+ import { join, dirname } from "node:path";
12
+ import { fileURLToPath } from "node:url";
13
+ import { extractSourceRegion } from "./test-helpers.ts";
14
+
15
+ const __dirname = dirname(fileURLToPath(import.meta.url));
16
+ const sourceFile = join(__dirname, "..", "auto-start.ts");
17
+
18
+ describe("auto-start cleanStaleRuntimeUnits DB gating (#4663)", () => {
19
+ const source = readFileSync(sourceFile, "utf-8");
20
+
21
+ test("imports isClosedStatus for DB-status check", () => {
22
+ assert.match(
23
+ source,
24
+ /import\s*\{\s*isClosedStatus\s*\}\s*from\s*["']\.\/status-guards/,
25
+ );
26
+ });
27
+
28
+ test("cleanStaleRuntimeUnits is called after openProjectDbIfPresent", () => {
29
+ const openDbIdx = source.indexOf("await openProjectDbIfPresent(base)");
30
+ assert.ok(openDbIdx > -1, "openProjectDbIfPresent should be called in auto-start");
31
+ const cleanIdx = source.indexOf("cleanStaleRuntimeUnits(", openDbIdx);
32
+ assert.ok(
33
+ cleanIdx > -1,
34
+ "cleanStaleRuntimeUnits must run AFTER openProjectDbIfPresent so predicate can consult DB",
35
+ );
36
+ });
37
+
38
+ test("cleanStaleRuntimeUnits predicate consults DB status when available", () => {
39
+ const cleanIdx = source.indexOf("cleanStaleRuntimeUnits(");
40
+ assert.ok(cleanIdx > -1);
41
+ const snippet = extractSourceRegion(source, "cleanStaleRuntimeUnits(");
42
+ assert.match(
43
+ snippet,
44
+ /isDbAvailable\(\)/,
45
+ "predicate must branch on DB availability",
46
+ );
47
+ assert.match(
48
+ snippet,
49
+ /isClosedStatus\(/,
50
+ "predicate must check DB status via isClosedStatus",
51
+ );
52
+ });
53
+
54
+ test("cleanStaleRuntimeUnits predicate still falls back to SUMMARY-file when DB unavailable", () => {
55
+ const cleanIdx = source.indexOf("cleanStaleRuntimeUnits(");
56
+ assert.ok(cleanIdx > -1);
57
+ const snippet = extractSourceRegion(source, "cleanStaleRuntimeUnits(");
58
+ assert.match(
59
+ snippet,
60
+ /resolveMilestoneFile\(base,\s*mid,\s*["']SUMMARY["']\)/,
61
+ "legacy FS-fallback branch should still use SUMMARY file presence",
62
+ );
63
+ });
64
+ });
@@ -1,7 +1,7 @@
1
1
  import { readFileSync } from "node:fs";
2
2
  import { join } from "node:path";
3
3
 
4
- import { createTestContext } from "./test-helpers.ts";
4
+ import {createTestContext, extractSourceRegion } from "./test-helpers.ts";
5
5
 
6
6
  const { assertTrue, report } = createTestContext();
7
7
 
@@ -13,7 +13,7 @@ console.log("\n=== #2841: cold DB opened before initial deriveState ===");
13
13
  const helperIdx = src.indexOf("async function openProjectDbIfPresent");
14
14
  assertTrue(helperIdx >= 0, "auto-start.ts defines a helper for pre-derive DB open (#2841)");
15
15
 
16
- const helperRegion = helperIdx >= 0 ? src.slice(helperIdx, helperIdx + 500) : "";
16
+ const helperRegion = helperIdx >= 0 ? extractSourceRegion(src, "async function openProjectDbIfPresent") : "";
17
17
  assertTrue(
18
18
  helperRegion.includes("resolveProjectRootDbPath(basePath)"),
19
19
  "pre-derive DB helper resolves the project-root DB path (#2841)",
@@ -157,62 +157,19 @@ describe("auto-start-needs-discussion (#1726)", () => {
157
157
  }
158
158
  });
159
159
 
160
- test("6. No infinite loop: needs-discussion always routes to showSmartEntry", () => {
161
- const source = readAutoStartSource();
162
-
163
- // Verify needs-discussion does NOT appear in auto-dispatch trigger conditions
164
- // within auto-start.ts. The only place needs-discussion should appear is in
165
- // the showSmartEntry routing block.
166
- const survivorSection = source.match(
167
- /\/\/ Milestone branch recovery.*?let hasSurvivorBranch = false;[\s\S]*?if\s*\([^)]*state\.phase[^)]*\)\s*\{/,
168
- );
169
- if (survivorSection) {
170
- assert.ok(
171
- !survivorSection[0].includes("needs-discussion"),
172
- "survivor branch phase condition must not mention needs-discussion",
173
- );
174
- }
175
-
176
- // Verify needs-discussion IS handled inside the !hasSurvivorBranch block
177
- const notSurvivorBlock = source.match(
178
- /if\s*\(!hasSurvivorBranch\)\s*\{([\s\S]*?)\/\/ Unreachable safety check/,
179
- );
180
- assert.ok(!!notSurvivorBlock,
181
- "found !hasSurvivorBranch block in auto-start.ts");
182
- if (notSurvivorBlock) {
183
- assert.ok(
184
- notSurvivorBlock[1].includes('"needs-discussion"'),
185
- "!hasSurvivorBranch block must handle needs-discussion phase",
186
- );
187
- }
188
- });
189
-
190
- test("7. Survivor branch + needs-discussion routes to showSmartEntry", () => {
191
- const source = readAutoStartSource();
192
-
193
- // When hasSurvivorBranch is true AND phase is needs-discussion, the code
194
- // must route to showSmartEntry instead of falling through to auto-mode.
195
- const survivorNeedsDiscussion = source.match(
196
- /if\s*\(hasSurvivorBranch\s*&&\s*state\.phase\s*===\s*"needs-discussion"\)\s*\{[^}]*showSmartEntry/s,
197
- );
198
- assert.ok(!!survivorNeedsDiscussion,
199
- "hasSurvivorBranch && needs-discussion must route to showSmartEntry");
200
-
201
- // Verify the handler checks if the discussion succeeded
202
- const handlerBlock = source.match(
203
- /if\s*\(hasSurvivorBranch\s*&&\s*state\.phase\s*===\s*"needs-discussion"\)\s*\{([\s\S]*?)\n \}/,
204
- );
205
- assert.ok(!!handlerBlock,
206
- "found survivor + needs-discussion handler block");
207
- if (handlerBlock) {
208
- assert.ok(
209
- handlerBlock[1].includes('postState.phase !== "needs-discussion"'),
210
- "handler must check if phase advanced after discussion",
211
- );
212
- assert.ok(
213
- handlerBlock[1].includes("releaseLockAndReturn"),
214
- "handler must abort if discussion didn't promote draft",
215
- );
216
- }
217
- });
160
+ // Tests 6 and 7 removed in the #4832 follow-up.
161
+ //
162
+ // They source-grepped `auto-start.ts` for specific regex patterns like
163
+ // `if (hasSurvivorBranch && state.phase === "needs-discussion")`
164
+ // which broke (correctly so) when the three-way survivor decision was
165
+ // extracted into the `decideSurvivorAction` pure helper. The
166
+ // behavioural invariants they were trying to uphold are now covered
167
+ // directly in `survivor-branch-complete.test.ts`:
168
+ // - (hasSurvivor=true, phase="needs-discussion") → "discuss"
169
+ // - (hasSurvivor=false, phase="needs-discussion") → "none"
170
+ // - (hasSurvivor=true, phase=other) → "none"
171
+ // Those tests fail on real decision regressions without the
172
+ // source-grep brittleness. Tests 1–5 above remain — they hit
173
+ // `deriveState` on real fixtures and defend the #1726 infinite-loop
174
+ // fix end-to-end.
218
175
  });
@@ -1,7 +1,7 @@
1
1
  import { readFileSync } from "node:fs";
2
2
  import { join } from "node:path";
3
3
 
4
- import { createTestContext } from "./test-helpers.ts";
4
+ import {createTestContext, extractSourceRegion } from "./test-helpers.ts";
5
5
 
6
6
  const { assertTrue, report } = createTestContext();
7
7
 
@@ -13,7 +13,7 @@ console.log("\n=== #3822: worktree bootstrap uses project DB path ===");
13
13
  const dbLifecycleIdx = src.indexOf("// ── DB lifecycle ──");
14
14
  assertTrue(dbLifecycleIdx > 0, "auto-start.ts has a DB lifecycle section");
15
15
 
16
- const dbLifecycleRegion = dbLifecycleIdx > 0 ? src.slice(dbLifecycleIdx, dbLifecycleIdx + 600) : "";
16
+ const dbLifecycleRegion = dbLifecycleIdx > 0 ? extractSourceRegion(src, "// ── DB lifecycle ──") : "";
17
17
 
18
18
  assertTrue(
19
19
  dbLifecycleRegion.includes("const gsdDbPath = resolveProjectRootDbPath(s.basePath);"),
@@ -2,6 +2,7 @@ import test from "node:test";
2
2
  import assert from "node:assert/strict";
3
3
  import { readFileSync } from "node:fs";
4
4
  import { join } from "node:path";
5
+ import { extractSourceRegion } from "./test-helpers.ts";
5
6
 
6
7
  const autoSrc = readFileSync(join(import.meta.dirname, "..", "auto.ts"), "utf-8");
7
8
  const phasesSrc = readFileSync(join(import.meta.dirname, "..", "auto", "phases.ts"), "utf-8");
@@ -20,7 +21,7 @@ test("stopAuto restores original thinking level", () => {
20
21
  test("runUnitPhase threads captured thinking level into selectAndApplyModel", () => {
21
22
  const callIdx = phasesSrc.indexOf("deps.selectAndApplyModel(");
22
23
  assert.ok(callIdx > -1, "phases.ts should call selectAndApplyModel");
23
- const callBlock = phasesSrc.slice(callIdx, callIdx + 600);
24
+ const callBlock = extractSourceRegion(phasesSrc, "deps.selectAndApplyModel(");
24
25
  assert.ok(
25
26
  callBlock.includes("s.autoModeStartThinkingLevel"),
26
27
  "runUnitPhase should pass autoModeStartThinkingLevel to selectAndApplyModel",
@@ -30,7 +31,7 @@ test("runUnitPhase threads captured thinking level into selectAndApplyModel", ()
30
31
  test("hook model override preserves captured thinking level", () => {
31
32
  const hookIdx = phasesSrc.indexOf("const hookModelOverride = sidecarItem?.model ?? iterData.hookModelOverride;");
32
33
  assert.ok(hookIdx > -1, "phases.ts should include hook model override handling");
33
- const hookBlock = phasesSrc.slice(hookIdx, hookIdx + 600);
34
+ const hookBlock = extractSourceRegion(phasesSrc, "const hookModelOverride = sidecarItem?.model ?? iterData.hookModelOverride;");
34
35
  assert.ok(
35
36
  hookBlock.includes("pi.setThinkingLevel(s.autoModeStartThinkingLevel)"),
36
37
  "hook model override should re-apply captured thinking level after setModel",
@@ -27,6 +27,7 @@ import { readFileSync } from "node:fs";
27
27
  import { join } from "node:path";
28
28
 
29
29
  import { buildFlatRateContext } from "../auto-model-selection.ts";
30
+ import { extractSourceRegion } from "./test-helpers.ts";
30
31
 
31
32
  // ─── Bug 2: this-binding regression ─────────────────────────────────────
32
33
 
@@ -69,7 +70,7 @@ test("isSamePath short-circuits ENOENT before logging a warning", () => {
69
70
  assert.ok(fnIdx !== -1, "isSamePath function exists");
70
71
 
71
72
  // Grab the function body (enough to cover the catch block).
72
- const fnBody = src.slice(fnIdx, fnIdx + 600);
73
+ const fnBody = extractSourceRegion(src, "function isSamePath", { fromIdx: fnIdx });
73
74
 
74
75
  const catchIdx = fnBody.indexOf("catch");
75
76
  assert.ok(catchIdx !== -1, "isSamePath has a catch block");
@@ -103,7 +104,7 @@ test("checkAutoStartAfterDiscuss guards DISCUSSION-MANIFEST.json unlink with exi
103
104
 
104
105
  // Everything from the comment to a short distance below should contain
105
106
  // the existsSync guard before the unlinkSync call.
106
- const block = src.slice(cleanupIdx, cleanupIdx + 400);
107
+ const block = extractSourceRegion(src, "remove discussion manifest after auto-start", { fromIdx: cleanupIdx });
107
108
 
108
109
  const existsIdx = block.indexOf("existsSync(manifestPath)");
109
110
  const unlinkIdx = block.indexOf("unlinkSync(manifestPath)");
@@ -144,3 +144,26 @@ describe("#3512: pauseAuto and stopAuto must flush queued follow-up messages", (
144
144
  );
145
145
  });
146
146
  });
147
+
148
+ describe("#4365: tool_execution_start hook must pass toolName to markToolStart", () => {
149
+ test("tool_execution_start handler passes event.toolName to markToolStart", () => {
150
+ // The tool_execution_start handler must forward toolName so that
151
+ // hasInteractiveToolInFlight() can correctly identify ask_user_questions
152
+ // and prevent the idle watchdog from firing during interactive tool calls.
153
+ const startMarker = 'pi.on("tool_execution_start", async (event) => {';
154
+ const endMarker = 'pi.on("tool_execution_end", async (event) => {';
155
+ const toolExecutionStartSection = registerHooksSrc.slice(
156
+ registerHooksSrc.indexOf(startMarker),
157
+ registerHooksSrc.indexOf(endMarker),
158
+ );
159
+
160
+ assert.ok(
161
+ toolExecutionStartSection.length > 0,
162
+ "Could not locate tool_execution_start handler section",
163
+ );
164
+ assert.ok(
165
+ toolExecutionStartSection.includes("markToolStart(event.toolCallId, event.toolName)"),
166
+ "tool_execution_start handler must pass event.toolName to markToolStart so hasInteractiveToolInFlight() works correctly",
167
+ );
168
+ });
169
+ });
@@ -2,6 +2,7 @@ import { describe, test } from "node:test";
2
2
  import assert from "node:assert/strict";
3
3
  import { readFileSync } from "node:fs";
4
4
  import { join } from "node:path";
5
+ import { extractSourceRegion } from "./test-helpers.ts";
5
6
 
6
7
  const systemContextSrc = readFileSync(
7
8
  join(import.meta.dirname, "..", "bootstrap", "system-context.ts"),
@@ -29,7 +30,7 @@ describe("bootstrap deriveState DB guards (#3844)", () => {
29
30
  test("register-hooks opens DB before deriveState in session_before_compact", () => {
30
31
  const compactIdx = registerHooksSrc.indexOf('pi.on("session_before_compact"');
31
32
  assert.ok(compactIdx > -1, "register-hooks should define session_before_compact");
32
- const compactSection = registerHooksSrc.slice(compactIdx, compactIdx + 1600);
33
+ const compactSection = extractSourceRegion(registerHooksSrc, 'pi.on("session_before_compact"');
33
34
  const ensureIdx = compactSection.indexOf("ensureDbOpen()");
34
35
  const deriveIdx = compactSection.indexOf("deriveState(basePath)");
35
36
  assert.ok(ensureIdx > -1, "session_before_compact should call ensureDbOpen()");
@@ -69,11 +69,11 @@ describe("cache-staleness-regression", () => {
69
69
  ].join('\n');
70
70
  writeMilestoneFile(base, 'M001', 'ROADMAP', roadmap);
71
71
 
72
- // Step 3: WITHOUT invalidation, the old state might be cached
73
- // The state cache has a 100ms TTL, so wait just past it
74
- await new Promise(r => setTimeout(r, 150));
75
-
76
- // Step 4: Invalidate and re-derive — should see the new roadmap
72
+ // Step 3: Explicit invalidation — this is the #1240 fix path. We
73
+ // do NOT rely on the 100ms TTL here; the production code calls
74
+ // invalidateAllCaches() / invalidateStateCache() immediately after
75
+ // writing planning files, so the next deriveState() must see the
76
+ // new roadmap without any wall-clock wait.
77
77
  invalidateAllCaches();
78
78
  invalidateStateCache();
79
79
  const state2 = await deriveState(base);
@@ -100,10 +100,8 @@ describe("cache-staleness-regression", () => {
100
100
  // Simulate: discussion completes, CONTEXT.md is written
101
101
  writeMilestoneFile(base, 'M001', 'CONTEXT', '# M001: Test\n\nFull context after discussion.\n');
102
102
 
103
- // Wait past TTL
104
- await new Promise(r => setTimeout(r, 150));
105
-
106
- // Without invalidation, we'd still see 'needs-discussion'
103
+ // Explicit invalidation is the production fix path for #1249 —
104
+ // no wall-clock wait needed.
107
105
  invalidateAllCaches();
108
106
  invalidateStateCache();
109
107
  const state2 = await deriveState(base);
@@ -116,7 +114,7 @@ describe("cache-staleness-regression", () => {
116
114
  }
117
115
  });
118
116
 
119
- test("state cache TTL: fresh reads after 100ms", async () => {
117
+ test("state cache TTL: within window returns cached; past window re-derives", async () => {
120
118
  const base = createBase();
121
119
  try {
122
120
  writeMilestoneFile(base, 'M001', 'CONTEXT', '# M001\n\nDesc.\n');
@@ -126,7 +124,7 @@ describe("cache-staleness-regression", () => {
126
124
  const state1 = await deriveState(base);
127
125
  assert.strictEqual(state1.phase, 'pre-planning', 'initial: pre-planning');
128
126
 
129
- // Write roadmap immediately
127
+ // Write roadmap immediately — no invalidation
130
128
  writeMilestoneFile(base, 'M001', 'ROADMAP', [
131
129
  '# M001: Test',
132
130
  '',
@@ -136,18 +134,19 @@ describe("cache-staleness-regression", () => {
136
134
  '',
137
135
  ].join('\n'));
138
136
 
139
- // Immediately after writing (within 100ms TTL), the cache might be stale
137
+ // Within the TTL window, deriveState() must return the cached
138
+ // pre-planning state — this is the "cached" half of the TTL
139
+ // contract and the reason invalidateStateCache() exists.
140
140
  const state2 = await deriveState(base);
141
- // This MAY still show pre-planning if within TTL that's expected behavior
141
+ assert.strictEqual(state2.phase, 'pre-planning', 'within TTL: cached pre-planning is returned');
142
142
 
143
- // Wait past TTL
143
+ // Past the TTL + explicit parse-cache flush, the fresh derive must
144
+ // see the new roadmap. invalidateAllCaches() is required because
145
+ // the file-parse cache is independent of the state TTL.
144
146
  await new Promise(r => setTimeout(r, 150));
145
-
146
- // ALSO invalidate parse cache (not just state cache)
147
147
  invalidateAllCaches();
148
- invalidateStateCache();
149
148
  const state3 = await deriveState(base);
150
- assert.strictEqual(state3.phase, 'planning', 'after TTL expiry + invalidation → planning');
149
+ assert.strictEqual(state3.phase, 'planning', 'past TTL: re-derive sees new roadmap');
151
150
  } finally {
152
151
  cleanup(base);
153
152
  }
@@ -194,7 +193,6 @@ describe("cache-staleness-regression", () => {
194
193
  '- [ ] **T02: Second Task** `est:1h`',
195
194
  ].join('\n'));
196
195
 
197
- await new Promise(r => setTimeout(r, 150));
198
196
  invalidateAllCaches();
199
197
  invalidateStateCache();
200
198
  const state2 = await deriveState(base);
@@ -242,7 +240,6 @@ describe("cache-staleness-regression", () => {
242
240
  '- [x] **T01: Task** `est:1h`',
243
241
  ].join('\n'));
244
242
 
245
- await new Promise(r => setTimeout(r, 150));
246
243
  invalidateAllCaches();
247
244
  invalidateStateCache();
248
245
  const state2 = await deriveState(base);
@@ -282,7 +279,6 @@ describe("cache-staleness-regression", () => {
282
279
  '',
283
280
  ].join('\n'));
284
281
 
285
- await new Promise(r => setTimeout(r, 150));
286
282
  invalidateAllCaches();
287
283
  invalidateStateCache();
288
284
  const state2 = await deriveState(base);
@@ -0,0 +1,108 @@
1
+ /**
2
+ * Tests for resolveCanonicalMilestoneRoot — the worktree-aware reader
3
+ * that fixes #4761 (worktree work stranded when auto-loop exits without
4
+ * milestone completion).
5
+ *
6
+ * Contract: given (basePath, milestoneId), return the worktree path if a
7
+ * live git worktree exists for that milestone at .gsd/worktrees/<MID>/;
8
+ * otherwise return basePath unchanged. A live worktree has a .git file
9
+ * (not directory) — a bare directory without .git is a stale leftover.
10
+ */
11
+
12
+ import test from "node:test";
13
+ import assert from "node:assert/strict";
14
+ import { mkdirSync, writeFileSync, rmSync } from "node:fs";
15
+ import { join } from "node:path";
16
+ import { tmpdir } from "node:os";
17
+ import { randomUUID } from "node:crypto";
18
+
19
+ import { resolveCanonicalMilestoneRoot } from "../worktree-manager.ts";
20
+
21
+ function makeTmpBase(): string {
22
+ const base = join(tmpdir(), `gsd-canon-test-${randomUUID()}`);
23
+ mkdirSync(join(base, ".gsd", "milestones"), { recursive: true });
24
+ return base;
25
+ }
26
+
27
+ function cleanup(base: string): void {
28
+ try { rmSync(base, { recursive: true, force: true }); } catch { /* */ }
29
+ }
30
+
31
+ /**
32
+ * Create a worktree directory shape that looks live: the .gsd/worktrees/<MID>/
33
+ * directory with a .git file containing a gitdir: pointer. We don't need a
34
+ * real git worktree — the resolver only checks for the .git file's presence.
35
+ */
36
+ function makeLiveWorktree(base: string, mid: string): string {
37
+ const wtPath = join(base, ".gsd", "worktrees", mid);
38
+ mkdirSync(wtPath, { recursive: true });
39
+ writeFileSync(
40
+ join(wtPath, ".git"),
41
+ `gitdir: ${join(base, ".git", "worktrees", mid)}\n`,
42
+ );
43
+ return wtPath;
44
+ }
45
+
46
+ function makeStaleWorktree(base: string, mid: string): string {
47
+ const wtPath = join(base, ".gsd", "worktrees", mid);
48
+ mkdirSync(wtPath, { recursive: true });
49
+ // No .git file — this is the stale-leftover shape createWorktree() sees
50
+ // and cleans up.
51
+ return wtPath;
52
+ }
53
+
54
+ test("returns worktree path when a live worktree exists for the milestone", () => {
55
+ const base = makeTmpBase();
56
+ try {
57
+ const wtPath = makeLiveWorktree(base, "M001");
58
+ const result = resolveCanonicalMilestoneRoot(base, "M001");
59
+ assert.equal(result, wtPath);
60
+ } finally {
61
+ cleanup(base);
62
+ }
63
+ });
64
+
65
+ test("returns basePath when no worktree directory exists", () => {
66
+ const base = makeTmpBase();
67
+ try {
68
+ const result = resolveCanonicalMilestoneRoot(base, "M001");
69
+ assert.equal(result, base);
70
+ } finally {
71
+ cleanup(base);
72
+ }
73
+ });
74
+
75
+ test("returns basePath when worktree directory exists but has no .git file (stale)", () => {
76
+ const base = makeTmpBase();
77
+ try {
78
+ makeStaleWorktree(base, "M001");
79
+ const result = resolveCanonicalMilestoneRoot(base, "M001");
80
+ assert.equal(result, base);
81
+ } finally {
82
+ cleanup(base);
83
+ }
84
+ });
85
+
86
+ test("returns basePath for invalid milestoneId (path separators)", () => {
87
+ const base = makeTmpBase();
88
+ try {
89
+ // Even if a worktree coincidentally exists, the guard should reject.
90
+ assert.equal(resolveCanonicalMilestoneRoot(base, "../evil"), base);
91
+ assert.equal(resolveCanonicalMilestoneRoot(base, "M001/subdir"), base);
92
+ assert.equal(resolveCanonicalMilestoneRoot(base, "M001\\subdir"), base);
93
+ assert.equal(resolveCanonicalMilestoneRoot(base, ""), base);
94
+ } finally {
95
+ cleanup(base);
96
+ }
97
+ });
98
+
99
+ test("only returns the worktree for the requested milestone, not siblings", () => {
100
+ const base = makeTmpBase();
101
+ try {
102
+ makeLiveWorktree(base, "M001");
103
+ const result = resolveCanonicalMilestoneRoot(base, "M002");
104
+ assert.equal(result, base, "M002 has no worktree → basePath");
105
+ } finally {
106
+ cleanup(base);
107
+ }
108
+ });