gsd-pi 2.79.0 → 2.80.0-dev.b62439b9f

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 (735) hide show
  1. package/README.md +94 -47
  2. package/dist/{cli-web-branch.d.ts → cli/cli-web-branch.d.ts} +1 -1
  3. package/dist/{cli-web-branch.js → cli/cli-web-branch.js} +3 -3
  4. package/dist/{cli.js → cli/cli.js} +25 -25
  5. package/dist/{web-mode.js → cli/web-mode.js} +3 -3
  6. package/dist/{extension-registry.js → extension-runtime/extension-registry.js} +1 -1
  7. package/dist/{headless-query.d.ts → headless/headless-query.d.ts} +1 -1
  8. package/dist/{headless-query.js → headless/headless-query.js} +3 -2
  9. package/dist/{headless-recover.js → headless/headless-recover.js} +3 -2
  10. package/dist/{headless.js → headless/headless.js} +3 -3
  11. package/dist/loader.js +10 -10
  12. package/dist/{onboarding.js → onboarding/onboarding.js} +8 -8
  13. package/dist/{welcome-screen.js → onboarding/welcome-screen.js} +1 -1
  14. package/dist/{models-resolver.js → providers/models-resolver.js} +1 -1
  15. package/dist/{remote-questions-config.js → providers/remote-questions-config.js} +1 -1
  16. package/dist/{resource-loader.d.ts → resource-runtime/resource-loader.d.ts} +1 -1
  17. package/dist/{resource-loader.js → resource-runtime/resource-loader.js} +6 -6
  18. package/dist/resources/.managed-resources-content-hash +1 -1
  19. package/dist/resources/extensions/github-sync/templates.js +55 -70
  20. package/dist/resources/extensions/gsd/auto/contracts.js +1 -0
  21. package/dist/resources/extensions/gsd/auto/custom-verify-retry-store.js +53 -0
  22. package/dist/resources/extensions/gsd/auto/loop.js +362 -523
  23. package/dist/resources/extensions/gsd/auto/orchestrator.js +146 -0
  24. package/dist/resources/extensions/gsd/auto/phases.js +61 -7
  25. package/dist/resources/extensions/gsd/auto/session.js +8 -0
  26. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-dispatch-outcome.js +12 -0
  27. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-iteration.js +24 -0
  28. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-reconcile-outcome.js +33 -0
  29. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-reconcile.js +26 -0
  30. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-retry.js +49 -0
  31. package/dist/resources/extensions/gsd/auto/workflow-custom-engine-verify-outcome.js +25 -0
  32. package/dist/resources/extensions/gsd/auto/workflow-dispatch-claim.js +48 -0
  33. package/dist/resources/extensions/gsd/auto/workflow-dispatch-ledger.js +26 -0
  34. package/dist/resources/extensions/gsd/auto/workflow-iteration-completion.js +10 -0
  35. package/dist/resources/extensions/gsd/auto/workflow-journal-reporter.js +16 -0
  36. package/dist/resources/extensions/gsd/auto/workflow-kernel.js +263 -0
  37. package/dist/resources/extensions/gsd/auto/workflow-memory-pressure.js +36 -0
  38. package/dist/resources/extensions/gsd/auto/workflow-phase-reporter.js +9 -0
  39. package/dist/resources/extensions/gsd/auto/workflow-session-lock.js +35 -0
  40. package/dist/resources/extensions/gsd/auto/workflow-sidecar-iteration.js +24 -0
  41. package/dist/resources/extensions/gsd/auto/workflow-sidecar-queue.js +26 -0
  42. package/dist/resources/extensions/gsd/auto/workflow-turn-reporter.js +36 -0
  43. package/dist/resources/extensions/gsd/auto/workflow-unit-dispatch.js +44 -0
  44. package/dist/resources/extensions/gsd/auto/workflow-worker-heartbeat.js +15 -0
  45. package/dist/resources/extensions/gsd/auto-artifact-paths.js +2 -2
  46. package/dist/resources/extensions/gsd/auto-dashboard.js +3 -0
  47. package/dist/resources/extensions/gsd/auto-dispatch.js +2 -0
  48. package/dist/resources/extensions/gsd/auto-prompts.js +220 -32
  49. package/dist/resources/extensions/gsd/auto-recovery.js +63 -55
  50. package/dist/resources/extensions/gsd/auto-runtime-state.js +4 -0
  51. package/dist/resources/extensions/gsd/auto-start.js +3 -2
  52. package/dist/resources/extensions/gsd/auto-verification.js +2 -11
  53. package/dist/resources/extensions/gsd/auto-worktree.js +85 -38
  54. package/dist/resources/extensions/gsd/auto.js +162 -5
  55. package/dist/resources/extensions/gsd/bootstrap/agent-end-recovery.js +9 -1
  56. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +10 -0
  57. package/dist/resources/extensions/gsd/bootstrap/exec-tools.js +2 -2
  58. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +52 -50
  59. package/dist/resources/extensions/gsd/bootstrap/write-gate.js +8 -8
  60. package/dist/resources/extensions/gsd/commands/context.js +1 -1
  61. package/dist/resources/extensions/gsd/commands-ship.js +23 -46
  62. package/dist/resources/extensions/gsd/commands-workflow-templates.js +12 -7
  63. package/dist/resources/extensions/gsd/component-loader.js +5 -11
  64. package/dist/resources/extensions/gsd/custom-workflow-engine.js +25 -1
  65. package/dist/resources/extensions/gsd/db-adapter.js +47 -0
  66. package/dist/resources/extensions/gsd/db-base-schema.js +337 -0
  67. package/dist/resources/extensions/gsd/db-connection-cache.js +31 -0
  68. package/dist/resources/extensions/gsd/db-coordination-schema.js +104 -0
  69. package/dist/resources/extensions/gsd/db-decision-requirement-rows.js +71 -0
  70. package/dist/resources/extensions/gsd/db-gate-rows.js +16 -0
  71. package/dist/resources/extensions/gsd/db-lightweight-query-rows.js +29 -0
  72. package/dist/resources/extensions/gsd/db-memory-fts-schema.js +56 -0
  73. package/dist/resources/extensions/gsd/db-migration-backup.js +22 -0
  74. package/dist/resources/extensions/gsd/db-migration-steps.js +394 -0
  75. package/dist/resources/extensions/gsd/db-milestone-artifact-rows.js +35 -0
  76. package/dist/resources/extensions/gsd/db-open-state.js +32 -0
  77. package/dist/resources/extensions/gsd/db-provider.js +108 -0
  78. package/dist/resources/extensions/gsd/db-runtime-kv-schema.js +27 -0
  79. package/dist/resources/extensions/gsd/db-schema-metadata.js +23 -0
  80. package/dist/resources/extensions/gsd/db-task-slice-rows.js +86 -0
  81. package/dist/resources/extensions/gsd/db-transaction.js +63 -0
  82. package/dist/resources/extensions/gsd/db-verification-evidence-rows.js +3 -0
  83. package/dist/resources/extensions/gsd/db-verification-evidence-schema.js +19 -0
  84. package/dist/resources/extensions/gsd/escalation.js +2 -0
  85. package/dist/resources/extensions/gsd/graph.js +9 -3
  86. package/dist/resources/extensions/gsd/gsd-db.js +215 -1519
  87. package/dist/resources/extensions/gsd/guided-flow.js +40 -0
  88. package/dist/resources/extensions/gsd/legacy-telemetry.js +70 -0
  89. package/dist/resources/extensions/gsd/markdown-renderer.js +2 -0
  90. package/dist/resources/extensions/gsd/model-router.js +9 -6
  91. package/dist/resources/extensions/gsd/notification-widget.js +21 -3
  92. package/dist/resources/extensions/gsd/paths.js +5 -1
  93. package/dist/resources/extensions/gsd/post-execution-checks.js +27 -6
  94. package/dist/resources/extensions/gsd/pr-evidence.js +76 -0
  95. package/dist/resources/extensions/gsd/pre-execution-checks.js +2 -0
  96. package/dist/resources/extensions/gsd/preferences-types.js +20 -2
  97. package/dist/resources/extensions/gsd/preferences-validation.js +3 -3
  98. package/dist/resources/extensions/gsd/process-task-path.js +61 -0
  99. package/dist/resources/extensions/gsd/prompt-loader.js +9 -5
  100. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +32 -30
  101. package/dist/resources/extensions/gsd/prompts/complete-slice.md +23 -34
  102. package/dist/resources/extensions/gsd/prompts/discuss-headless.md +50 -96
  103. package/dist/resources/extensions/gsd/prompts/discuss.md +81 -181
  104. package/dist/resources/extensions/gsd/prompts/execute-task.md +40 -67
  105. package/dist/resources/extensions/gsd/prompts/forensics.md +41 -84
  106. package/dist/resources/extensions/gsd/prompts/guided-discuss-milestone.md +29 -39
  107. package/dist/resources/extensions/gsd/prompts/guided-discuss-project.md +30 -65
  108. package/dist/resources/extensions/gsd/prompts/guided-discuss-requirements.md +25 -52
  109. package/dist/resources/extensions/gsd/prompts/guided-discuss-slice.md +36 -36
  110. package/dist/resources/extensions/gsd/prompts/guided-research-project.md +20 -38
  111. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +45 -59
  112. package/dist/resources/extensions/gsd/prompts/plan-slice.md +25 -87
  113. package/dist/resources/extensions/gsd/prompts/queue.md +46 -53
  114. package/dist/resources/extensions/gsd/prompts/refine-slice.md +23 -23
  115. package/dist/resources/extensions/gsd/prompts/research-slice.md +23 -23
  116. package/dist/resources/extensions/gsd/prompts/rethink.md +10 -10
  117. package/dist/resources/extensions/gsd/prompts/system.md +65 -107
  118. package/dist/resources/extensions/gsd/prompts/triage-captures.md +15 -15
  119. package/dist/resources/extensions/gsd/prompts/validate-milestone.md +24 -24
  120. package/dist/resources/extensions/gsd/prompts/worktree-merge.md +35 -35
  121. package/dist/resources/extensions/gsd/state.js +4 -0
  122. package/dist/resources/extensions/gsd/tools/complete-milestone.js +14 -9
  123. package/dist/resources/extensions/gsd/tools/complete-task.js +2 -0
  124. package/dist/resources/extensions/gsd/tools/workflow-tool-executors.js +88 -3
  125. package/dist/resources/extensions/gsd/unit-context-composer.js +32 -0
  126. package/dist/resources/extensions/gsd/unit-context-manifest.js +21 -0
  127. package/dist/resources/extensions/gsd/uok/audit.js +23 -9
  128. package/dist/resources/extensions/gsd/uok/contracts.js +69 -1
  129. package/dist/resources/extensions/gsd/uok/dispatch-envelope.js +3 -0
  130. package/dist/resources/extensions/gsd/uok/kernel.js +8 -3
  131. package/dist/resources/extensions/gsd/uok/loop-adapter.js +48 -33
  132. package/dist/resources/extensions/gsd/uok/plan-v2.js +2 -0
  133. package/dist/resources/extensions/gsd/uok/timeline.js +125 -0
  134. package/dist/resources/extensions/gsd/workflow-logger.js +13 -13
  135. package/dist/resources/extensions/gsd/workflow-manifest.js +2 -0
  136. package/dist/resources/extensions/gsd/workflow-projections.js +2 -0
  137. package/dist/resources/extensions/gsd/workflow-templates.js +9 -0
  138. package/dist/resources/extensions/shared/gsd-phase-state.js +45 -3
  139. package/dist/resources/extensions/shared/interview-ui.js +15 -4
  140. package/dist/{security-overrides.js → security/security-overrides.js} +1 -1
  141. package/dist/{startup-model-validation.js → startup/startup-model-validation.js} +1 -1
  142. package/dist/tsconfig.extensions.tsbuildinfo +1 -1
  143. package/dist/{update-check.js → update/update-check.js} +1 -1
  144. package/dist/web/standalone/.next/BUILD_ID +1 -1
  145. package/dist/web/standalone/.next/app-path-routes-manifest.json +12 -12
  146. package/dist/web/standalone/.next/build-manifest.json +3 -3
  147. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  148. package/dist/web/standalone/.next/required-server-files.json +4 -4
  149. package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
  150. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  151. package/dist/web/standalone/.next/server/app/_global-error.html +1 -1
  152. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  153. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  154. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  155. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  156. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  157. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  158. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  159. package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
  160. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  161. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  162. package/dist/web/standalone/.next/server/app/_not-found.rsc +3 -3
  163. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  164. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  165. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  166. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  167. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  168. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  169. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  170. package/dist/web/standalone/.next/server/app/api/boot/route.js.nft.json +1 -1
  171. package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
  172. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  173. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js.nft.json +1 -1
  174. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
  175. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  176. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js.nft.json +1 -1
  177. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
  178. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
  179. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js.nft.json +1 -1
  180. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
  181. package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
  182. package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
  183. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  184. package/dist/web/standalone/.next/server/app/api/captures/route.js.nft.json +1 -1
  185. package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
  186. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  187. package/dist/web/standalone/.next/server/app/api/cleanup/route.js.nft.json +1 -1
  188. package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
  189. package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
  190. package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
  191. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  192. package/dist/web/standalone/.next/server/app/api/doctor/route.js.nft.json +1 -1
  193. package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
  194. package/dist/web/standalone/.next/server/app/api/experimental/route.js +2 -2
  195. package/dist/web/standalone/.next/server/app/api/experimental/route_client-reference-manifest.js +1 -1
  196. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  197. package/dist/web/standalone/.next/server/app/api/export-data/route.js.nft.json +1 -1
  198. package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
  199. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  200. package/dist/web/standalone/.next/server/app/api/files/route.js.nft.json +1 -1
  201. package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
  202. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  203. package/dist/web/standalone/.next/server/app/api/forensics/route.js.nft.json +1 -1
  204. package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
  205. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  206. package/dist/web/standalone/.next/server/app/api/git/route.js.nft.json +1 -1
  207. package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
  208. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  209. package/dist/web/standalone/.next/server/app/api/history/route.js.nft.json +1 -1
  210. package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
  211. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  212. package/dist/web/standalone/.next/server/app/api/hooks/route.js.nft.json +1 -1
  213. package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
  214. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  215. package/dist/web/standalone/.next/server/app/api/inspect/route.js.nft.json +1 -1
  216. package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
  217. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  218. package/dist/web/standalone/.next/server/app/api/knowledge/route.js.nft.json +1 -1
  219. package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
  220. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  221. package/dist/web/standalone/.next/server/app/api/live-state/route.js.nft.json +1 -1
  222. package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
  223. package/dist/web/standalone/.next/server/app/api/notifications/route.js +2 -2
  224. package/dist/web/standalone/.next/server/app/api/notifications/route.js.nft.json +1 -1
  225. package/dist/web/standalone/.next/server/app/api/notifications/route_client-reference-manifest.js +1 -1
  226. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  227. package/dist/web/standalone/.next/server/app/api/onboarding/route.js.nft.json +1 -1
  228. package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
  229. package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
  230. package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
  231. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  232. package/dist/web/standalone/.next/server/app/api/projects/route.js.nft.json +1 -1
  233. package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
  234. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  235. package/dist/web/standalone/.next/server/app/api/recovery/route.js.nft.json +1 -1
  236. package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
  237. package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +2 -2
  238. package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
  239. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  240. package/dist/web/standalone/.next/server/app/api/session/browser/route.js.nft.json +1 -1
  241. package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
  242. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  243. package/dist/web/standalone/.next/server/app/api/session/command/route.js.nft.json +1 -1
  244. package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
  245. package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
  246. package/dist/web/standalone/.next/server/app/api/session/events/route.js.nft.json +1 -1
  247. package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
  248. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  249. package/dist/web/standalone/.next/server/app/api/session/manage/route.js.nft.json +1 -1
  250. package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
  251. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  252. package/dist/web/standalone/.next/server/app/api/settings-data/route.js.nft.json +1 -1
  253. package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
  254. package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
  255. package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  256. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  257. package/dist/web/standalone/.next/server/app/api/skill-health/route.js.nft.json +1 -1
  258. package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
  259. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  260. package/dist/web/standalone/.next/server/app/api/steer/route.js.nft.json +1 -1
  261. package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
  262. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -1
  263. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -1
  264. package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
  265. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +2 -2
  266. package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
  267. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
  268. package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
  269. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
  270. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js.nft.json +1 -1
  271. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
  272. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +3 -3
  273. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js.nft.json +1 -1
  274. package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
  275. package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
  276. package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
  277. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  278. package/dist/web/standalone/.next/server/app/api/undo/route.js.nft.json +1 -1
  279. package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
  280. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  281. package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
  282. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  283. package/dist/web/standalone/.next/server/app/api/visualizer/route.js.nft.json +1 -1
  284. package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
  285. package/dist/web/standalone/.next/server/app/index.html +1 -1
  286. package/dist/web/standalone/.next/server/app/index.rsc +4 -4
  287. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  288. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
  289. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  290. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +3 -3
  291. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  292. package/dist/web/standalone/.next/server/app/page.js +2 -2
  293. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  294. package/dist/web/standalone/.next/server/app-paths-manifest.json +12 -12
  295. package/dist/web/standalone/.next/server/chunks/167.js +2 -0
  296. package/dist/web/standalone/.next/server/chunks/63.js +3 -3
  297. package/dist/web/standalone/.next/server/chunks/7020.js +12 -0
  298. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  299. package/dist/web/standalone/.next/server/middleware.js +2 -2
  300. package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
  301. package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
  302. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  303. package/dist/web/standalone/.next/server/pages/500.html +1 -1
  304. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  305. package/dist/web/standalone/.next/static/chunks/app/_not-found/{page-2f24283c162b6ab3.js → page-f2a7482d42a5614b.js} +1 -1
  306. package/dist/web/standalone/.next/static/chunks/app/{layout-9ecfd95f343793f0.js → layout-a16c7a7ecdf0c2cf.js} +1 -1
  307. package/dist/web/standalone/.next/static/chunks/app/page-fab3ebb85b006001.js +1 -0
  308. package/dist/web/standalone/.next/static/chunks/main-app-fdab67f7802d7832.js +1 -0
  309. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
  310. package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
  311. package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
  312. package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
  313. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
  314. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
  315. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
  316. package/dist/web/standalone/package.json +1 -0
  317. package/dist/web/standalone/server.js +1 -1
  318. package/dist/{worktree-cli.js → worktrees/worktree-cli.js} +3 -2
  319. package/package.json +12 -5
  320. package/packages/contracts/dist/index.d.ts +3 -0
  321. package/packages/contracts/dist/index.d.ts.map +1 -0
  322. package/packages/contracts/dist/index.js +5 -0
  323. package/packages/contracts/dist/index.js.map +1 -0
  324. package/packages/contracts/dist/rpc.d.ts +549 -0
  325. package/packages/contracts/dist/rpc.d.ts.map +1 -0
  326. package/packages/contracts/dist/rpc.js +53 -0
  327. package/packages/contracts/dist/rpc.js.map +1 -0
  328. package/packages/contracts/dist/rpc.test.d.ts +2 -0
  329. package/packages/contracts/dist/rpc.test.d.ts.map +1 -0
  330. package/packages/contracts/dist/rpc.test.js +47 -0
  331. package/packages/contracts/dist/rpc.test.js.map +1 -0
  332. package/packages/contracts/dist/workflow.d.ts +180 -0
  333. package/packages/contracts/dist/workflow.d.ts.map +1 -0
  334. package/packages/contracts/dist/workflow.js +201 -0
  335. package/packages/contracts/dist/workflow.js.map +1 -0
  336. package/packages/contracts/package.json +39 -0
  337. package/packages/contracts/src/index.ts +5 -0
  338. package/packages/contracts/src/rpc.test.ts +72 -0
  339. package/packages/contracts/src/rpc.ts +286 -0
  340. package/packages/contracts/src/workflow.ts +213 -0
  341. package/packages/contracts/tsconfig.json +25 -0
  342. package/packages/daemon/package.json +3 -2
  343. package/packages/daemon/src/event-bridge.test.ts +2 -1
  344. package/packages/daemon/src/event-bridge.ts +1 -1
  345. package/packages/daemon/src/event-formatter.test.ts +1 -2
  346. package/packages/daemon/src/event-formatter.ts +1 -2
  347. package/packages/daemon/src/session-manager.ts +2 -2
  348. package/packages/daemon/src/types.ts +3 -18
  349. package/packages/mcp-server/dist/server.d.ts +13 -0
  350. package/packages/mcp-server/dist/server.d.ts.map +1 -1
  351. package/packages/mcp-server/dist/server.js +77 -0
  352. package/packages/mcp-server/dist/server.js.map +1 -1
  353. package/packages/mcp-server/dist/session-manager.js +1 -1
  354. package/packages/mcp-server/dist/session-manager.js.map +1 -1
  355. package/packages/mcp-server/dist/types.d.ts +3 -11
  356. package/packages/mcp-server/dist/types.d.ts.map +1 -1
  357. package/packages/mcp-server/dist/types.js.map +1 -1
  358. package/packages/mcp-server/dist/workflow-tools.d.ts +1 -1
  359. package/packages/mcp-server/dist/workflow-tools.d.ts.map +1 -1
  360. package/packages/mcp-server/dist/workflow-tools.js +52 -37
  361. package/packages/mcp-server/dist/workflow-tools.js.map +1 -1
  362. package/packages/mcp-server/package.json +3 -2
  363. package/packages/mcp-server/src/mcp-server.test.ts +138 -0
  364. package/packages/mcp-server/src/server.ts +99 -1
  365. package/packages/mcp-server/src/session-manager.ts +2 -2
  366. package/packages/mcp-server/src/types.ts +7 -18
  367. package/packages/mcp-server/src/workflow-tools.test.ts +129 -2
  368. package/packages/mcp-server/src/workflow-tools.ts +80 -37
  369. package/packages/mcp-server/tsconfig.tsbuildinfo +1 -1
  370. package/packages/native/package.json +1 -1
  371. package/packages/pi-agent-core/package.json +1 -1
  372. package/packages/pi-ai/package.json +1 -1
  373. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js +14 -0
  374. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/tool-execution.test.js.map +1 -1
  375. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js +20 -0
  376. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.js.map +1 -1
  377. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  378. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +6 -1
  379. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  380. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts +9 -1
  381. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  382. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +31 -10
  383. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  384. package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.d.ts +1 -512
  385. package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.d.ts.map +1 -1
  386. package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.js +3 -7
  387. package/packages/pi-coding-agent/dist/modes/rpc/rpc-types.js.map +1 -1
  388. package/packages/pi-coding-agent/package.json +2 -1
  389. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/tool-execution.test.ts +23 -2
  390. package/packages/pi-coding-agent/src/modes/interactive/components/tool-card-cleanup-and-success-runtime.test.ts +31 -0
  391. package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +6 -1
  392. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +50 -9
  393. package/packages/pi-coding-agent/src/modes/rpc/rpc-types.ts +3 -336
  394. package/packages/pi-coding-agent/tsconfig.tsbuildinfo +1 -1
  395. package/packages/pi-tui/dist/__tests__/tui.test.js +25 -3
  396. package/packages/pi-tui/dist/__tests__/tui.test.js.map +1 -1
  397. package/packages/pi-tui/dist/tui.d.ts +3 -1
  398. package/packages/pi-tui/dist/tui.d.ts.map +1 -1
  399. package/packages/pi-tui/dist/tui.js +3 -1
  400. package/packages/pi-tui/dist/tui.js.map +1 -1
  401. package/packages/pi-tui/package.json +1 -1
  402. package/packages/pi-tui/src/__tests__/tui.test.ts +30 -3
  403. package/packages/pi-tui/src/tui.ts +3 -1
  404. package/packages/pi-tui/tsconfig.tsbuildinfo +1 -1
  405. package/packages/rpc-client/README.md +3 -3
  406. package/packages/rpc-client/dist/index.d.ts +1 -1
  407. package/packages/rpc-client/dist/index.d.ts.map +1 -1
  408. package/packages/rpc-client/dist/index.js.map +1 -1
  409. package/packages/rpc-client/dist/rpc-client.d.ts +2 -6
  410. package/packages/rpc-client/dist/rpc-client.d.ts.map +1 -1
  411. package/packages/rpc-client/dist/rpc-client.js.map +1 -1
  412. package/packages/rpc-client/dist/rpc-types.d.ts +1 -565
  413. package/packages/rpc-client/dist/rpc-types.d.ts.map +1 -1
  414. package/packages/rpc-client/dist/rpc-types.js +3 -11
  415. package/packages/rpc-client/dist/rpc-types.js.map +1 -1
  416. package/packages/rpc-client/package.json +4 -1
  417. package/packages/rpc-client/src/index.ts +1 -1
  418. package/packages/rpc-client/src/rpc-client.ts +3 -6
  419. package/packages/rpc-client/src/rpc-types.ts +3 -398
  420. package/packages/rpc-client/tsconfig.tsbuildinfo +1 -1
  421. package/pkg/package.json +1 -1
  422. package/src/resources/extensions/github-sync/templates.ts +59 -84
  423. package/src/resources/extensions/github-sync/tests/templates.test.ts +10 -2
  424. package/src/resources/extensions/gsd/auto/contracts.ts +87 -0
  425. package/src/resources/extensions/gsd/auto/custom-verify-retry-store.ts +72 -0
  426. package/src/resources/extensions/gsd/auto/loop-deps.ts +10 -3
  427. package/src/resources/extensions/gsd/auto/loop.ts +414 -598
  428. package/src/resources/extensions/gsd/auto/orchestrator.ts +161 -0
  429. package/src/resources/extensions/gsd/auto/phases.ts +88 -9
  430. package/src/resources/extensions/gsd/auto/session.ts +11 -0
  431. package/src/resources/extensions/gsd/auto/workflow-custom-engine-dispatch-outcome.ts +28 -0
  432. package/src/resources/extensions/gsd/auto/workflow-custom-engine-iteration.ts +52 -0
  433. package/src/resources/extensions/gsd/auto/workflow-custom-engine-reconcile-outcome.ts +58 -0
  434. package/src/resources/extensions/gsd/auto/workflow-custom-engine-reconcile.ts +71 -0
  435. package/src/resources/extensions/gsd/auto/workflow-custom-engine-retry.ts +90 -0
  436. package/src/resources/extensions/gsd/auto/workflow-custom-engine-verify-outcome.ts +50 -0
  437. package/src/resources/extensions/gsd/auto/workflow-dispatch-claim.ts +97 -0
  438. package/src/resources/extensions/gsd/auto/workflow-dispatch-ledger.ts +45 -0
  439. package/src/resources/extensions/gsd/auto/workflow-iteration-completion.ts +26 -0
  440. package/src/resources/extensions/gsd/auto/workflow-journal-reporter.ts +33 -0
  441. package/src/resources/extensions/gsd/auto/workflow-kernel.ts +520 -0
  442. package/src/resources/extensions/gsd/auto/workflow-memory-pressure.ts +58 -0
  443. package/src/resources/extensions/gsd/auto/workflow-phase-reporter.ts +22 -0
  444. package/src/resources/extensions/gsd/auto/workflow-session-lock.ts +68 -0
  445. package/src/resources/extensions/gsd/auto/workflow-sidecar-iteration.ts +46 -0
  446. package/src/resources/extensions/gsd/auto/workflow-sidecar-queue.ts +46 -0
  447. package/src/resources/extensions/gsd/auto/workflow-turn-reporter.ts +68 -0
  448. package/src/resources/extensions/gsd/auto/workflow-unit-dispatch.ts +89 -0
  449. package/src/resources/extensions/gsd/auto/workflow-worker-heartbeat.ts +38 -0
  450. package/src/resources/extensions/gsd/auto-artifact-paths.ts +2 -2
  451. package/src/resources/extensions/gsd/auto-dashboard.ts +4 -0
  452. package/src/resources/extensions/gsd/auto-dispatch.ts +1 -0
  453. package/src/resources/extensions/gsd/auto-prompts.ts +276 -31
  454. package/src/resources/extensions/gsd/auto-recovery.ts +59 -53
  455. package/src/resources/extensions/gsd/auto-runtime-state.ts +7 -0
  456. package/src/resources/extensions/gsd/auto-start.ts +3 -2
  457. package/src/resources/extensions/gsd/auto-verification.ts +5 -1
  458. package/src/resources/extensions/gsd/auto-worktree.ts +83 -36
  459. package/src/resources/extensions/gsd/auto.ts +170 -4
  460. package/src/resources/extensions/gsd/bootstrap/agent-end-recovery.ts +14 -1
  461. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +11 -0
  462. package/src/resources/extensions/gsd/bootstrap/exec-tools.ts +2 -2
  463. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +62 -51
  464. package/src/resources/extensions/gsd/bootstrap/tests/write-gate-shouldblock-basepath.test.ts +97 -0
  465. package/src/resources/extensions/gsd/bootstrap/write-gate.ts +8 -4
  466. package/src/resources/extensions/gsd/commands/context.ts +1 -1
  467. package/src/resources/extensions/gsd/commands-ship.ts +24 -51
  468. package/src/resources/extensions/gsd/commands-workflow-templates.ts +13 -0
  469. package/src/resources/extensions/gsd/component-loader.ts +5 -11
  470. package/src/resources/extensions/gsd/custom-workflow-engine.ts +29 -0
  471. package/src/resources/extensions/gsd/db-adapter.ts +75 -0
  472. package/src/resources/extensions/gsd/db-base-schema.ts +368 -0
  473. package/src/resources/extensions/gsd/db-connection-cache.ts +45 -0
  474. package/src/resources/extensions/gsd/db-coordination-schema.ts +109 -0
  475. package/src/resources/extensions/gsd/db-decision-requirement-rows.ts +77 -0
  476. package/src/resources/extensions/gsd/db-gate-rows.ts +19 -0
  477. package/src/resources/extensions/gsd/db-lightweight-query-rows.ts +50 -0
  478. package/src/resources/extensions/gsd/db-memory-fts-schema.ts +66 -0
  479. package/src/resources/extensions/gsd/db-migration-backup.ts +34 -0
  480. package/src/resources/extensions/gsd/db-migration-steps.ts +434 -0
  481. package/src/resources/extensions/gsd/db-milestone-artifact-rows.ts +70 -0
  482. package/src/resources/extensions/gsd/db-open-state.ts +47 -0
  483. package/src/resources/extensions/gsd/db-provider.ts +148 -0
  484. package/src/resources/extensions/gsd/db-runtime-kv-schema.ts +30 -0
  485. package/src/resources/extensions/gsd/db-schema-metadata.ts +33 -0
  486. package/src/resources/extensions/gsd/db-task-slice-rows.ts +146 -0
  487. package/src/resources/extensions/gsd/db-transaction.ts +76 -0
  488. package/src/resources/extensions/gsd/db-verification-evidence-rows.ts +14 -0
  489. package/src/resources/extensions/gsd/db-verification-evidence-schema.ts +22 -0
  490. package/src/resources/extensions/gsd/escalation.ts +3 -1
  491. package/src/resources/extensions/gsd/graph.ts +12 -5
  492. package/src/resources/extensions/gsd/gsd-db.ts +260 -1659
  493. package/src/resources/extensions/gsd/guided-flow.ts +47 -0
  494. package/src/resources/extensions/gsd/interrupted-session.ts +1 -0
  495. package/src/resources/extensions/gsd/legacy-telemetry.ts +99 -0
  496. package/src/resources/extensions/gsd/markdown-renderer.ts +4 -1
  497. package/src/resources/extensions/gsd/model-router.ts +10 -6
  498. package/src/resources/extensions/gsd/notification-widget.ts +25 -4
  499. package/src/resources/extensions/gsd/paths.ts +6 -1
  500. package/src/resources/extensions/gsd/post-execution-checks.ts +35 -7
  501. package/src/resources/extensions/gsd/pr-evidence.ts +124 -0
  502. package/src/resources/extensions/gsd/pre-execution-checks.ts +4 -1
  503. package/src/resources/extensions/gsd/preferences-types.ts +23 -4
  504. package/src/resources/extensions/gsd/preferences-validation.ts +3 -3
  505. package/src/resources/extensions/gsd/process-task-path.ts +81 -0
  506. package/src/resources/extensions/gsd/prompt-loader.ts +9 -5
  507. package/src/resources/extensions/gsd/prompts/complete-milestone.md +32 -30
  508. package/src/resources/extensions/gsd/prompts/complete-slice.md +23 -34
  509. package/src/resources/extensions/gsd/prompts/discuss-headless.md +50 -96
  510. package/src/resources/extensions/gsd/prompts/discuss.md +81 -181
  511. package/src/resources/extensions/gsd/prompts/execute-task.md +40 -67
  512. package/src/resources/extensions/gsd/prompts/forensics.md +41 -84
  513. package/src/resources/extensions/gsd/prompts/guided-discuss-milestone.md +29 -39
  514. package/src/resources/extensions/gsd/prompts/guided-discuss-project.md +30 -65
  515. package/src/resources/extensions/gsd/prompts/guided-discuss-requirements.md +25 -52
  516. package/src/resources/extensions/gsd/prompts/guided-discuss-slice.md +36 -36
  517. package/src/resources/extensions/gsd/prompts/guided-research-project.md +20 -38
  518. package/src/resources/extensions/gsd/prompts/plan-milestone.md +45 -59
  519. package/src/resources/extensions/gsd/prompts/plan-slice.md +25 -87
  520. package/src/resources/extensions/gsd/prompts/queue.md +46 -53
  521. package/src/resources/extensions/gsd/prompts/refine-slice.md +23 -23
  522. package/src/resources/extensions/gsd/prompts/research-slice.md +23 -23
  523. package/src/resources/extensions/gsd/prompts/rethink.md +10 -10
  524. package/src/resources/extensions/gsd/prompts/system.md +65 -107
  525. package/src/resources/extensions/gsd/prompts/triage-captures.md +15 -15
  526. package/src/resources/extensions/gsd/prompts/validate-milestone.md +24 -24
  527. package/src/resources/extensions/gsd/prompts/worktree-merge.md +35 -35
  528. package/src/resources/extensions/gsd/state.ts +6 -3
  529. package/src/resources/extensions/gsd/tests/auto-abort-pause-regression.test.ts +32 -0
  530. package/src/resources/extensions/gsd/tests/auto-dashboard.test.ts +65 -0
  531. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +38 -0
  532. package/src/resources/extensions/gsd/tests/auto-orchestrator.test.ts +353 -0
  533. package/src/resources/extensions/gsd/tests/auto-pr-bugs.test.ts +19 -0
  534. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +108 -1
  535. package/src/resources/extensions/gsd/tests/auto-runtime-state.test.ts +39 -0
  536. package/src/resources/extensions/gsd/tests/auto-session-encapsulation.test.ts +3 -0
  537. package/src/resources/extensions/gsd/tests/bootstrap-derive-state-db-open.test.ts +2 -2
  538. package/src/resources/extensions/gsd/tests/check-auto-start-pending-gate.test.ts +203 -0
  539. package/src/resources/extensions/gsd/tests/check-auto-start-ready-guard.test.ts +148 -0
  540. package/src/resources/extensions/gsd/tests/commands-eval-review.test.ts +2 -2
  541. package/src/resources/extensions/gsd/tests/commands-ship-eval-warn.test.ts +3 -2
  542. package/src/resources/extensions/gsd/tests/complete-milestone-prompt-rendering.test.ts +47 -0
  543. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +19 -5
  544. package/src/resources/extensions/gsd/tests/component-loader.test.ts +2 -9
  545. package/src/resources/extensions/gsd/tests/current-directory-root-homedir-fallback.test.ts +63 -0
  546. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +144 -0
  547. package/src/resources/extensions/gsd/tests/custom-verify-retry-store.test.ts +139 -0
  548. package/src/resources/extensions/gsd/tests/custom-workflow-engine.test.ts +50 -0
  549. package/src/resources/extensions/gsd/tests/dashboard-custom-engine.test.ts +3 -3
  550. package/src/resources/extensions/gsd/tests/db-adapter.test.ts +82 -0
  551. package/src/resources/extensions/gsd/tests/db-base-schema.test.ts +62 -0
  552. package/src/resources/extensions/gsd/tests/db-connection-cache.test.ts +60 -0
  553. package/src/resources/extensions/gsd/tests/db-coordination-schema.test.ts +39 -0
  554. package/src/resources/extensions/gsd/tests/db-decision-requirement-rows.test.ts +135 -0
  555. package/src/resources/extensions/gsd/tests/db-gate-rows.test.ts +53 -0
  556. package/src/resources/extensions/gsd/tests/db-lightweight-query-rows.test.ts +45 -0
  557. package/src/resources/extensions/gsd/tests/db-memory-fts-schema.test.ts +86 -0
  558. package/src/resources/extensions/gsd/tests/db-migration-backup.test.ts +105 -0
  559. package/src/resources/extensions/gsd/tests/db-migration-steps.test.ts +159 -0
  560. package/src/resources/extensions/gsd/tests/db-milestone-artifact-rows.test.ts +53 -0
  561. package/src/resources/extensions/gsd/tests/db-open-state.test.ts +56 -0
  562. package/src/resources/extensions/gsd/tests/db-provider.test.ts +105 -0
  563. package/src/resources/extensions/gsd/tests/db-runtime-kv-schema.test.ts +37 -0
  564. package/src/resources/extensions/gsd/tests/db-schema-metadata.test.ts +115 -0
  565. package/src/resources/extensions/gsd/tests/db-task-slice-rows.test.ts +128 -0
  566. package/src/resources/extensions/gsd/tests/db-transaction.test.ts +110 -0
  567. package/src/resources/extensions/gsd/tests/db-verification-evidence-schema.test.ts +76 -0
  568. package/src/resources/extensions/gsd/tests/deep-planning-mode-dispatch.test.ts +42 -0
  569. package/src/resources/extensions/gsd/tests/deep-project-auto-loop.test.ts +63 -2
  570. package/src/resources/extensions/gsd/tests/discuss-headless-rendering.test.ts +37 -0
  571. package/src/resources/extensions/gsd/tests/execute-summary-save-empty-project.test.ts +109 -0
  572. package/src/resources/extensions/gsd/tests/execute-task-rendering.test.ts +59 -0
  573. package/src/resources/extensions/gsd/tests/forensics-prompt-rendering.test.ts +36 -0
  574. package/src/resources/extensions/gsd/tests/graph-operations.test.ts +10 -0
  575. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +95 -0
  576. package/src/resources/extensions/gsd/tests/guided-discuss-milestone-prompt-rendering.test.ts +43 -0
  577. package/src/resources/extensions/gsd/tests/guided-discuss-project-prompt-rendering.test.ts +41 -0
  578. package/src/resources/extensions/gsd/tests/guided-discuss-requirements-prompt-rendering.test.ts +45 -0
  579. package/src/resources/extensions/gsd/tests/guided-flow-prompt-consolidation.test.ts +14 -0
  580. package/src/resources/extensions/gsd/tests/headless-answers.test.ts +1 -1
  581. package/src/resources/extensions/gsd/tests/headless-query.test.ts +2 -2
  582. package/src/resources/extensions/gsd/tests/integration/auto-recovery.test.ts +79 -0
  583. package/src/resources/extensions/gsd/tests/integration/auto-worktree-milestone-merge.test.ts +37 -0
  584. package/src/resources/extensions/gsd/tests/integration/state-machine-live-validation.test.ts +5 -3
  585. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +134 -0
  586. package/src/resources/extensions/gsd/tests/legacy-component-format-telemetry.test.ts +62 -0
  587. package/src/resources/extensions/gsd/tests/legacy-telemetry.test.ts +144 -0
  588. package/src/resources/extensions/gsd/tests/memory-pressure-stuck-state.test.ts +40 -16
  589. package/src/resources/extensions/gsd/tests/model-router.test.ts +33 -12
  590. package/src/resources/extensions/gsd/tests/notification-store.test.ts +8 -0
  591. package/src/resources/extensions/gsd/tests/notification-widget.test.ts +40 -1
  592. package/src/resources/extensions/gsd/tests/parallel-skill-prompt-integration.test.ts +8 -0
  593. package/src/resources/extensions/gsd/tests/paused-session-via-db.test.ts +2 -0
  594. package/src/resources/extensions/gsd/tests/plan-milestone-rendering.test.ts +45 -0
  595. package/src/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +65 -16
  596. package/src/resources/extensions/gsd/tests/plan-slice.test.ts +27 -0
  597. package/src/resources/extensions/gsd/tests/post-execution-checks.test.ts +46 -0
  598. package/src/resources/extensions/gsd/tests/pr-evidence.test.ts +79 -0
  599. package/src/resources/extensions/gsd/tests/pre-exec-gate-loop.test.ts +3 -0
  600. package/src/resources/extensions/gsd/tests/process-task-path.test.ts +51 -0
  601. package/src/resources/extensions/gsd/tests/prompt-step-ordering.test.ts +16 -1
  602. package/src/resources/extensions/gsd/tests/queue-prompt-rendering.test.ts +37 -0
  603. package/src/resources/extensions/gsd/tests/register-hooks-compaction-checkpoint.test.ts +85 -0
  604. package/src/resources/extensions/gsd/tests/resource-loader-import-path.test.ts +1 -1
  605. package/src/resources/extensions/gsd/tests/run-uat-composer.test.ts +2 -0
  606. package/src/resources/extensions/gsd/tests/subagent-model-dispatch.test.ts +59 -0
  607. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +32 -9
  608. package/src/resources/extensions/gsd/tests/unit-context-composer.test.ts +42 -4
  609. package/src/resources/extensions/gsd/tests/unit-context-manifest.test.ts +32 -0
  610. package/src/resources/extensions/gsd/tests/uok-contracts.test.ts +109 -1
  611. package/src/resources/extensions/gsd/tests/uok-kernel-path.test.ts +12 -0
  612. package/src/resources/extensions/gsd/tests/uok-loop-adapter-writer.test.ts +98 -0
  613. package/src/resources/extensions/gsd/tests/workflow-custom-engine-dispatch-outcome.test.ts +55 -0
  614. package/src/resources/extensions/gsd/tests/workflow-custom-engine-iteration.test.ts +93 -0
  615. package/src/resources/extensions/gsd/tests/workflow-custom-engine-reconcile-outcome.test.ts +108 -0
  616. package/src/resources/extensions/gsd/tests/workflow-custom-engine-reconcile.test.ts +146 -0
  617. package/src/resources/extensions/gsd/tests/workflow-custom-engine-retry.test.ts +136 -0
  618. package/src/resources/extensions/gsd/tests/workflow-custom-engine-verify-outcome.test.ts +95 -0
  619. package/src/resources/extensions/gsd/tests/workflow-dispatch-claim.test.ts +158 -0
  620. package/src/resources/extensions/gsd/tests/workflow-dispatch-ledger.test.ts +82 -0
  621. package/src/resources/extensions/gsd/tests/workflow-iteration-completion.test.ts +44 -0
  622. package/src/resources/extensions/gsd/tests/workflow-journal-reporter.test.ts +49 -0
  623. package/src/resources/extensions/gsd/tests/workflow-kernel.test.ts +607 -0
  624. package/src/resources/extensions/gsd/tests/workflow-logger.test.ts +20 -4
  625. package/src/resources/extensions/gsd/tests/workflow-mcp.test.ts +8 -7
  626. package/src/resources/extensions/gsd/tests/workflow-memory-pressure.test.ts +71 -0
  627. package/src/resources/extensions/gsd/tests/workflow-phase-reporter.test.ts +40 -0
  628. package/src/resources/extensions/gsd/tests/workflow-session-lock.test.ts +135 -0
  629. package/src/resources/extensions/gsd/tests/workflow-sidecar-iteration.test.ts +110 -0
  630. package/src/resources/extensions/gsd/tests/workflow-sidecar-queue.test.ts +116 -0
  631. package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +21 -0
  632. package/src/resources/extensions/gsd/tests/workflow-tool-executors.test.ts +164 -3
  633. package/src/resources/extensions/gsd/tests/workflow-turn-reporter.test.ts +87 -0
  634. package/src/resources/extensions/gsd/tests/workflow-unit-dispatch.test.ts +160 -0
  635. package/src/resources/extensions/gsd/tests/workflow-worker-heartbeat.test.ts +123 -0
  636. package/src/resources/extensions/gsd/tests/worktree-path-injection.test.ts +3 -0
  637. package/src/resources/extensions/gsd/tests/worktree-submodule-safety.test.ts +18 -34
  638. package/src/resources/extensions/gsd/tools/complete-milestone.ts +15 -9
  639. package/src/resources/extensions/gsd/tools/complete-task.ts +4 -1
  640. package/src/resources/extensions/gsd/tools/workflow-tool-executors.ts +90 -2
  641. package/src/resources/extensions/gsd/unit-context-composer.ts +49 -0
  642. package/src/resources/extensions/gsd/unit-context-manifest.ts +34 -0
  643. package/src/resources/extensions/gsd/uok/audit.ts +25 -9
  644. package/src/resources/extensions/gsd/uok/contracts.ts +105 -0
  645. package/src/resources/extensions/gsd/uok/dispatch-envelope.ts +4 -0
  646. package/src/resources/extensions/gsd/uok/kernel.ts +10 -3
  647. package/src/resources/extensions/gsd/uok/loop-adapter.ts +60 -45
  648. package/src/resources/extensions/gsd/uok/plan-v2.ts +5 -1
  649. package/src/resources/extensions/gsd/uok/timeline.ts +158 -0
  650. package/src/resources/extensions/gsd/workflow-logger.ts +13 -13
  651. package/src/resources/extensions/gsd/workflow-manifest.ts +6 -15
  652. package/src/resources/extensions/gsd/workflow-projections.ts +5 -1
  653. package/src/resources/extensions/gsd/workflow-templates.ts +11 -0
  654. package/src/resources/extensions/shared/gsd-phase-state.ts +56 -3
  655. package/src/resources/extensions/shared/interview-ui.ts +18 -5
  656. package/src/resources/extensions/shared/tests/gsd-phase-state.test.ts +43 -1
  657. package/src/resources/extensions/shared/tests/interview-notes-loop.test.ts +41 -0
  658. package/dist/web/standalone/.next/server/chunks/6336.js +0 -1
  659. package/dist/web/standalone/.next/server/chunks/6897.js +0 -12
  660. package/dist/web/standalone/.next/static/chunks/app/page-ff639266d978f2a0.js +0 -1
  661. package/dist/web/standalone/.next/static/chunks/main-app-d3d4c336195465f9.js +0 -1
  662. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-ab5a8926e07ec673.js +0 -1
  663. /package/dist/{app-paths.d.ts → app/app-paths.d.ts} +0 -0
  664. /package/dist/{app-paths.js → app/app-paths.js} +0 -0
  665. /package/dist/{project-sessions.d.ts → app/project-sessions.d.ts} +0 -0
  666. /package/dist/{project-sessions.js → app/project-sessions.js} +0 -0
  667. /package/dist/{tool-bootstrap.d.ts → app/tool-bootstrap.d.ts} +0 -0
  668. /package/dist/{tool-bootstrap.js → app/tool-bootstrap.js} +0 -0
  669. /package/dist/{cli-auto-routing.d.ts → cli/cli-auto-routing.d.ts} +0 -0
  670. /package/dist/{cli-auto-routing.js → cli/cli-auto-routing.js} +0 -0
  671. /package/dist/{cli-policy.d.ts → cli/cli-policy.d.ts} +0 -0
  672. /package/dist/{cli-policy.js → cli/cli-policy.js} +0 -0
  673. /package/dist/{cli.d.ts → cli/cli.d.ts} +0 -0
  674. /package/dist/{help-text.d.ts → cli/help-text.d.ts} +0 -0
  675. /package/dist/{help-text.js → cli/help-text.js} +0 -0
  676. /package/dist/{logo.d.ts → cli/logo.d.ts} +0 -0
  677. /package/dist/{logo.js → cli/logo.js} +0 -0
  678. /package/dist/{web-mode.d.ts → cli/web-mode.d.ts} +0 -0
  679. /package/dist/{bundled-extension-paths.d.ts → extension-runtime/bundled-extension-paths.d.ts} +0 -0
  680. /package/dist/{bundled-extension-paths.js → extension-runtime/bundled-extension-paths.js} +0 -0
  681. /package/dist/{bundled-resource-path.d.ts → extension-runtime/bundled-resource-path.d.ts} +0 -0
  682. /package/dist/{bundled-resource-path.js → extension-runtime/bundled-resource-path.js} +0 -0
  683. /package/dist/{extension-discovery.d.ts → extension-runtime/extension-discovery.d.ts} +0 -0
  684. /package/dist/{extension-discovery.js → extension-runtime/extension-discovery.js} +0 -0
  685. /package/dist/{extension-registry.d.ts → extension-runtime/extension-registry.d.ts} +0 -0
  686. /package/dist/{extension-sort.d.ts → extension-runtime/extension-sort.d.ts} +0 -0
  687. /package/dist/{extension-sort.js → extension-runtime/extension-sort.js} +0 -0
  688. /package/dist/{extension-validator.d.ts → extension-runtime/extension-validator.d.ts} +0 -0
  689. /package/dist/{extension-validator.js → extension-runtime/extension-validator.js} +0 -0
  690. /package/dist/{headless-answers.d.ts → headless/headless-answers.d.ts} +0 -0
  691. /package/dist/{headless-answers.js → headless/headless-answers.js} +0 -0
  692. /package/dist/{headless-context.d.ts → headless/headless-context.d.ts} +0 -0
  693. /package/dist/{headless-context.js → headless/headless-context.js} +0 -0
  694. /package/dist/{headless-events.d.ts → headless/headless-events.d.ts} +0 -0
  695. /package/dist/{headless-events.js → headless/headless-events.js} +0 -0
  696. /package/dist/{headless-recover.d.ts → headless/headless-recover.d.ts} +0 -0
  697. /package/dist/{headless-types.d.ts → headless/headless-types.d.ts} +0 -0
  698. /package/dist/{headless-types.js → headless/headless-types.js} +0 -0
  699. /package/dist/{headless-ui.d.ts → headless/headless-ui.d.ts} +0 -0
  700. /package/dist/{headless-ui.js → headless/headless-ui.js} +0 -0
  701. /package/dist/{headless.d.ts → headless/headless.d.ts} +0 -0
  702. /package/dist/{mcp-server.d.ts → mcp/mcp-server.d.ts} +0 -0
  703. /package/dist/{mcp-server.js → mcp/mcp-server.js} +0 -0
  704. /package/dist/{onboarding.d.ts → onboarding/onboarding.d.ts} +0 -0
  705. /package/dist/{welcome-screen.d.ts → onboarding/welcome-screen.d.ts} +0 -0
  706. /package/dist/{wizard.d.ts → onboarding/wizard.d.ts} +0 -0
  707. /package/dist/{wizard.js → onboarding/wizard.js} +0 -0
  708. /package/dist/{models-resolver.d.ts → providers/models-resolver.d.ts} +0 -0
  709. /package/dist/{pi-migration.d.ts → providers/pi-migration.d.ts} +0 -0
  710. /package/dist/{pi-migration.js → providers/pi-migration.js} +0 -0
  711. /package/dist/{provider-migrations.d.ts → providers/provider-migrations.d.ts} +0 -0
  712. /package/dist/{provider-migrations.js → providers/provider-migrations.js} +0 -0
  713. /package/dist/{remote-questions-config.d.ts → providers/remote-questions-config.d.ts} +0 -0
  714. /package/dist/{rtk-shared.d.ts → rtk/rtk-shared.d.ts} +0 -0
  715. /package/dist/{rtk-shared.js → rtk/rtk-shared.js} +0 -0
  716. /package/dist/{rtk.d.ts → rtk/rtk.d.ts} +0 -0
  717. /package/dist/{rtk.js → rtk/rtk.js} +0 -0
  718. /package/dist/{security-overrides.d.ts → security/security-overrides.d.ts} +0 -0
  719. /package/dist/{claude-cli-check.d.ts → startup/claude-cli-check.d.ts} +0 -0
  720. /package/dist/{claude-cli-check.js → startup/claude-cli-check.js} +0 -0
  721. /package/dist/{runtime-checks.d.ts → startup/runtime-checks.d.ts} +0 -0
  722. /package/dist/{runtime-checks.js → startup/runtime-checks.js} +0 -0
  723. /package/dist/{startup-model-validation.d.ts → startup/startup-model-validation.d.ts} +0 -0
  724. /package/dist/{startup-timings.d.ts → startup/startup-timings.d.ts} +0 -0
  725. /package/dist/{startup-timings.js → startup/startup-timings.js} +0 -0
  726. /package/dist/{update-check.d.ts → update/update-check.d.ts} +0 -0
  727. /package/dist/{update-cmd.d.ts → update/update-cmd.d.ts} +0 -0
  728. /package/dist/{update-cmd.js → update/update-cmd.js} +0 -0
  729. /package/dist/web/standalone/.next/static/{J-CU-p_sp45CJHT3R9TJS → -WDXZiiJHGZDbYH75Mu6f}/_buildManifest.js +0 -0
  730. /package/dist/web/standalone/.next/static/{J-CU-p_sp45CJHT3R9TJS → -WDXZiiJHGZDbYH75Mu6f}/_ssgManifest.js +0 -0
  731. /package/dist/{worktree-cli.d.ts → worktrees/worktree-cli.d.ts} +0 -0
  732. /package/dist/{worktree-name-gen.d.ts → worktrees/worktree-name-gen.d.ts} +0 -0
  733. /package/dist/{worktree-name-gen.js → worktrees/worktree-name-gen.js} +0 -0
  734. /package/dist/{worktree-status-banner.d.ts → worktrees/worktree-status-banner.d.ts} +0 -0
  735. /package/dist/{worktree-status-banner.js → worktrees/worktree-status-banner.js} +0 -0
@@ -1,3 +1,5 @@
1
+ // GSD Extension — Auto recovery integration tests.
2
+
1
3
  import test from "node:test";
2
4
  import assert from "node:assert/strict";
3
5
  import { mkdirSync, writeFileSync, existsSync, readFileSync, rmSync, chmodSync } from "node:fs";
@@ -401,6 +403,57 @@ test("verifyExpectedArtifact plan-slice fails for plan with no tasks (#699)", (t
401
403
  assert.equal(result, false, "should fail when plan has no task entries (empty scaffold, #699)");
402
404
  });
403
405
 
406
+ test("verifyExpectedArtifact plan-slice trusts DB tasks over legacy plan syntax", (t) => {
407
+ const base = makeTmpBase();
408
+ t.after(() => {
409
+ closeDatabase();
410
+ cleanup(base);
411
+ });
412
+
413
+ openDatabase(join(base, ".gsd", "gsd.db"));
414
+ insertMilestone({ id: "M001", title: "Milestone", status: "active" });
415
+ insertSlice({ id: "S01", milestoneId: "M001", title: "Slice", status: "pending" });
416
+ insertTask({ id: "T01", milestoneId: "M001", sliceId: "S01", title: "First task", status: "pending" });
417
+ insertTask({ id: "T02", milestoneId: "M001", sliceId: "S01", title: "Second task", status: "pending" });
418
+
419
+ const sliceDir = join(base, ".gsd", "milestones", "M001", "slices", "S01");
420
+ const tasksDir = join(sliceDir, "tasks");
421
+ writeFileSync(
422
+ join(sliceDir, "S01-PLAN.md"),
423
+ "# S01: Slice\n\n## Tasks\n\nTask rows live in the DB; this projection intentionally has no legacy task syntax.\n",
424
+ );
425
+ writeFileSync(join(tasksDir, "T01-PLAN.md"), "# T01 Plan\n");
426
+ writeFileSync(join(tasksDir, "T02-PLAN.md"), "# T02 Plan\n");
427
+
428
+ const result = verifyExpectedArtifact("plan-slice", "M001/S01", base);
429
+ assert.equal(result, true, "DB task rows plus task plan files should verify plan-slice");
430
+ });
431
+
432
+ test("verifyExpectedArtifact plan-slice still fails when a DB-backed task plan file is missing", (t) => {
433
+ const base = makeTmpBase();
434
+ t.after(() => {
435
+ closeDatabase();
436
+ cleanup(base);
437
+ });
438
+
439
+ openDatabase(join(base, ".gsd", "gsd.db"));
440
+ insertMilestone({ id: "M001", title: "Milestone", status: "active" });
441
+ insertSlice({ id: "S01", milestoneId: "M001", title: "Slice", status: "pending" });
442
+ insertTask({ id: "T01", milestoneId: "M001", sliceId: "S01", title: "First task", status: "pending" });
443
+ insertTask({ id: "T02", milestoneId: "M001", sliceId: "S01", title: "Second task", status: "pending" });
444
+
445
+ const sliceDir = join(base, ".gsd", "milestones", "M001", "slices", "S01");
446
+ const tasksDir = join(sliceDir, "tasks");
447
+ writeFileSync(
448
+ join(sliceDir, "S01-PLAN.md"),
449
+ "# S01: Slice\n\n## Tasks\n\nTask rows live in the DB; this projection intentionally has no legacy task syntax.\n",
450
+ );
451
+ writeFileSync(join(tasksDir, "T01-PLAN.md"), "# T01 Plan\n");
452
+
453
+ const result = verifyExpectedArtifact("plan-slice", "M001/S01", base);
454
+ assert.equal(result, false, "DB task rows must still require matching task plan files");
455
+ });
456
+
404
457
  // ─── verifyExpectedArtifact: heading-style plan tasks (#1691) ─────────────
405
458
 
406
459
  test("verifyExpectedArtifact accepts plan-slice with heading-style tasks (### T01 --)", (t) => {
@@ -456,6 +509,32 @@ test("verifyExpectedArtifact accepts plan-slice with colon-style heading tasks (
456
509
  );
457
510
  });
458
511
 
512
+ test("verifyExpectedArtifact accepts indented legacy plan-slice task markers", (t) => {
513
+ const base = makeTmpBase();
514
+ t.after(() => cleanup(base));
515
+
516
+ const sliceDir = join(base, ".gsd", "milestones", "M001", "slices", "S01");
517
+ const tasksDir = join(sliceDir, "tasks");
518
+ mkdirSync(tasksDir, { recursive: true });
519
+ writeFileSync(join(sliceDir, "S01-PLAN.md"), [
520
+ "# S01: Test Slice",
521
+ "",
522
+ "## Tasks",
523
+ "",
524
+ " - [ ] **T01: Implement feature** `est:1h`",
525
+ "",
526
+ " ### T02 -- Write tests",
527
+ ].join("\n"));
528
+ writeFileSync(join(tasksDir, "T01-PLAN.md"), "# T01 Plan");
529
+ writeFileSync(join(tasksDir, "T02-PLAN.md"), "# T02 Plan");
530
+
531
+ assert.strictEqual(
532
+ verifyExpectedArtifact("plan-slice", "M001/S01", base),
533
+ true,
534
+ "Indented legacy task markers should be treated as completed plan-slice artifacts",
535
+ );
536
+ });
537
+
459
538
  test("verifyExpectedArtifact execute-task rejects heading-style plan without checked checkbox (#3607)", (t) => {
460
539
  const base = makeTmpBase();
461
540
  t.after(() => cleanup(base));
@@ -24,6 +24,7 @@ import {
24
24
  } from "../../auto-worktree.ts";
25
25
  import { getSliceBranchName } from "../../worktree.ts";
26
26
  import { nativeMergeSquash } from "../../native-git-bridge.ts";
27
+ import { drainLogs, setStderrLoggingEnabled } from "../../workflow-logger.ts";
27
28
 
28
29
  function run(cmd: string, cwd: string): string {
29
30
  // Safe: all inputs are hardcoded test strings, not user input
@@ -251,6 +252,42 @@ describe("auto-worktree-milestone-merge", { timeout: 300_000 }, () => {
251
252
  assert.strictEqual(typeof result.pushed, "boolean", "pushed flag remains boolean");
252
253
  });
253
254
 
255
+ test("external .gsd and local-only auto_push closeout without cleanup or push warnings", () => {
256
+ const { repo, externalState } = freshRepoWithExternalGsd();
257
+ const previousStderr = setStderrLoggingEnabled(false);
258
+ drainLogs();
259
+
260
+ try {
261
+ writeFileSync(
262
+ join(externalState, "PREFERENCES.md"),
263
+ "---\nversion: 1\n---\n\ngit:\n auto_push: true\n",
264
+ );
265
+ mkdirSync(join(externalState, "milestones", "M041"), { recursive: true });
266
+ mkdirSync(join(externalState, "runtime", "units"), { recursive: true });
267
+ writeFileSync(join(externalState, "runtime", "units", "leftover.json"), "{}\n");
268
+
269
+ const wtPath = createAutoWorktree(repo, "M041");
270
+ addSliceToMilestone(repo, wtPath, "M041", "S01", "Local-only push", [
271
+ { file: "local-only.ts", content: "export const localOnly = true;\n", message: "add local only file" },
272
+ ]);
273
+
274
+ const roadmap = makeRoadmap("M041", "Local-only closeout", [
275
+ { id: "S01", title: "Local-only push" },
276
+ ]);
277
+
278
+ const result = mergeMilestoneToMain(repo, "M041", roadmap);
279
+ const logs = drainLogs();
280
+ const messages = logs.map((entry) => entry.message).join("\n");
281
+
282
+ assert.equal(result.pushed, false, "local-only repo should not report pushed");
283
+ assert.ok(!messages.includes("untracked file cleanup failed"), "external .gsd cleanup should not call git on paths outside the repo");
284
+ assert.ok(!messages.includes("git push failed"), "missing origin should skip auto-push instead of running git push");
285
+ } finally {
286
+ drainLogs();
287
+ setStderrLoggingEnabled(previousStderr);
288
+ }
289
+ });
290
+
254
291
  test("auto-resolve .gsd/ state file conflicts", () => {
255
292
  const repo = freshRepo();
256
293
  const wtPath = createAutoWorktree(repo, "M050");
@@ -575,7 +575,7 @@ describe("state-machine-live-validation", () => {
575
575
  assert.match((result as any).error, /verification did not pass/);
576
576
  });
577
577
 
578
- test("double milestone completion returns error", async () => {
578
+ test("double milestone completion is idempotent", async () => {
579
579
  base = createFullFixture();
580
580
  openDatabase(join(base, ".gsd", "gsd.db"));
581
581
  insertMilestone({ id: "M001", title: "Done", status: "complete" });
@@ -583,8 +583,10 @@ describe("state-machine-live-validation", () => {
583
583
  insertTask({ id: "T01", sliceId: "S01", milestoneId: "M001", status: "complete" });
584
584
 
585
585
  const result = await handleCompleteMilestone(makeMilestoneParams("M001") as any, base);
586
- assert.ok("error" in result);
587
- assert.match((result as any).error, /already complete/);
586
+ assert.ok(!("error" in result), `already-complete milestone should be accepted: ${JSON.stringify(result)}`);
587
+ assert.equal(result.alreadyComplete, true);
588
+ assert.match(result.summaryPath, /M001-SUMMARY\.md$/);
589
+ assert.ok(isClosedStatus(getMilestone("M001")!.status), "milestone remains closed");
588
590
  });
589
591
  });
590
592
 
@@ -399,6 +399,140 @@ test("runDispatch pauses when complete-milestone summary exists on disk but the
399
399
  assert.equal(stopCalls, 0, "mismatch pause should not hard-stop the loop");
400
400
  });
401
401
 
402
+ test("runDispatch clears stuck state after Level 1 artifact recovery", async (t) => {
403
+ const capture = createEventCapture();
404
+ let invalidateCalls = 0;
405
+ let stopCalls = 0;
406
+ const base = join(tmpdir(), `gsd-stuck-plan-${randomUUID()}`);
407
+ t.after(() => {
408
+ closeDatabase();
409
+ rmSync(base, { recursive: true, force: true });
410
+ });
411
+
412
+ const sliceDir = join(base, ".gsd", "milestones", "M001", "slices", "S01");
413
+ const tasksDir = join(sliceDir, "tasks");
414
+ mkdirSync(tasksDir, { recursive: true });
415
+ openDatabase(join(base, ".gsd", "gsd.db"));
416
+ insertMilestone({ id: "M001", title: "Test", status: "active" });
417
+ insertSlice({ id: "S01", milestoneId: "M001", title: "Slice", status: "pending" });
418
+ insertTask({ id: "T01", milestoneId: "M001", sliceId: "S01", title: "First task", status: "pending" });
419
+ writeFileSync(join(sliceDir, "S01-PLAN.md"), "# S01\n\n## Tasks\n\n- [ ] **T01: First task** `est:1h`\n");
420
+ writeFileSync(join(tasksDir, "T01-PLAN.md"), "# T01 Plan\n");
421
+
422
+ const deps = makeMockDeps(capture, {
423
+ invalidateAllCaches: () => { invalidateCalls++; },
424
+ stopAuto: async () => { stopCalls++; },
425
+ resolveDispatch: async () => ({
426
+ action: "dispatch" as const,
427
+ unitType: "plan-slice",
428
+ unitId: "M001/S01",
429
+ prompt: "plan the slice",
430
+ matchedRule: "planning → plan-slice",
431
+ }),
432
+ });
433
+ const ic = makeIC(deps, {
434
+ s: {
435
+ ...makeSession(),
436
+ basePath: base,
437
+ originalBasePath: base,
438
+ } as any,
439
+ });
440
+ const preData: PreDispatchData = {
441
+ state: {
442
+ phase: "planning",
443
+ activeMilestone: { id: "M001", title: "Test", status: "active" },
444
+ activeSlice: { id: "S01", title: "Slice" },
445
+ registry: [{ id: "M001", status: "active" }],
446
+ blockers: [],
447
+ } as any,
448
+ mid: "M001",
449
+ midTitle: "Test Milestone",
450
+ };
451
+ const loopState: LoopState = {
452
+ recentUnits: [
453
+ { key: "plan-slice/M001/S01" },
454
+ { key: "plan-slice/M001/S01" },
455
+ ],
456
+ stuckRecoveryAttempts: 0,
457
+ consecutiveFinalizeTimeouts: 0,
458
+ };
459
+
460
+ const result = await runDispatch(ic, preData, loopState);
461
+
462
+ assert.equal(result.action, "continue");
463
+ assert.equal(invalidateCalls, 1, "Level 1 artifact recovery should invalidate caches");
464
+ assert.equal(stopCalls, 0, "Level 1 artifact recovery should not hard-stop");
465
+ assert.deepEqual(loopState.recentUnits, [], "Level 1 artifact recovery should clear the stuck window");
466
+ assert.equal(loopState.stuckRecoveryAttempts, 0, "Level 1 artifact recovery should reset the recovery counter");
467
+ });
468
+
469
+ test("runDispatch escapes Level 2 stuck stop when artifact verifies after cache invalidation", async (t) => {
470
+ const capture = createEventCapture();
471
+ let invalidateCalls = 0;
472
+ let stopCalls = 0;
473
+ const base = join(tmpdir(), `gsd-stuck-plan-l2-${randomUUID()}`);
474
+ t.after(() => {
475
+ closeDatabase();
476
+ rmSync(base, { recursive: true, force: true });
477
+ });
478
+
479
+ const sliceDir = join(base, ".gsd", "milestones", "M001", "slices", "S01");
480
+ const tasksDir = join(sliceDir, "tasks");
481
+ mkdirSync(tasksDir, { recursive: true });
482
+ openDatabase(join(base, ".gsd", "gsd.db"));
483
+ insertMilestone({ id: "M001", title: "Test", status: "active" });
484
+ insertSlice({ id: "S01", milestoneId: "M001", title: "Slice", status: "pending" });
485
+ insertTask({ id: "T01", milestoneId: "M001", sliceId: "S01", title: "First task", status: "pending" });
486
+ writeFileSync(join(sliceDir, "S01-PLAN.md"), "# S01\n\n## Tasks\n\n- [ ] **T01: First task** `est:1h`\n");
487
+ writeFileSync(join(tasksDir, "T01-PLAN.md"), "# T01 Plan\n");
488
+
489
+ const deps = makeMockDeps(capture, {
490
+ invalidateAllCaches: () => { invalidateCalls++; },
491
+ stopAuto: async () => { stopCalls++; },
492
+ resolveDispatch: async () => ({
493
+ action: "dispatch" as const,
494
+ unitType: "plan-slice",
495
+ unitId: "M001/S01",
496
+ prompt: "plan the slice",
497
+ matchedRule: "planning → plan-slice",
498
+ }),
499
+ });
500
+ const ic = makeIC(deps, {
501
+ s: {
502
+ ...makeSession(),
503
+ basePath: base,
504
+ originalBasePath: base,
505
+ } as any,
506
+ });
507
+ const preData: PreDispatchData = {
508
+ state: {
509
+ phase: "planning",
510
+ activeMilestone: { id: "M001", title: "Test", status: "active" },
511
+ activeSlice: { id: "S01", title: "Slice" },
512
+ registry: [{ id: "M001", status: "active" }],
513
+ blockers: [],
514
+ } as any,
515
+ mid: "M001",
516
+ midTitle: "Test Milestone",
517
+ };
518
+ const loopState: LoopState = {
519
+ recentUnits: [
520
+ { key: "plan-slice/M001/S01" },
521
+ { key: "plan-slice/M001/S01" },
522
+ ],
523
+ stuckRecoveryAttempts: 1,
524
+ consecutiveFinalizeTimeouts: 0,
525
+ };
526
+
527
+ const result = await runDispatch(ic, preData, loopState);
528
+
529
+ assert.equal(result.action, "continue");
530
+ assert.equal(invalidateCalls, 1, "Level 2 escape should invalidate caches before rechecking artifacts");
531
+ assert.equal(stopCalls, 0, "verified artifacts should escape Level 2 hard stop");
532
+ assert.deepEqual(loopState.recentUnits, [], "Level 2 artifact escape should clear the stuck window");
533
+ assert.equal(loopState.stuckRecoveryAttempts, 0, "Level 2 artifact escape should reset the recovery counter");
534
+ });
535
+
402
536
  test("runUnitPhase emits unit-start and unit-end with causedBy reference", async () => {
403
537
  const capture = createEventCapture();
404
538
 
@@ -0,0 +1,62 @@
1
+ // Project/App: GSD-2
2
+ // File Purpose: Verifies telemetry for legacy component formats.
3
+
4
+ import test from "node:test";
5
+ import assert from "node:assert/strict";
6
+ import { mkdtempSync, mkdirSync, rmSync, writeFileSync } from "node:fs";
7
+ import { join } from "node:path";
8
+ import { tmpdir } from "node:os";
9
+
10
+ import { loadComponentFromAgentFile, loadComponentFromDir } from "../component-loader.js";
11
+ import { getLegacyTelemetry, resetLegacyTelemetry } from "../legacy-telemetry.js";
12
+
13
+ function makeTempDir(): string {
14
+ return mkdtempSync(join(tmpdir(), "gsd-legacy-component-format-"));
15
+ }
16
+
17
+ test("legacy component telemetry counts successful skill and agent format loads", () => {
18
+ const dir = makeTempDir();
19
+ try {
20
+ resetLegacyTelemetry();
21
+
22
+ const modernDir = join(dir, "modern-skill");
23
+ mkdirSync(modernDir, { recursive: true });
24
+ writeFileSync(join(modernDir, "component.yaml"), `
25
+ apiVersion: gsd/v1
26
+ kind: skill
27
+ metadata:
28
+ name: modern-skill
29
+ description: "Modern skill"
30
+ spec:
31
+ prompt: SKILL.md
32
+ `, "utf-8");
33
+ writeFileSync(join(modernDir, "SKILL.md"), "Modern content.", "utf-8");
34
+ assert.ok(loadComponentFromDir(modernDir, "user").component);
35
+ assert.equal(getLegacyTelemetry()["legacy.componentFormatUsed"], 0);
36
+
37
+ const legacySkillDir = join(dir, "legacy-skill");
38
+ mkdirSync(legacySkillDir, { recursive: true });
39
+ writeFileSync(join(legacySkillDir, "SKILL.md"), `---
40
+ name: legacy-skill
41
+ description: Legacy skill
42
+ ---
43
+ Skill content.
44
+ `, "utf-8");
45
+ assert.ok(loadComponentFromDir(legacySkillDir, "user").component);
46
+ assert.equal(getLegacyTelemetry()["legacy.componentFormatUsed"], 1);
47
+
48
+ const legacyAgentFile = join(dir, "legacy-agent.md");
49
+ writeFileSync(legacyAgentFile, `---
50
+ name: legacy-agent
51
+ description: Legacy agent
52
+ tools: read, grep
53
+ ---
54
+ Agent content.
55
+ `, "utf-8");
56
+ assert.ok(loadComponentFromAgentFile(legacyAgentFile, "user").component);
57
+ assert.equal(getLegacyTelemetry()["legacy.componentFormatUsed"], 2);
58
+ } finally {
59
+ resetLegacyTelemetry();
60
+ rmSync(dir, { recursive: true, force: true });
61
+ }
62
+ });
@@ -0,0 +1,144 @@
1
+ // Project/App: GSD-2
2
+ // File Purpose: Tests for telemetry counters guarding legacy compatibility cleanup.
3
+
4
+ import test from "node:test";
5
+ import assert from "node:assert/strict";
6
+ import { mkdtempSync, mkdirSync, readFileSync, rmSync, writeFileSync } from "node:fs";
7
+ import { join } from "node:path";
8
+ import { tmpdir } from "node:os";
9
+
10
+ import {
11
+ getLegacyTelemetryReport,
12
+ getLegacyTelemetry,
13
+ incrementLegacyTelemetry,
14
+ listLegacyTelemetryCounters,
15
+ persistLegacyTelemetrySnapshot,
16
+ resetLegacyTelemetry,
17
+ } from "../legacy-telemetry.ts";
18
+ import { closeDatabase } from "../gsd-db.ts";
19
+ import { deriveState, invalidateStateCache } from "../state.ts";
20
+ import { _resetLogs, peekLogs, setStderrLoggingEnabled } from "../workflow-logger.ts";
21
+
22
+ test("legacy telemetry exposes every Phase 8 cleanup counter", () => {
23
+ resetLegacyTelemetry();
24
+
25
+ assert.deepEqual(listLegacyTelemetryCounters(), [
26
+ "legacy.markdownFallbackUsed",
27
+ "legacy.workflowEngineUsed",
28
+ "legacy.uokFallbackUsed",
29
+ "legacy.mcpAliasUsed",
30
+ "legacy.componentFormatUsed",
31
+ "legacy.providerDefaultUsed",
32
+ ]);
33
+ assert.equal(getLegacyTelemetry()["legacy.markdownFallbackUsed"], 0);
34
+ });
35
+
36
+ test("legacy telemetry increments positive finite amounts only", () => {
37
+ resetLegacyTelemetry();
38
+
39
+ incrementLegacyTelemetry("legacy.workflowEngineUsed");
40
+ incrementLegacyTelemetry("legacy.workflowEngineUsed", 2);
41
+ incrementLegacyTelemetry("legacy.workflowEngineUsed", 0);
42
+ incrementLegacyTelemetry("legacy.workflowEngineUsed", Number.NaN);
43
+
44
+ assert.equal(getLegacyTelemetry()["legacy.workflowEngineUsed"], 3);
45
+ });
46
+
47
+ test("legacy telemetry emits one actionable diagnostic per counter", () => {
48
+ const previousStderr = setStderrLoggingEnabled(false);
49
+ try {
50
+ resetLegacyTelemetry();
51
+ _resetLogs();
52
+
53
+ incrementLegacyTelemetry("legacy.mcpAliasUsed");
54
+ incrementLegacyTelemetry("legacy.mcpAliasUsed");
55
+
56
+ const logs = peekLogs();
57
+ assert.equal(logs.length, 1);
58
+ assert.equal(logs[0]?.component, "migration");
59
+ assert.equal(logs[0]?.context?.counter, "legacy.mcpAliasUsed");
60
+ assert.match(logs[0]?.message ?? "", /canonical gsd_\* tool name/);
61
+ } finally {
62
+ _resetLogs();
63
+ resetLegacyTelemetry();
64
+ setStderrLoggingEnabled(previousStderr);
65
+ }
66
+ });
67
+
68
+ test("legacy telemetry can persist an opt-in snapshot file", () => {
69
+ const previousStderr = setStderrLoggingEnabled(false);
70
+ const previousOutput = process.env.GSD_LEGACY_TELEMETRY_FILE;
71
+ const base = mkdtempSync(join(tmpdir(), "gsd-legacy-telemetry-file-"));
72
+ const outputPath = join(base, "runtime", "legacy-telemetry.json");
73
+ try {
74
+ resetLegacyTelemetry();
75
+ _resetLogs();
76
+ process.env.GSD_LEGACY_TELEMETRY_FILE = outputPath;
77
+
78
+ incrementLegacyTelemetry("legacy.providerDefaultUsed", 2);
79
+
80
+ const report = JSON.parse(readFileSync(outputPath, "utf-8")) as ReturnType<typeof getLegacyTelemetryReport>;
81
+ assert.equal(typeof report.ts, "string");
82
+ assert.equal(report.counters["legacy.providerDefaultUsed"], 2);
83
+ assert.equal(report.counters["legacy.markdownFallbackUsed"], 0);
84
+ } finally {
85
+ if (previousOutput === undefined) delete process.env.GSD_LEGACY_TELEMETRY_FILE;
86
+ else process.env.GSD_LEGACY_TELEMETRY_FILE = previousOutput;
87
+ _resetLogs();
88
+ resetLegacyTelemetry();
89
+ setStderrLoggingEnabled(previousStderr);
90
+ rmSync(base, { recursive: true, force: true });
91
+ }
92
+ });
93
+
94
+ test("legacy telemetry can persist a zero-use snapshot for deletion gates", () => {
95
+ const previousOutput = process.env.GSD_LEGACY_TELEMETRY_FILE;
96
+ const base = mkdtempSync(join(tmpdir(), "gsd-legacy-zero-telemetry-"));
97
+ const outputPath = join(base, "legacy-telemetry.json");
98
+ try {
99
+ resetLegacyTelemetry();
100
+ process.env.GSD_LEGACY_TELEMETRY_FILE = outputPath;
101
+
102
+ persistLegacyTelemetrySnapshot();
103
+
104
+ const report = JSON.parse(readFileSync(outputPath, "utf-8")) as ReturnType<typeof getLegacyTelemetryReport>;
105
+ assert.equal(typeof report.ts, "string");
106
+ assert.deepEqual(report.counters, {
107
+ "legacy.markdownFallbackUsed": 0,
108
+ "legacy.workflowEngineUsed": 0,
109
+ "legacy.uokFallbackUsed": 0,
110
+ "legacy.mcpAliasUsed": 0,
111
+ "legacy.componentFormatUsed": 0,
112
+ "legacy.providerDefaultUsed": 0,
113
+ });
114
+ } finally {
115
+ if (previousOutput === undefined) delete process.env.GSD_LEGACY_TELEMETRY_FILE;
116
+ else process.env.GSD_LEGACY_TELEMETRY_FILE = previousOutput;
117
+ resetLegacyTelemetry();
118
+ rmSync(base, { recursive: true, force: true });
119
+ }
120
+ });
121
+
122
+ test("deriveState increments markdown fallback telemetry on explicit legacy fallback", async () => {
123
+ const base = mkdtempSync(join(tmpdir(), "gsd-legacy-telemetry-"));
124
+ const originalFallback = process.env.GSD_ALLOW_MARKDOWN_DERIVE_FALLBACK;
125
+ try {
126
+ closeDatabase();
127
+ resetLegacyTelemetry();
128
+ invalidateStateCache();
129
+ process.env.GSD_ALLOW_MARKDOWN_DERIVE_FALLBACK = "1";
130
+ mkdirSync(join(base, ".gsd", "milestones", "M001"), { recursive: true });
131
+ writeFileSync(join(base, ".gsd", "milestones", "M001", "M001-CONTEXT.md"), "# M001: Legacy\n");
132
+
133
+ const state = await deriveState(base);
134
+
135
+ assert.equal(state.activeMilestone?.id, "M001");
136
+ assert.equal(getLegacyTelemetry()["legacy.markdownFallbackUsed"], 1);
137
+ } finally {
138
+ invalidateStateCache();
139
+ resetLegacyTelemetry();
140
+ if (originalFallback === undefined) delete process.env.GSD_ALLOW_MARKDOWN_DERIVE_FALLBACK;
141
+ else process.env.GSD_ALLOW_MARKDOWN_DERIVE_FALLBACK = originalFallback;
142
+ rmSync(base, { recursive: true, force: true });
143
+ }
144
+ });
@@ -9,16 +9,36 @@ import { readFileSync } from "node:fs";
9
9
  import { join, dirname } from "node:path";
10
10
  import { fileURLToPath } from "node:url";
11
11
 
12
+ import { decideMemoryPressure } from "../auto/workflow-kernel.ts";
13
+ import { measureMemoryPressure } from "../auto/workflow-memory-pressure.ts";
14
+
12
15
  const __dirname = dirname(fileURLToPath(import.meta.url));
13
16
  const loopSource = readFileSync(join(__dirname, "..", "auto", "loop.ts"), "utf-8");
14
17
 
15
18
  describe("memory pressure monitoring (#3331)", () => {
16
- test("checkMemoryPressure function exists", () => {
17
- assert.match(loopSource, /function checkMemoryPressure/);
19
+ test("measureMemoryPressure reports pressure above threshold", () => {
20
+ const snapshot = measureMemoryPressure({
21
+ threshold: 0.5,
22
+ deps: {
23
+ memoryUsage: () => ({ heapUsed: 768 * 1024 * 1024 }),
24
+ heapLimitBytes: () => 1024 * 1024 * 1024,
25
+ },
26
+ });
27
+
28
+ assert.equal(snapshot.pressured, true);
29
+ assert.equal(snapshot.heapMB, 768);
30
+ assert.equal(snapshot.limitMB, 1024);
18
31
  });
19
32
 
20
- test("MEMORY_PRESSURE_THRESHOLD constant is defined", () => {
21
- assert.match(loopSource, /MEMORY_PRESSURE_THRESHOLD\s*=\s*0\.\d+/);
33
+ test("measureMemoryPressure defaults to a sub-100-percent threshold", () => {
34
+ const snapshot = measureMemoryPressure({
35
+ deps: {
36
+ memoryUsage: () => ({ heapUsed: 3584 * 1024 * 1024 }),
37
+ heapLimitBytes: () => 4096 * 1024 * 1024,
38
+ },
39
+ });
40
+
41
+ assert.equal(snapshot.pressured, true);
22
42
  });
23
43
 
24
44
  test("memory check runs every MEMORY_CHECK_INTERVAL iterations", () => {
@@ -26,8 +46,16 @@ describe("memory pressure monitoring (#3331)", () => {
26
46
  });
27
47
 
28
48
  test("memory pressure triggers graceful stopAuto", () => {
29
- assert.match(loopSource, /mem\.pressured/);
30
- assert.match(loopSource, /Stopping gracefully to prevent OOM/);
49
+ const decision = decideMemoryPressure({
50
+ pressured: true,
51
+ heapMB: 3900,
52
+ limitMB: 4096,
53
+ pct: 0.95,
54
+ iteration: 10,
55
+ });
56
+
57
+ assert.equal(decision.action, "stop");
58
+ assert.match(decision.stopMessage, /Stopping gracefully to prevent OOM/);
31
59
  });
32
60
  });
33
61
 
@@ -55,15 +83,11 @@ describe("stuck detection persistence (#3704)", () => {
55
83
  // unit_dispatches (recentUnits) + runtime_kv (stuckRecoveryAttempts).
56
84
  // The stuck-state-via-db.test.ts suite covers the round-trip.
57
85
 
58
- test("saveStuckState called in standard dev path as well as custom engine path (#4382)", () => {
59
- // Count all call-sites of saveStuckState (excluding the function definition itself).
60
- // After the fix, both the custom-engine path and the standard dev path must each
61
- // call saveStuckState so stuckRecoveryAttempts survives session restarts.
62
- const callMatches = loopSource.match(/saveStuckState\(s,\s*loopState\)/g) ?? [];
63
- assert.ok(
64
- callMatches.length >= 2,
65
- `saveStuckState must be called in both the custom-engine path and the standard dev path ` +
66
- `(found ${callMatches.length} call(s) — standard path is missing its call, #4382)`,
67
- );
86
+ test("completeIteration centralizes stuck-state persistence for both loop paths (#4382)", () => {
87
+ assert.match(loopSource, /const completeIteration = \(\): void =>/);
88
+ assert.match(loopSource, /completeWorkflowIteration\(/);
89
+ assert.match(loopSource, /saveStuckState:\s*\(\)\s*=>\s*saveStuckState\(s,\s*loopState\)/);
90
+ assert.match(loopSource, /completeIteration,/);
91
+ assert.match(loopSource, /completeIteration\(\);/);
68
92
  });
69
93
  });
@@ -1,3 +1,5 @@
1
+ // Project/App: GSD-2
2
+ // File Purpose: Verifies model routing decisions and legacy provider-default telemetry.
1
3
  import test, { describe } from "node:test";
2
4
  import assert from "node:assert/strict";
3
5
 
@@ -14,6 +16,7 @@ import {
14
16
  } from "../model-router.js";
15
17
  import type { DynamicRoutingConfig, RoutingDecision, ModelCapabilities } from "../model-router.js";
16
18
  import type { ClassificationResult } from "../complexity-classifier.js";
19
+ import { getLegacyTelemetry, resetLegacyTelemetry } from "../legacy-telemetry.js";
17
20
 
18
21
  // ─── Helpers ─────────────────────────────────────────────────────────────────
19
22
 
@@ -297,16 +300,28 @@ test("cross-provider: configured primary available by bare ID wins over equivale
297
300
  // ─── resolveModelForTier (provider-agnostic tier resolution) ────────────────
298
301
 
299
302
  test("resolveModelForTier: returns canonical Anthropic model when no available models", () => {
300
- assert.equal(resolveModelForTier("heavy", []), "claude-opus-4-6");
301
- assert.equal(resolveModelForTier("standard", []), "claude-sonnet-4-6");
302
- assert.equal(resolveModelForTier("light", []), "claude-haiku-4-5");
303
+ try {
304
+ resetLegacyTelemetry();
305
+ assert.equal(resolveModelForTier("heavy", []), "claude-opus-4-6");
306
+ assert.equal(resolveModelForTier("standard", []), "claude-sonnet-4-6");
307
+ assert.equal(resolveModelForTier("light", []), "claude-haiku-4-5");
308
+ assert.equal(getLegacyTelemetry()["legacy.providerDefaultUsed"], 3);
309
+ } finally {
310
+ resetLegacyTelemetry();
311
+ }
303
312
  });
304
313
 
305
314
  test("resolveModelForTier: returns canonical model when it is available", () => {
306
- assert.equal(
307
- resolveModelForTier("heavy", ["claude-opus-4-6", "claude-sonnet-4-6"]),
308
- "claude-opus-4-6",
309
- );
315
+ try {
316
+ resetLegacyTelemetry();
317
+ assert.equal(
318
+ resolveModelForTier("heavy", ["claude-opus-4-6", "claude-sonnet-4-6"]),
319
+ "claude-opus-4-6",
320
+ );
321
+ assert.equal(getLegacyTelemetry()["legacy.providerDefaultUsed"], 0);
322
+ } finally {
323
+ resetLegacyTelemetry();
324
+ }
310
325
  });
311
326
 
312
327
  test("resolveModelForTier: does not prefer canonical over cheaper same-tier model", () => {
@@ -341,11 +356,17 @@ test("resolveModelForTier: picks light-tier cross-provider model", () => {
341
356
  });
342
357
 
343
358
  test("resolveModelForTier: falls back to canonical when no tier match available", () => {
344
- // Only unknown models available — getModelTier classifies unknowns as
345
- // "standard", so a request for "heavy" finds no match and the canonical
346
- // Anthropic ID is returned as a documented fallback.
347
- const result = resolveModelForTier("heavy", ["some-custom-model"]);
348
- assert.equal(result, "claude-opus-4-6");
359
+ try {
360
+ resetLegacyTelemetry();
361
+ // Only unknown models available getModelTier classifies unknowns as
362
+ // "standard", so a request for "heavy" finds no match and the canonical
363
+ // Anthropic ID is returned as a documented fallback.
364
+ const result = resolveModelForTier("heavy", ["some-custom-model"]);
365
+ assert.equal(result, "claude-opus-4-6");
366
+ assert.equal(getLegacyTelemetry()["legacy.providerDefaultUsed"], 1);
367
+ } finally {
368
+ resetLegacyTelemetry();
369
+ }
349
370
  });
350
371
 
351
372
  test("resolveModelForTier: handles provider-prefixed available models", () => {