gsd-pi 2.43.0 → 2.44.0-dev.62b5d6c

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 (568) hide show
  1. package/dist/cli.js +13 -1
  2. package/dist/help-text.js +24 -0
  3. package/dist/resources/extensions/bg-shell/overlay.js +3 -0
  4. package/dist/resources/extensions/github-sync/sync.js +2 -1
  5. package/dist/resources/extensions/gsd/auto/loop.js +0 -2
  6. package/dist/resources/extensions/gsd/auto/phases.js +7 -12
  7. package/dist/resources/extensions/gsd/auto-dashboard.js +19 -18
  8. package/dist/resources/extensions/gsd/auto-direct-dispatch.js +34 -19
  9. package/dist/resources/extensions/gsd/auto-dispatch.js +36 -21
  10. package/dist/resources/extensions/gsd/auto-post-unit.js +128 -14
  11. package/dist/resources/extensions/gsd/auto-prompts.js +202 -92
  12. package/dist/resources/extensions/gsd/auto-recovery.js +83 -135
  13. package/dist/resources/extensions/gsd/auto-supervisor.js +14 -0
  14. package/dist/resources/extensions/gsd/auto-timeout-recovery.js +4 -7
  15. package/dist/resources/extensions/gsd/auto-verification.js +5 -10
  16. package/dist/resources/extensions/gsd/auto-worktree.js +123 -30
  17. package/dist/resources/extensions/gsd/auto.js +1 -4
  18. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +611 -0
  19. package/dist/resources/extensions/gsd/bootstrap/dynamic-tools.js +28 -3
  20. package/dist/resources/extensions/gsd/bootstrap/register-hooks.js +7 -0
  21. package/dist/resources/extensions/gsd/commands/catalog.js +3 -1
  22. package/dist/resources/extensions/gsd/commands/handlers/ops.js +15 -1
  23. package/dist/resources/extensions/gsd/commands-handlers.js +1 -1
  24. package/dist/resources/extensions/gsd/commands-maintenance.js +78 -3
  25. package/dist/resources/extensions/gsd/dashboard-overlay.js +32 -31
  26. package/dist/resources/extensions/gsd/db-writer.js +95 -4
  27. package/dist/resources/extensions/gsd/dispatch-guard.js +35 -30
  28. package/dist/resources/extensions/gsd/doctor-checks.js +28 -11
  29. package/dist/resources/extensions/gsd/doctor-environment.js +28 -0
  30. package/dist/resources/extensions/gsd/doctor-types.js +0 -15
  31. package/dist/resources/extensions/gsd/doctor.js +46 -282
  32. package/dist/resources/extensions/gsd/file-watcher.js +5 -1
  33. package/dist/resources/extensions/gsd/files.js +14 -198
  34. package/dist/resources/extensions/gsd/git-service.js +4 -0
  35. package/dist/resources/extensions/gsd/gitignore.js +4 -0
  36. package/dist/resources/extensions/gsd/gsd-db.js +819 -197
  37. package/dist/resources/extensions/gsd/guided-flow.js +18 -8
  38. package/dist/resources/extensions/gsd/markdown-renderer.js +862 -0
  39. package/dist/resources/extensions/gsd/md-importer.js +182 -4
  40. package/dist/resources/extensions/gsd/native-git-bridge.js +10 -1
  41. package/dist/resources/extensions/gsd/parallel-eligibility.js +14 -19
  42. package/dist/resources/extensions/gsd/parallel-orchestrator.js +38 -0
  43. package/dist/resources/extensions/gsd/parsers-legacy.js +239 -0
  44. package/dist/resources/extensions/gsd/preferences-types.js +1 -0
  45. package/dist/resources/extensions/gsd/preferences-validation.js +9 -0
  46. package/dist/resources/extensions/gsd/preferences.js +1 -0
  47. package/dist/resources/extensions/gsd/prompts/complete-slice.md +22 -9
  48. package/dist/resources/extensions/gsd/prompts/discuss.md +2 -2
  49. package/dist/resources/extensions/gsd/prompts/execute-task.md +15 -5
  50. package/dist/resources/extensions/gsd/prompts/guided-complete-slice.md +1 -1
  51. package/dist/resources/extensions/gsd/prompts/guided-execute-task.md +1 -1
  52. package/dist/resources/extensions/gsd/prompts/guided-plan-milestone.md +1 -1
  53. package/dist/resources/extensions/gsd/prompts/plan-milestone.md +6 -10
  54. package/dist/resources/extensions/gsd/prompts/plan-slice.md +4 -7
  55. package/dist/resources/extensions/gsd/prompts/reactive-execute.md +3 -3
  56. package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +6 -7
  57. package/dist/resources/extensions/gsd/prompts/replan-slice.md +6 -6
  58. package/dist/resources/extensions/gsd/reactive-graph.js +33 -3
  59. package/dist/resources/extensions/gsd/skill-health.js +3 -1
  60. package/dist/resources/extensions/gsd/state.js +484 -30
  61. package/dist/resources/extensions/gsd/tools/complete-milestone.js +128 -0
  62. package/dist/resources/extensions/gsd/tools/complete-slice.js +244 -0
  63. package/dist/resources/extensions/gsd/tools/complete-task.js +204 -0
  64. package/dist/resources/extensions/gsd/tools/plan-milestone.js +205 -0
  65. package/dist/resources/extensions/gsd/tools/plan-slice.js +155 -0
  66. package/dist/resources/extensions/gsd/tools/plan-task.js +94 -0
  67. package/dist/resources/extensions/gsd/tools/reassess-roadmap.js +152 -0
  68. package/dist/resources/extensions/gsd/tools/replan-slice.js +146 -0
  69. package/dist/resources/extensions/gsd/triage-resolution.js +17 -1
  70. package/dist/resources/extensions/gsd/undo.js +197 -3
  71. package/dist/resources/extensions/gsd/visualizer-data.js +53 -16
  72. package/dist/resources/extensions/gsd/workspace-index.js +63 -39
  73. package/dist/web/standalone/.next/BUILD_ID +1 -1
  74. package/dist/web/standalone/.next/app-path-routes-manifest.json +17 -16
  75. package/dist/web/standalone/.next/build-manifest.json +4 -4
  76. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  77. package/dist/web/standalone/.next/react-loadable-manifest.json +1 -1
  78. package/dist/web/standalone/.next/required-server-files.json +4 -4
  79. package/dist/web/standalone/.next/routes-manifest.json +6 -0
  80. package/dist/web/standalone/.next/server/app/_global-error/page.js +3 -3
  81. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  82. package/dist/web/standalone/.next/server/app/_global-error.html +2 -2
  83. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  84. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  85. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  86. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  87. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  88. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  89. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  90. package/dist/web/standalone/.next/server/app/_not-found/page.js +2 -2
  91. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  92. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  93. package/dist/web/standalone/.next/server/app/_not-found.rsc +4 -4
  94. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +4 -4
  95. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  96. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +4 -4
  97. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  98. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  99. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  100. package/dist/web/standalone/.next/server/app/api/boot/route.js +1 -1
  101. package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
  102. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route.js +1 -1
  103. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
  104. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route.js +1 -1
  105. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
  106. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route.js +2 -2
  107. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
  108. package/dist/web/standalone/.next/server/app/api/browse-directories/route.js +1 -1
  109. package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
  110. package/dist/web/standalone/.next/server/app/api/captures/route.js +1 -1
  111. package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
  112. package/dist/web/standalone/.next/server/app/api/cleanup/route.js +1 -1
  113. package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
  114. package/dist/web/standalone/.next/server/app/api/dev-mode/route.js +1 -1
  115. package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
  116. package/dist/web/standalone/.next/server/app/api/doctor/route.js +1 -1
  117. package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
  118. package/dist/web/standalone/.next/server/app/api/export-data/route.js +1 -1
  119. package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
  120. package/dist/web/standalone/.next/server/app/api/files/route.js +1 -1
  121. package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
  122. package/dist/web/standalone/.next/server/app/api/forensics/route.js +1 -1
  123. package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
  124. package/dist/web/standalone/.next/server/app/api/git/route.js +1 -1
  125. package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
  126. package/dist/web/standalone/.next/server/app/api/history/route.js +1 -1
  127. package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
  128. package/dist/web/standalone/.next/server/app/api/hooks/route.js +1 -1
  129. package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
  130. package/dist/web/standalone/.next/server/app/api/inspect/route.js +1 -1
  131. package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
  132. package/dist/web/standalone/.next/server/app/api/knowledge/route.js +1 -1
  133. package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
  134. package/dist/web/standalone/.next/server/app/api/live-state/route.js +1 -1
  135. package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
  136. package/dist/web/standalone/.next/server/app/api/onboarding/route.js +1 -1
  137. package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
  138. package/dist/web/standalone/.next/server/app/api/preferences/route.js +1 -1
  139. package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
  140. package/dist/web/standalone/.next/server/app/api/projects/route.js +1 -1
  141. package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
  142. package/dist/web/standalone/.next/server/app/api/recovery/route.js +1 -1
  143. package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
  144. package/dist/web/standalone/.next/server/app/api/remote-questions/route.js +5 -5
  145. package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
  146. package/dist/web/standalone/.next/server/app/api/session/browser/route.js +1 -1
  147. package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
  148. package/dist/web/standalone/.next/server/app/api/session/command/route.js +1 -1
  149. package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
  150. package/dist/web/standalone/.next/server/app/api/session/events/route.js +2 -2
  151. package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
  152. package/dist/web/standalone/.next/server/app/api/session/manage/route.js +1 -1
  153. package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
  154. package/dist/web/standalone/.next/server/app/api/settings-data/route.js +1 -1
  155. package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
  156. package/dist/web/standalone/.next/server/app/api/shutdown/route.js +1 -1
  157. package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  158. package/dist/web/standalone/.next/server/app/api/skill-health/route.js +1 -1
  159. package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
  160. package/dist/web/standalone/.next/server/app/api/steer/route.js +1 -1
  161. package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
  162. package/dist/web/standalone/.next/server/app/api/switch-root/route.js +1 -0
  163. package/dist/web/standalone/.next/server/app/api/switch-root/route.js.nft.json +1 -0
  164. package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -0
  165. package/dist/web/standalone/.next/server/app/api/terminal/input/route.js +1 -1
  166. package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
  167. package/dist/web/standalone/.next/server/app/api/terminal/resize/route.js +2 -2
  168. package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
  169. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route.js +2 -2
  170. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
  171. package/dist/web/standalone/.next/server/app/api/terminal/stream/route.js +4 -4
  172. package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
  173. package/dist/web/standalone/.next/server/app/api/terminal/upload/route.js +1 -1
  174. package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
  175. package/dist/web/standalone/.next/server/app/api/undo/route.js +1 -1
  176. package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
  177. package/dist/web/standalone/.next/server/app/api/update/route.js +1 -1
  178. package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
  179. package/dist/web/standalone/.next/server/app/api/visualizer/route.js +1 -1
  180. package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
  181. package/dist/web/standalone/.next/server/app/index.html +1 -1
  182. package/dist/web/standalone/.next/server/app/index.rsc +5 -5
  183. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  184. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +5 -5
  185. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  186. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +4 -4
  187. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  188. package/dist/web/standalone/.next/server/app/page.js +2 -2
  189. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  190. package/dist/web/standalone/.next/server/app-paths-manifest.json +17 -16
  191. package/dist/web/standalone/.next/server/chunks/229.js +3 -3
  192. package/dist/web/standalone/.next/server/chunks/471.js +3 -3
  193. package/dist/web/standalone/.next/server/functions-config-manifest.json +1 -0
  194. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  195. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  196. package/dist/web/standalone/.next/server/middleware.js +2 -2
  197. package/dist/web/standalone/.next/server/next-font-manifest.js +1 -1
  198. package/dist/web/standalone/.next/server/next-font-manifest.json +1 -1
  199. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  200. package/dist/web/standalone/.next/server/pages/500.html +2 -2
  201. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  202. package/dist/web/standalone/.next/static/chunks/{4024.c195dc1fdd2adbea.js → 4024.0de81b543b28b9fe.js} +2 -2
  203. package/dist/web/standalone/.next/static/chunks/app/_global-error/{page-d07a2c023f1aef1e.js → page-d83ba70a25a85472.js} +1 -1
  204. package/dist/web/standalone/.next/static/chunks/app/_not-found/page-f2a7482d42a5614b.js +1 -0
  205. package/dist/web/standalone/.next/static/chunks/app/api/boot/{route-d07a2c023f1aef1e.js → route-d83ba70a25a85472.js} +1 -1
  206. package/dist/web/standalone/.next/static/chunks/app/api/bridge-terminal/input/{route-d07a2c023f1aef1e.js → route-d83ba70a25a85472.js} +1 -1
  207. package/dist/web/standalone/.next/static/chunks/app/api/bridge-terminal/resize/{route-d07a2c023f1aef1e.js → route-d83ba70a25a85472.js} +1 -1
  208. package/dist/web/standalone/.next/static/chunks/app/api/bridge-terminal/stream/route-d83ba70a25a85472.js +1 -0
  209. package/dist/web/standalone/.next/static/chunks/app/api/browse-directories/route-d83ba70a25a85472.js +1 -0
  210. package/dist/web/standalone/.next/static/chunks/app/api/captures/route-d83ba70a25a85472.js +1 -0
  211. package/dist/web/standalone/.next/static/chunks/app/api/cleanup/route-d83ba70a25a85472.js +1 -0
  212. package/dist/web/standalone/.next/static/chunks/app/api/dev-mode/route-d83ba70a25a85472.js +1 -0
  213. package/dist/web/standalone/.next/static/chunks/app/api/doctor/route-d83ba70a25a85472.js +1 -0
  214. package/dist/web/standalone/.next/static/chunks/app/api/export-data/route-d83ba70a25a85472.js +1 -0
  215. package/dist/web/standalone/.next/static/chunks/app/api/files/route-d83ba70a25a85472.js +1 -0
  216. package/dist/web/standalone/.next/static/chunks/app/api/forensics/route-d83ba70a25a85472.js +1 -0
  217. package/dist/web/standalone/.next/static/chunks/app/api/git/route-d83ba70a25a85472.js +1 -0
  218. package/dist/web/standalone/.next/static/chunks/app/api/history/route-d83ba70a25a85472.js +1 -0
  219. package/dist/web/standalone/.next/static/chunks/app/api/hooks/route-d83ba70a25a85472.js +1 -0
  220. package/dist/web/standalone/.next/static/chunks/app/api/inspect/route-d83ba70a25a85472.js +1 -0
  221. package/dist/web/standalone/.next/static/chunks/app/api/knowledge/route-d83ba70a25a85472.js +1 -0
  222. package/dist/web/standalone/.next/static/chunks/app/api/live-state/route-d83ba70a25a85472.js +1 -0
  223. package/dist/web/standalone/.next/static/chunks/app/api/onboarding/route-d83ba70a25a85472.js +1 -0
  224. package/dist/web/standalone/.next/static/chunks/app/api/preferences/route-d83ba70a25a85472.js +1 -0
  225. package/dist/web/standalone/.next/static/chunks/app/api/projects/route-d83ba70a25a85472.js +1 -0
  226. package/dist/web/standalone/.next/static/chunks/app/api/recovery/route-d83ba70a25a85472.js +1 -0
  227. package/dist/web/standalone/.next/static/chunks/app/api/remote-questions/route-d83ba70a25a85472.js +1 -0
  228. package/dist/web/standalone/.next/static/chunks/app/api/session/browser/route-d83ba70a25a85472.js +1 -0
  229. package/dist/web/standalone/.next/static/chunks/app/api/session/command/route-d83ba70a25a85472.js +1 -0
  230. package/dist/web/standalone/.next/static/chunks/app/api/session/events/route-d83ba70a25a85472.js +1 -0
  231. package/dist/web/standalone/.next/static/chunks/app/api/session/manage/route-d83ba70a25a85472.js +1 -0
  232. package/dist/web/standalone/.next/static/chunks/app/api/settings-data/route-d83ba70a25a85472.js +1 -0
  233. package/dist/web/standalone/.next/static/chunks/app/api/shutdown/route-d83ba70a25a85472.js +1 -0
  234. package/dist/web/standalone/.next/static/chunks/app/api/skill-health/route-d83ba70a25a85472.js +1 -0
  235. package/dist/web/standalone/.next/static/chunks/app/api/steer/route-d83ba70a25a85472.js +1 -0
  236. package/dist/web/standalone/.next/static/chunks/app/api/switch-root/route-d83ba70a25a85472.js +1 -0
  237. package/dist/web/standalone/.next/static/chunks/app/api/terminal/input/route-d83ba70a25a85472.js +1 -0
  238. package/dist/web/standalone/.next/static/chunks/app/api/terminal/resize/route-d83ba70a25a85472.js +1 -0
  239. package/dist/web/standalone/.next/static/chunks/app/api/terminal/sessions/route-d83ba70a25a85472.js +1 -0
  240. package/dist/web/standalone/.next/static/chunks/app/api/terminal/stream/route-d83ba70a25a85472.js +1 -0
  241. package/dist/web/standalone/.next/static/chunks/app/api/terminal/upload/route-d83ba70a25a85472.js +1 -0
  242. package/dist/web/standalone/.next/static/chunks/app/api/undo/route-d83ba70a25a85472.js +1 -0
  243. package/dist/web/standalone/.next/static/chunks/app/api/update/route-d83ba70a25a85472.js +1 -0
  244. package/dist/web/standalone/.next/static/chunks/app/api/visualizer/route-d83ba70a25a85472.js +1 -0
  245. package/dist/web/standalone/.next/static/chunks/app/layout-a16c7a7ecdf0c2cf.js +1 -0
  246. package/dist/web/standalone/.next/static/chunks/app/page-b9367c5ae13b99c6.js +1 -0
  247. package/dist/web/standalone/.next/static/chunks/{main-app-2f2ee7b85712c2bd.js → main-app-fdab67f7802d7832.js} +1 -1
  248. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/app-error-d83ba70a25a85472.js +1 -0
  249. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/forbidden-d83ba70a25a85472.js +1 -0
  250. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-459824ffb8c323dd.js +1 -0
  251. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/not-found-d83ba70a25a85472.js +1 -0
  252. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/unauthorized-d83ba70a25a85472.js +1 -0
  253. package/dist/web/standalone/.next/static/chunks/{webpack-fa307370fcf9fb2c.js → webpack-9014b5adb127a98a.js} +1 -1
  254. package/dist/web/standalone/.next/static/css/8a727f372cf53002.css +1 -0
  255. package/dist/web/standalone/.next/static/fOnWQBjWXMKUs4bqTg530/_buildManifest.js +1 -0
  256. package/dist/web/standalone/node_modules/node-pty/build/Makefile +2 -2
  257. package/dist/web/standalone/node_modules/node-pty/build/Release/pty.node +0 -0
  258. package/dist/web/standalone/node_modules/node-pty/build/pty.target.mk +14 -14
  259. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api.target.mk +14 -14
  260. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_except.target.mk +14 -14
  261. package/dist/web/standalone/node_modules/node-pty/node-addon-api/node_addon_api_maybe.target.mk +14 -14
  262. package/dist/web/standalone/server.js +1 -1
  263. package/package.json +4 -4
  264. package/packages/pi-ai/dist/models.custom.d.ts +173 -0
  265. package/packages/pi-ai/dist/models.custom.d.ts.map +1 -0
  266. package/packages/pi-ai/dist/models.custom.js +170 -0
  267. package/packages/pi-ai/dist/models.custom.js.map +1 -0
  268. package/packages/pi-ai/dist/models.d.ts.map +1 -1
  269. package/packages/pi-ai/dist/models.js +16 -1
  270. package/packages/pi-ai/dist/models.js.map +1 -1
  271. package/packages/pi-ai/dist/models.test.d.ts +2 -0
  272. package/packages/pi-ai/dist/models.test.d.ts.map +1 -0
  273. package/packages/pi-ai/dist/models.test.js +67 -0
  274. package/packages/pi-ai/dist/models.test.js.map +1 -0
  275. package/packages/pi-ai/src/models.custom.ts +172 -0
  276. package/packages/pi-ai/src/models.test.ts +85 -0
  277. package/packages/pi-ai/src/models.ts +17 -1
  278. package/packages/pi-coding-agent/dist/core/agent-session.d.ts +10 -3
  279. package/packages/pi-coding-agent/dist/core/agent-session.d.ts.map +1 -1
  280. package/packages/pi-coding-agent/dist/core/agent-session.js +21 -34
  281. package/packages/pi-coding-agent/dist/core/agent-session.js.map +1 -1
  282. package/packages/pi-coding-agent/dist/core/compaction/branch-summarization.d.ts +2 -2
  283. package/packages/pi-coding-agent/dist/core/compaction/branch-summarization.d.ts.map +1 -1
  284. package/packages/pi-coding-agent/dist/core/compaction/branch-summarization.js.map +1 -1
  285. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts +2 -2
  286. package/packages/pi-coding-agent/dist/core/compaction/compaction.d.ts.map +1 -1
  287. package/packages/pi-coding-agent/dist/core/compaction/compaction.js.map +1 -1
  288. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js +4 -4
  289. package/packages/pi-coding-agent/dist/core/compaction-orchestrator.js.map +1 -1
  290. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts +1 -1
  291. package/packages/pi-coding-agent/dist/core/extensions/index.d.ts.map +1 -1
  292. package/packages/pi-coding-agent/dist/core/extensions/index.js.map +1 -1
  293. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts +6 -0
  294. package/packages/pi-coding-agent/dist/core/extensions/loader.d.ts.map +1 -1
  295. package/packages/pi-coding-agent/dist/core/extensions/loader.js +80 -0
  296. package/packages/pi-coding-agent/dist/core/extensions/loader.js.map +1 -1
  297. package/packages/pi-coding-agent/dist/core/extensions/loader.test.js +63 -0
  298. package/packages/pi-coding-agent/dist/core/extensions/loader.test.js.map +1 -1
  299. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts +37 -0
  300. package/packages/pi-coding-agent/dist/core/extensions/types.d.ts.map +1 -1
  301. package/packages/pi-coding-agent/dist/core/extensions/types.js.map +1 -1
  302. package/packages/pi-coding-agent/dist/core/fallback-resolver.d.ts.map +1 -1
  303. package/packages/pi-coding-agent/dist/core/fallback-resolver.js +2 -3
  304. package/packages/pi-coding-agent/dist/core/fallback-resolver.js.map +1 -1
  305. package/packages/pi-coding-agent/dist/core/fallback-resolver.test.js +12 -2
  306. package/packages/pi-coding-agent/dist/core/fallback-resolver.test.js.map +1 -1
  307. package/packages/pi-coding-agent/dist/core/lifecycle-hooks.d.ts +38 -0
  308. package/packages/pi-coding-agent/dist/core/lifecycle-hooks.d.ts.map +1 -0
  309. package/packages/pi-coding-agent/dist/core/lifecycle-hooks.js +192 -0
  310. package/packages/pi-coding-agent/dist/core/lifecycle-hooks.js.map +1 -0
  311. package/packages/pi-coding-agent/dist/core/lsp/client.d.ts +5 -0
  312. package/packages/pi-coding-agent/dist/core/lsp/client.d.ts.map +1 -1
  313. package/packages/pi-coding-agent/dist/core/lsp/client.js +69 -21
  314. package/packages/pi-coding-agent/dist/core/lsp/client.js.map +1 -1
  315. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.d.ts +2 -0
  316. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.d.ts.map +1 -0
  317. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js +255 -0
  318. package/packages/pi-coding-agent/dist/core/model-registry-auth-mode.test.js.map +1 -0
  319. package/packages/pi-coding-agent/dist/core/model-registry.d.ts +15 -0
  320. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  321. package/packages/pi-coding-agent/dist/core/model-registry.js +40 -3
  322. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  323. package/packages/pi-coding-agent/dist/core/package-commands.d.ts +25 -0
  324. package/packages/pi-coding-agent/dist/core/package-commands.d.ts.map +1 -0
  325. package/packages/pi-coding-agent/dist/core/package-commands.js +253 -0
  326. package/packages/pi-coding-agent/dist/core/package-commands.js.map +1 -0
  327. package/packages/pi-coding-agent/dist/core/package-commands.test.d.ts +2 -0
  328. package/packages/pi-coding-agent/dist/core/package-commands.test.d.ts.map +1 -0
  329. package/packages/pi-coding-agent/dist/core/package-commands.test.js +225 -0
  330. package/packages/pi-coding-agent/dist/core/package-commands.test.js.map +1 -0
  331. package/packages/pi-coding-agent/dist/core/sdk.d.ts.map +1 -1
  332. package/packages/pi-coding-agent/dist/core/sdk.js +4 -0
  333. package/packages/pi-coding-agent/dist/core/sdk.js.map +1 -1
  334. package/packages/pi-coding-agent/dist/index.d.ts +3 -1
  335. package/packages/pi-coding-agent/dist/index.d.ts.map +1 -1
  336. package/packages/pi-coding-agent/dist/index.js +1 -0
  337. package/packages/pi-coding-agent/dist/index.js.map +1 -1
  338. package/packages/pi-coding-agent/dist/main.d.ts.map +1 -1
  339. package/packages/pi-coding-agent/dist/main.js +11 -199
  340. package/packages/pi-coding-agent/dist/main.js.map +1 -1
  341. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts +6 -0
  342. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.d.ts.map +1 -1
  343. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js +21 -0
  344. package/packages/pi-coding-agent/dist/modes/interactive/components/footer.js.map +1 -1
  345. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts +1 -1
  346. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  347. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js +8 -15
  348. package/packages/pi-coding-agent/dist/modes/interactive/theme/theme.js.map +1 -1
  349. package/packages/pi-coding-agent/dist/modes/print-mode.d.ts.map +1 -1
  350. package/packages/pi-coding-agent/dist/modes/print-mode.js +45 -34
  351. package/packages/pi-coding-agent/dist/modes/print-mode.js.map +1 -1
  352. package/packages/pi-coding-agent/dist/modes/rpc/rpc-client.d.ts +1 -0
  353. package/packages/pi-coding-agent/dist/modes/rpc/rpc-client.d.ts.map +1 -1
  354. package/packages/pi-coding-agent/dist/modes/rpc/rpc-client.js +7 -2
  355. package/packages/pi-coding-agent/dist/modes/rpc/rpc-client.js.map +1 -1
  356. package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.d.ts.map +1 -1
  357. package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.js +2 -1
  358. package/packages/pi-coding-agent/dist/modes/rpc/rpc-mode.js.map +1 -1
  359. package/packages/pi-coding-agent/package.json +1 -1
  360. package/packages/pi-coding-agent/src/core/agent-session.ts +26 -37
  361. package/packages/pi-coding-agent/src/core/compaction/branch-summarization.ts +2 -2
  362. package/packages/pi-coding-agent/src/core/compaction/compaction.ts +3 -3
  363. package/packages/pi-coding-agent/src/core/compaction-orchestrator.ts +4 -4
  364. package/packages/pi-coding-agent/src/core/extensions/index.ts +5 -0
  365. package/packages/pi-coding-agent/src/core/extensions/loader.test.ts +96 -0
  366. package/packages/pi-coding-agent/src/core/extensions/loader.ts +89 -0
  367. package/packages/pi-coding-agent/src/core/extensions/types.ts +44 -0
  368. package/packages/pi-coding-agent/src/core/fallback-resolver.test.ts +15 -2
  369. package/packages/pi-coding-agent/src/core/fallback-resolver.ts +2 -3
  370. package/packages/pi-coding-agent/src/core/lifecycle-hooks.ts +274 -0
  371. package/packages/pi-coding-agent/src/core/lsp/client.ts +83 -21
  372. package/packages/pi-coding-agent/src/core/model-registry-auth-mode.test.ts +288 -0
  373. package/packages/pi-coding-agent/src/core/model-registry.ts +39 -3
  374. package/packages/pi-coding-agent/src/core/package-commands.test.ts +240 -0
  375. package/packages/pi-coding-agent/src/core/package-commands.ts +310 -0
  376. package/packages/pi-coding-agent/src/core/sdk.ts +4 -0
  377. package/packages/pi-coding-agent/src/index.ts +7 -0
  378. package/packages/pi-coding-agent/src/main.ts +11 -232
  379. package/packages/pi-coding-agent/src/modes/interactive/components/footer.ts +20 -0
  380. package/packages/pi-coding-agent/src/modes/interactive/theme/theme.ts +9 -16
  381. package/packages/pi-coding-agent/src/modes/print-mode.ts +42 -32
  382. package/packages/pi-coding-agent/src/modes/rpc/rpc-client.ts +8 -2
  383. package/packages/pi-coding-agent/src/modes/rpc/rpc-mode.ts +2 -1
  384. package/pkg/dist/modes/interactive/theme/theme.d.ts +1 -1
  385. package/pkg/dist/modes/interactive/theme/theme.d.ts.map +1 -1
  386. package/pkg/dist/modes/interactive/theme/theme.js +8 -15
  387. package/pkg/dist/modes/interactive/theme/theme.js.map +1 -1
  388. package/pkg/package.json +1 -1
  389. package/src/resources/extensions/bg-shell/overlay.ts +4 -0
  390. package/src/resources/extensions/github-sync/sync.ts +2 -1
  391. package/src/resources/extensions/gsd/auto/loop-deps.ts +0 -8
  392. package/src/resources/extensions/gsd/auto/loop.ts +0 -2
  393. package/src/resources/extensions/gsd/auto/phases.ts +7 -20
  394. package/src/resources/extensions/gsd/auto/types.ts +0 -1
  395. package/src/resources/extensions/gsd/auto-dashboard.ts +20 -16
  396. package/src/resources/extensions/gsd/auto-direct-dispatch.ts +34 -19
  397. package/src/resources/extensions/gsd/auto-dispatch.ts +38 -21
  398. package/src/resources/extensions/gsd/auto-post-unit.ts +150 -15
  399. package/src/resources/extensions/gsd/auto-prompts.ts +186 -103
  400. package/src/resources/extensions/gsd/auto-recovery.ts +77 -142
  401. package/src/resources/extensions/gsd/auto-supervisor.ts +14 -0
  402. package/src/resources/extensions/gsd/auto-timeout-recovery.ts +6 -7
  403. package/src/resources/extensions/gsd/auto-verification.ts +4 -9
  404. package/src/resources/extensions/gsd/auto-worktree.ts +126 -30
  405. package/src/resources/extensions/gsd/auto.ts +0 -9
  406. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +675 -4
  407. package/src/resources/extensions/gsd/bootstrap/dynamic-tools.ts +31 -3
  408. package/src/resources/extensions/gsd/bootstrap/register-hooks.ts +7 -0
  409. package/src/resources/extensions/gsd/commands/catalog.ts +3 -1
  410. package/src/resources/extensions/gsd/commands/handlers/ops.ts +15 -1
  411. package/src/resources/extensions/gsd/commands-handlers.ts +1 -1
  412. package/src/resources/extensions/gsd/commands-maintenance.ts +86 -3
  413. package/src/resources/extensions/gsd/dashboard-overlay.ts +17 -13
  414. package/src/resources/extensions/gsd/db-writer.ts +105 -4
  415. package/src/resources/extensions/gsd/dispatch-guard.ts +32 -30
  416. package/src/resources/extensions/gsd/doctor-checks.ts +25 -11
  417. package/src/resources/extensions/gsd/doctor-environment.ts +31 -0
  418. package/src/resources/extensions/gsd/doctor-types.ts +0 -23
  419. package/src/resources/extensions/gsd/doctor.ts +45 -295
  420. package/src/resources/extensions/gsd/file-watcher.ts +4 -1
  421. package/src/resources/extensions/gsd/files.ts +16 -220
  422. package/src/resources/extensions/gsd/git-service.ts +4 -0
  423. package/src/resources/extensions/gsd/gitignore.ts +4 -0
  424. package/src/resources/extensions/gsd/gsd-db.ts +1157 -370
  425. package/src/resources/extensions/gsd/guided-flow.ts +20 -8
  426. package/src/resources/extensions/gsd/markdown-renderer.ts +1098 -0
  427. package/src/resources/extensions/gsd/md-importer.ts +211 -2
  428. package/src/resources/extensions/gsd/native-git-bridge.ts +12 -1
  429. package/src/resources/extensions/gsd/parallel-eligibility.ts +14 -18
  430. package/src/resources/extensions/gsd/parallel-orchestrator.ts +43 -0
  431. package/src/resources/extensions/gsd/parsers-legacy.ts +271 -0
  432. package/src/resources/extensions/gsd/preferences-types.ts +3 -0
  433. package/src/resources/extensions/gsd/preferences-validation.ts +9 -0
  434. package/src/resources/extensions/gsd/preferences.ts +1 -0
  435. package/src/resources/extensions/gsd/prompts/complete-slice.md +22 -9
  436. package/src/resources/extensions/gsd/prompts/discuss.md +2 -2
  437. package/src/resources/extensions/gsd/prompts/execute-task.md +15 -5
  438. package/src/resources/extensions/gsd/prompts/guided-complete-slice.md +1 -1
  439. package/src/resources/extensions/gsd/prompts/guided-execute-task.md +1 -1
  440. package/src/resources/extensions/gsd/prompts/guided-plan-milestone.md +1 -1
  441. package/src/resources/extensions/gsd/prompts/plan-milestone.md +6 -10
  442. package/src/resources/extensions/gsd/prompts/plan-slice.md +4 -7
  443. package/src/resources/extensions/gsd/prompts/reactive-execute.md +3 -3
  444. package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +6 -7
  445. package/src/resources/extensions/gsd/prompts/replan-slice.md +6 -6
  446. package/src/resources/extensions/gsd/reactive-graph.ts +33 -3
  447. package/src/resources/extensions/gsd/skill-health.ts +2 -1
  448. package/src/resources/extensions/gsd/state.ts +547 -29
  449. package/src/resources/extensions/gsd/tests/atomic-task-closeout.test.ts +8 -120
  450. package/src/resources/extensions/gsd/tests/auto-loop.test.ts +20 -11
  451. package/src/resources/extensions/gsd/tests/auto-preflight.test.ts +1 -1
  452. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +150 -5
  453. package/src/resources/extensions/gsd/tests/auto-stash-merge.test.ts +121 -0
  454. package/src/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +15 -20
  455. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +1 -1
  456. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +410 -0
  457. package/src/resources/extensions/gsd/tests/complete-task.test.ts +439 -0
  458. package/src/resources/extensions/gsd/tests/custom-engine-loop-integration.test.ts +0 -2
  459. package/src/resources/extensions/gsd/tests/derive-state-crossval.test.ts +527 -0
  460. package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +593 -2
  461. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +104 -57
  462. package/src/resources/extensions/gsd/tests/doctor-completion-deferral.test.ts +22 -80
  463. package/src/resources/extensions/gsd/tests/doctor-enhancements.test.ts +5 -7
  464. package/src/resources/extensions/gsd/tests/doctor-environment-worktree.test.ts +175 -0
  465. package/src/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +38 -130
  466. package/src/resources/extensions/gsd/tests/doctor-roadmap-summary-atomicity.test.ts +38 -76
  467. package/src/resources/extensions/gsd/tests/doctor.test.ts +9 -19
  468. package/src/resources/extensions/gsd/tests/flag-file-db.test.ts +290 -0
  469. package/src/resources/extensions/gsd/tests/freeform-decisions.test.ts +240 -0
  470. package/src/resources/extensions/gsd/tests/git-service.test.ts +6 -2
  471. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +1 -1
  472. package/src/resources/extensions/gsd/tests/gsd-recover.test.ts +462 -0
  473. package/src/resources/extensions/gsd/tests/idle-recovery.test.ts +4 -172
  474. package/src/resources/extensions/gsd/tests/integration-proof.test.ts +643 -0
  475. package/src/resources/extensions/gsd/tests/journal-integration.test.ts +0 -3
  476. package/src/resources/extensions/gsd/tests/markdown-renderer.test.ts +1205 -0
  477. package/src/resources/extensions/gsd/tests/md-importer.test.ts +1 -1
  478. package/src/resources/extensions/gsd/tests/memory-store.test.ts +2 -2
  479. package/src/resources/extensions/gsd/tests/migrate-hierarchy.test.ts +439 -0
  480. package/src/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +2 -1
  481. package/src/resources/extensions/gsd/tests/migrate-writer.test.ts +2 -0
  482. package/src/resources/extensions/gsd/tests/parsers.test.ts +2 -1
  483. package/src/resources/extensions/gsd/tests/plan-milestone.test.ts +176 -113
  484. package/src/resources/extensions/gsd/tests/plan-slice-prompt.test.ts +7 -0
  485. package/src/resources/extensions/gsd/tests/plan-slice.test.ts +179 -0
  486. package/src/resources/extensions/gsd/tests/plan-task.test.ts +145 -0
  487. package/src/resources/extensions/gsd/tests/planning-crossval.test.ts +305 -0
  488. package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +139 -0
  489. package/src/resources/extensions/gsd/tests/reassess-handler.test.ts +325 -0
  490. package/src/resources/extensions/gsd/tests/replan-handler.test.ts +410 -0
  491. package/src/resources/extensions/gsd/tests/roadmap-slices.test.ts +1 -1
  492. package/src/resources/extensions/gsd/tests/rogue-file-detection.test.ts +296 -0
  493. package/src/resources/extensions/gsd/tests/schema-v9-sequence.test.ts +176 -0
  494. package/src/resources/extensions/gsd/tests/shared-wal.test.ts +216 -0
  495. package/src/resources/extensions/gsd/tests/token-cost-display.test.ts +118 -0
  496. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +11 -3
  497. package/src/resources/extensions/gsd/tests/undo.test.ts +321 -1
  498. package/src/resources/extensions/gsd/tests/validate-milestone.test.ts +1 -1
  499. package/src/resources/extensions/gsd/tests/verification-evidence.test.ts +0 -142
  500. package/src/resources/extensions/gsd/tests/worktree-health-dispatch.test.ts +12 -5
  501. package/src/resources/extensions/gsd/tools/complete-milestone.ts +176 -0
  502. package/src/resources/extensions/gsd/tools/complete-slice.ts +300 -0
  503. package/src/resources/extensions/gsd/tools/complete-task.ts +245 -0
  504. package/src/resources/extensions/gsd/tools/plan-milestone.ts +249 -0
  505. package/src/resources/extensions/gsd/tools/plan-slice.ts +194 -0
  506. package/src/resources/extensions/gsd/tools/plan-task.ts +116 -0
  507. package/src/resources/extensions/gsd/tools/reassess-roadmap.ts +203 -0
  508. package/src/resources/extensions/gsd/tools/replan-slice.ts +192 -0
  509. package/src/resources/extensions/gsd/triage-resolution.ts +20 -1
  510. package/src/resources/extensions/gsd/types.ts +50 -0
  511. package/src/resources/extensions/gsd/undo.ts +247 -3
  512. package/src/resources/extensions/gsd/visualizer-data.ts +54 -17
  513. package/src/resources/extensions/gsd/workspace-index.ts +64 -46
  514. package/dist/resources/extensions/gsd/auto-observability.js +0 -56
  515. package/dist/resources/extensions/gsd/observability-validator.js +0 -422
  516. package/dist/resources/extensions/gsd/roadmap-mutations.js +0 -110
  517. package/dist/web/standalone/.next/static/VvclDCW6TAWjEyLU-EYL1/_buildManifest.js +0 -1
  518. package/dist/web/standalone/.next/static/chunks/app/_not-found/page-e07acdb7dd069836.js +0 -1
  519. package/dist/web/standalone/.next/static/chunks/app/api/bridge-terminal/stream/route-d07a2c023f1aef1e.js +0 -1
  520. package/dist/web/standalone/.next/static/chunks/app/api/browse-directories/route-d07a2c023f1aef1e.js +0 -1
  521. package/dist/web/standalone/.next/static/chunks/app/api/captures/route-d07a2c023f1aef1e.js +0 -1
  522. package/dist/web/standalone/.next/static/chunks/app/api/cleanup/route-d07a2c023f1aef1e.js +0 -1
  523. package/dist/web/standalone/.next/static/chunks/app/api/dev-mode/route-d07a2c023f1aef1e.js +0 -1
  524. package/dist/web/standalone/.next/static/chunks/app/api/doctor/route-d07a2c023f1aef1e.js +0 -1
  525. package/dist/web/standalone/.next/static/chunks/app/api/export-data/route-d07a2c023f1aef1e.js +0 -1
  526. package/dist/web/standalone/.next/static/chunks/app/api/files/route-d07a2c023f1aef1e.js +0 -1
  527. package/dist/web/standalone/.next/static/chunks/app/api/forensics/route-d07a2c023f1aef1e.js +0 -1
  528. package/dist/web/standalone/.next/static/chunks/app/api/git/route-d07a2c023f1aef1e.js +0 -1
  529. package/dist/web/standalone/.next/static/chunks/app/api/history/route-d07a2c023f1aef1e.js +0 -1
  530. package/dist/web/standalone/.next/static/chunks/app/api/hooks/route-d07a2c023f1aef1e.js +0 -1
  531. package/dist/web/standalone/.next/static/chunks/app/api/inspect/route-d07a2c023f1aef1e.js +0 -1
  532. package/dist/web/standalone/.next/static/chunks/app/api/knowledge/route-d07a2c023f1aef1e.js +0 -1
  533. package/dist/web/standalone/.next/static/chunks/app/api/live-state/route-d07a2c023f1aef1e.js +0 -1
  534. package/dist/web/standalone/.next/static/chunks/app/api/onboarding/route-d07a2c023f1aef1e.js +0 -1
  535. package/dist/web/standalone/.next/static/chunks/app/api/preferences/route-d07a2c023f1aef1e.js +0 -1
  536. package/dist/web/standalone/.next/static/chunks/app/api/projects/route-d07a2c023f1aef1e.js +0 -1
  537. package/dist/web/standalone/.next/static/chunks/app/api/recovery/route-d07a2c023f1aef1e.js +0 -1
  538. package/dist/web/standalone/.next/static/chunks/app/api/remote-questions/route-d07a2c023f1aef1e.js +0 -1
  539. package/dist/web/standalone/.next/static/chunks/app/api/session/browser/route-d07a2c023f1aef1e.js +0 -1
  540. package/dist/web/standalone/.next/static/chunks/app/api/session/command/route-d07a2c023f1aef1e.js +0 -1
  541. package/dist/web/standalone/.next/static/chunks/app/api/session/events/route-d07a2c023f1aef1e.js +0 -1
  542. package/dist/web/standalone/.next/static/chunks/app/api/session/manage/route-d07a2c023f1aef1e.js +0 -1
  543. package/dist/web/standalone/.next/static/chunks/app/api/settings-data/route-d07a2c023f1aef1e.js +0 -1
  544. package/dist/web/standalone/.next/static/chunks/app/api/shutdown/route-d07a2c023f1aef1e.js +0 -1
  545. package/dist/web/standalone/.next/static/chunks/app/api/skill-health/route-d07a2c023f1aef1e.js +0 -1
  546. package/dist/web/standalone/.next/static/chunks/app/api/steer/route-d07a2c023f1aef1e.js +0 -1
  547. package/dist/web/standalone/.next/static/chunks/app/api/terminal/input/route-d07a2c023f1aef1e.js +0 -1
  548. package/dist/web/standalone/.next/static/chunks/app/api/terminal/resize/route-d07a2c023f1aef1e.js +0 -1
  549. package/dist/web/standalone/.next/static/chunks/app/api/terminal/sessions/route-d07a2c023f1aef1e.js +0 -1
  550. package/dist/web/standalone/.next/static/chunks/app/api/terminal/stream/route-d07a2c023f1aef1e.js +0 -1
  551. package/dist/web/standalone/.next/static/chunks/app/api/terminal/upload/route-d07a2c023f1aef1e.js +0 -1
  552. package/dist/web/standalone/.next/static/chunks/app/api/undo/route-d07a2c023f1aef1e.js +0 -1
  553. package/dist/web/standalone/.next/static/chunks/app/api/update/route-d07a2c023f1aef1e.js +0 -1
  554. package/dist/web/standalone/.next/static/chunks/app/api/visualizer/route-d07a2c023f1aef1e.js +0 -1
  555. package/dist/web/standalone/.next/static/chunks/app/layout-745c6ed5fea5fb06.js +0 -1
  556. package/dist/web/standalone/.next/static/chunks/app/page-801b53eff6e83579.js +0 -1
  557. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/app-error-d07a2c023f1aef1e.js +0 -1
  558. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/forbidden-d07a2c023f1aef1e.js +0 -1
  559. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/global-error-e6255954dccfcf0a.js +0 -1
  560. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/not-found-d07a2c023f1aef1e.js +0 -1
  561. package/dist/web/standalone/.next/static/chunks/next/dist/client/components/builtin/unauthorized-d07a2c023f1aef1e.js +0 -1
  562. package/dist/web/standalone/.next/static/css/123c0bb039697968.css +0 -1
  563. package/src/resources/extensions/gsd/auto-observability.ts +0 -74
  564. package/src/resources/extensions/gsd/observability-validator.ts +0 -456
  565. package/src/resources/extensions/gsd/roadmap-mutations.ts +0 -134
  566. package/src/resources/extensions/gsd/tests/doctor-task-done-missing-summary-slice-loop.test.ts +0 -174
  567. package/src/resources/extensions/gsd/tests/plan-quality-validator.test.ts +0 -474
  568. /package/dist/web/standalone/.next/static/{VvclDCW6TAWjEyLU-EYL1 → fOnWQBjWXMKUs4bqTg530}/_ssgManifest.js +0 -0
@@ -0,0 +1,296 @@
1
+ /**
2
+ * Rogue file detection tests — verifies that detectRogueFileWrites()
3
+ * correctly identifies summary files written directly to disk without
4
+ * a corresponding DB completion record.
5
+ */
6
+
7
+ import test from "node:test";
8
+ import assert from "node:assert/strict";
9
+ import { existsSync, mkdirSync, mkdtempSync, realpathSync, rmSync, writeFileSync } from "node:fs";
10
+ import { join } from "node:path";
11
+ import { tmpdir } from "node:os";
12
+
13
+ import { detectRogueFileWrites } from "../auto-post-unit.ts";
14
+ import { openDatabase, closeDatabase, isDbAvailable, insertMilestone, insertSlice, insertTask, updateSliceStatus, upsertMilestonePlanning } from "../gsd-db.ts";
15
+
16
+ // ── Helpers ──────────────────────────────────────────────────────────────────
17
+
18
+ function createTmpBase(): string {
19
+ return realpathSync(mkdtempSync(join(tmpdir(), "gsd-rogue-test-")));
20
+ }
21
+
22
+ /**
23
+ * Create a minimal .gsd/ directory structure with a task summary file.
24
+ */
25
+ function createTaskSummaryOnDisk(basePath: string, mid: string, sid: string, tid: string): string {
26
+ const tasksDir = join(basePath, ".gsd", "milestones", mid, "slices", sid, "tasks");
27
+ mkdirSync(tasksDir, { recursive: true });
28
+ const summaryFile = join(tasksDir, `${tid}-SUMMARY.md`);
29
+ writeFileSync(summaryFile, `---\nid: ${tid}\nparent: ${sid}\nmilestone: ${mid}\n---\n# ${tid}: Test\n`, "utf-8");
30
+ return summaryFile;
31
+ }
32
+
33
+ /**
34
+ * Create a minimal .gsd/ directory structure with a slice summary file.
35
+ */
36
+ function createSliceSummaryOnDisk(basePath: string, mid: string, sid: string): string {
37
+ const sliceDir = join(basePath, ".gsd", "milestones", mid, "slices", sid);
38
+ mkdirSync(sliceDir, { recursive: true });
39
+ const summaryFile = join(sliceDir, `${sid}-SUMMARY.md`);
40
+ writeFileSync(summaryFile, `---\nid: ${sid}\nmilestone: ${mid}\n---\n# ${sid}: Test Slice\n`, "utf-8");
41
+ return summaryFile;
42
+ }
43
+
44
+ function createRoadmapOnDisk(basePath: string, mid: string): string {
45
+ const milestoneDir = join(basePath, ".gsd", "milestones", mid);
46
+ mkdirSync(milestoneDir, { recursive: true });
47
+ const roadmapFile = join(milestoneDir, `${mid}-ROADMAP.md`);
48
+ writeFileSync(roadmapFile, `# ${mid}: Test Roadmap\n`, "utf-8");
49
+ return roadmapFile;
50
+ }
51
+
52
+ function createSlicePlanOnDisk(basePath: string, mid: string, sid: string): string {
53
+ const sliceDir = join(basePath, ".gsd", "milestones", mid, "slices", sid);
54
+ mkdirSync(sliceDir, { recursive: true });
55
+ const planFile = join(sliceDir, `${sid}-PLAN.md`);
56
+ writeFileSync(planFile, `# ${sid}: Test Plan\n`, "utf-8");
57
+ return planFile;
58
+ }
59
+
60
+
61
+ // ── Tests ────────────────────────────────────────────────────────────────────
62
+
63
+ test("rogue detection: task summary on disk, no DB row → detected as rogue", () => {
64
+ const basePath = createTmpBase();
65
+ const dbPath = join(basePath, ".gsd", "gsd.db");
66
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
67
+
68
+ try {
69
+ openDatabase(dbPath);
70
+ assert.ok(isDbAvailable(), "DB should be available");
71
+
72
+ const summaryPath = createTaskSummaryOnDisk(basePath, "M001", "S01", "T01");
73
+ assert.ok(existsSync(summaryPath), "Summary file should exist on disk");
74
+
75
+ const rogues = detectRogueFileWrites("execute-task", "M001/S01/T01", basePath);
76
+ assert.equal(rogues.length, 1, "Should detect one rogue file");
77
+ assert.equal(rogues[0].path, summaryPath);
78
+ assert.equal(rogues[0].unitType, "execute-task");
79
+ assert.equal(rogues[0].unitId, "M001/S01/T01");
80
+ } finally {
81
+ closeDatabase();
82
+ rmSync(basePath, { recursive: true, force: true });
83
+ }
84
+ });
85
+
86
+ test("rogue detection: task summary on disk, DB row with status 'complete' → NOT rogue", () => {
87
+ const basePath = createTmpBase();
88
+ const dbPath = join(basePath, ".gsd", "gsd.db");
89
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
90
+
91
+ try {
92
+ openDatabase(dbPath);
93
+
94
+ createTaskSummaryOnDisk(basePath, "M001", "S01", "T01");
95
+
96
+ // Insert parent milestone and slice first (foreign key constraints)
97
+ insertMilestone({ id: "M001" });
98
+ insertSlice({ milestoneId: "M001", id: "S01" });
99
+
100
+ // Insert a completed task row into the DB (INSERT OR REPLACE)
101
+ insertTask({
102
+ milestoneId: "M001",
103
+ sliceId: "S01",
104
+ id: "T01",
105
+ title: "Test Task",
106
+ status: "complete",
107
+ oneLiner: "Test",
108
+ });
109
+
110
+ const rogues = detectRogueFileWrites("execute-task", "M001/S01/T01", basePath);
111
+ assert.equal(rogues.length, 0, "Should NOT detect rogue when DB row is complete");
112
+ } finally {
113
+ closeDatabase();
114
+ rmSync(basePath, { recursive: true, force: true });
115
+ }
116
+ });
117
+
118
+ test("rogue detection: no summary file on disk → NOT rogue regardless of DB state", () => {
119
+ const basePath = createTmpBase();
120
+ const dbPath = join(basePath, ".gsd", "gsd.db");
121
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
122
+
123
+ try {
124
+ openDatabase(dbPath);
125
+
126
+ // Don't create any summary file on disk
127
+ const rogues = detectRogueFileWrites("execute-task", "M001/S01/T01", basePath);
128
+ assert.equal(rogues.length, 0, "Should NOT detect rogue when no file on disk");
129
+ } finally {
130
+ closeDatabase();
131
+ rmSync(basePath, { recursive: true, force: true });
132
+ }
133
+ });
134
+
135
+ test("rogue detection: DB not available → returns empty array (graceful degradation)", () => {
136
+ const basePath = createTmpBase();
137
+
138
+ try {
139
+ closeDatabase();
140
+ assert.ok(!isDbAvailable(), "DB should not be available");
141
+
142
+ // Create a file on disk even though DB is closed
143
+ createTaskSummaryOnDisk(basePath, "M001", "S01", "T01");
144
+
145
+ const rogues = detectRogueFileWrites("execute-task", "M001/S01/T01", basePath);
146
+ assert.equal(rogues.length, 0, "Should return empty array when DB unavailable");
147
+ } finally {
148
+ rmSync(basePath, { recursive: true, force: true });
149
+ }
150
+ });
151
+
152
+ test("rogue detection: slice summary on disk, no DB row → detected as rogue", () => {
153
+ const basePath = createTmpBase();
154
+ const dbPath = join(basePath, ".gsd", "gsd.db");
155
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
156
+
157
+ try {
158
+ openDatabase(dbPath);
159
+
160
+ const summaryPath = createSliceSummaryOnDisk(basePath, "M001", "S01");
161
+ assert.ok(existsSync(summaryPath), "Slice summary file should exist on disk");
162
+
163
+ const rogues = detectRogueFileWrites("complete-slice", "M001/S01", basePath);
164
+ assert.equal(rogues.length, 1, "Should detect one rogue slice file");
165
+ assert.equal(rogues[0].path, summaryPath);
166
+ assert.equal(rogues[0].unitType, "complete-slice");
167
+ assert.equal(rogues[0].unitId, "M001/S01");
168
+ } finally {
169
+ closeDatabase();
170
+ rmSync(basePath, { recursive: true, force: true });
171
+ }
172
+ });
173
+
174
+ test("rogue detection: slice summary on disk, DB row with status 'complete' → NOT rogue", () => {
175
+ const basePath = createTmpBase();
176
+ const dbPath = join(basePath, ".gsd", "gsd.db");
177
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
178
+
179
+ try {
180
+ openDatabase(dbPath);
181
+
182
+ createSliceSummaryOnDisk(basePath, "M001", "S01");
183
+
184
+ // Insert parent milestone first (foreign key constraint)
185
+ insertMilestone({ id: "M001" });
186
+
187
+ // Insert a slice row, then update to complete
188
+ insertSlice({
189
+ milestoneId: "M001",
190
+ id: "S01",
191
+ title: "Test Slice",
192
+ status: "complete",
193
+ });
194
+ updateSliceStatus("M001", "S01", "complete", new Date().toISOString());
195
+
196
+ const rogues = detectRogueFileWrites("complete-slice", "M001/S01", basePath);
197
+ assert.equal(rogues.length, 0, "Should NOT detect rogue when slice DB row is complete");
198
+ } finally {
199
+ closeDatabase();
200
+ rmSync(basePath, { recursive: true, force: true });
201
+ }
202
+ });
203
+
204
+ test("rogue detection: plan milestone roadmap on disk, no milestone planning row → detected as rogue", () => {
205
+ const basePath = createTmpBase();
206
+ const dbPath = join(basePath, ".gsd", "gsd.db");
207
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
208
+
209
+ try {
210
+ openDatabase(dbPath);
211
+
212
+ const roadmapPath = createRoadmapOnDisk(basePath, "M001");
213
+ assert.ok(existsSync(roadmapPath), "Roadmap file should exist on disk");
214
+
215
+ const rogues = detectRogueFileWrites("plan-milestone", "M001", basePath);
216
+ assert.equal(rogues.length, 1, "Should detect one rogue roadmap file");
217
+ assert.equal(rogues[0].path, roadmapPath);
218
+ assert.equal(rogues[0].unitType, "plan-milestone");
219
+ assert.equal(rogues[0].unitId, "M001");
220
+ } finally {
221
+ closeDatabase();
222
+ rmSync(basePath, { recursive: true, force: true });
223
+ }
224
+ });
225
+
226
+ test("rogue detection: plan milestone roadmap on disk, DB milestone planning row exists → NOT rogue", () => {
227
+ const basePath = createTmpBase();
228
+ const dbPath = join(basePath, ".gsd", "gsd.db");
229
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
230
+
231
+ try {
232
+ openDatabase(dbPath);
233
+
234
+ createRoadmapOnDisk(basePath, "M001");
235
+ insertMilestone({ id: "M001", title: "Planned Milestone" });
236
+ upsertMilestonePlanning("M001", {
237
+ vision: "Real planning state",
238
+ requirementCoverage: "R001 → S01",
239
+ boundaryMapMarkdown: "- planner → db",
240
+ });
241
+
242
+ const rogues = detectRogueFileWrites("plan-milestone", "M001", basePath);
243
+ assert.equal(rogues.length, 0, "Should NOT detect rogue when milestone planning state exists");
244
+ } finally {
245
+ closeDatabase();
246
+ rmSync(basePath, { recursive: true, force: true });
247
+ }
248
+ });
249
+
250
+ test("rogue detection: slice plan on disk, no slice planning row → detected as rogue", () => {
251
+ const basePath = createTmpBase();
252
+ const dbPath = join(basePath, ".gsd", "gsd.db");
253
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
254
+
255
+ try {
256
+ openDatabase(dbPath);
257
+
258
+ const planPath = createSlicePlanOnDisk(basePath, "M001", "S01");
259
+ assert.ok(existsSync(planPath), "Slice plan file should exist on disk");
260
+
261
+ const rogues = detectRogueFileWrites("plan-slice", "M001/S01", basePath);
262
+ assert.equal(rogues.length, 1, "Should detect one rogue slice plan file");
263
+ assert.equal(rogues[0].path, planPath);
264
+ assert.equal(rogues[0].unitType, "plan-slice");
265
+ assert.equal(rogues[0].unitId, "M001/S01");
266
+ } finally {
267
+ closeDatabase();
268
+ rmSync(basePath, { recursive: true, force: true });
269
+ }
270
+ });
271
+
272
+ test("rogue detection: slice plan on disk, DB slice planning row exists → NOT rogue", () => {
273
+ const basePath = createTmpBase();
274
+ const dbPath = join(basePath, ".gsd", "gsd.db");
275
+ mkdirSync(join(basePath, ".gsd"), { recursive: true });
276
+
277
+ try {
278
+ openDatabase(dbPath);
279
+
280
+ createSlicePlanOnDisk(basePath, "M001", "S01");
281
+ insertMilestone({ id: "M001" });
282
+ insertSlice({
283
+ milestoneId: "M001",
284
+ id: "S01",
285
+ title: "Planned Slice",
286
+ status: "pending",
287
+ demo: "Observable plan",
288
+ });
289
+
290
+ const rogues = detectRogueFileWrites("plan-slice", "M001/S01", basePath);
291
+ assert.equal(rogues.length, 0, "Should NOT detect rogue when slice planning state exists");
292
+ } finally {
293
+ closeDatabase();
294
+ rmSync(basePath, { recursive: true, force: true });
295
+ }
296
+ });
@@ -0,0 +1,176 @@
1
+ import test from 'node:test';
2
+ import assert from 'node:assert/strict';
3
+ import { mkdtempSync, rmSync } from 'node:fs';
4
+ import { join } from 'node:path';
5
+ import { tmpdir } from 'node:os';
6
+
7
+ import {
8
+ openDatabase,
9
+ closeDatabase,
10
+ insertMilestone,
11
+ insertSlice,
12
+ insertTask,
13
+ getMilestoneSlices,
14
+ getSliceTasks,
15
+ getActiveSliceFromDb,
16
+ getActiveTaskFromDb,
17
+ } from '../gsd-db.ts';
18
+
19
+ function makeTmp(): string {
20
+ return mkdtempSync(join(tmpdir(), 'gsd-v9-'));
21
+ }
22
+
23
+ function cleanup(base: string): void {
24
+ try { closeDatabase(); } catch { /* noop */ }
25
+ try { rmSync(base, { recursive: true, force: true }); } catch { /* noop */ }
26
+ }
27
+
28
+ test('schema v9: migration adds sequence column to slices and tasks', () => {
29
+ const base = makeTmp();
30
+ const dbPath = join(base, 'gsd.db');
31
+ openDatabase(dbPath);
32
+ try {
33
+ insertMilestone({ id: 'M001', title: 'Test', status: 'active' });
34
+ // If sequence column doesn't exist, these would throw
35
+ insertSlice({ id: 'S01', milestoneId: 'M001', title: 'Slice 1', sequence: 5 });
36
+ insertTask({ id: 'T01', sliceId: 'S01', milestoneId: 'M001', title: 'Task 1', sequence: 3 });
37
+
38
+ const slices = getMilestoneSlices('M001');
39
+ assert.equal(slices.length, 1);
40
+ assert.equal(slices[0]!.sequence, 5);
41
+
42
+ const tasks = getSliceTasks('M001', 'S01');
43
+ assert.equal(tasks.length, 1);
44
+ assert.equal(tasks[0]!.sequence, 3);
45
+ } finally {
46
+ cleanup(base);
47
+ }
48
+ });
49
+
50
+ test('schema v9: getMilestoneSlices returns slices ordered by sequence then id', () => {
51
+ const base = makeTmp();
52
+ openDatabase(join(base, 'gsd.db'));
53
+ try {
54
+ insertMilestone({ id: 'M001', title: 'Test', status: 'active' });
55
+
56
+ // Insert in reverse lexicographic order with sequence overriding id order
57
+ insertSlice({ id: 'S03', milestoneId: 'M001', title: 'Third by id, first by seq', sequence: 1 });
58
+ insertSlice({ id: 'S01', milestoneId: 'M001', title: 'First by id, third by seq', sequence: 3 });
59
+ insertSlice({ id: 'S02', milestoneId: 'M001', title: 'Second by id, second by seq', sequence: 2 });
60
+
61
+ const slices = getMilestoneSlices('M001');
62
+ assert.equal(slices.length, 3);
63
+ assert.equal(slices[0]!.id, 'S03', 'sequence=1 should be first');
64
+ assert.equal(slices[1]!.id, 'S02', 'sequence=2 should be second');
65
+ assert.equal(slices[2]!.id, 'S01', 'sequence=3 should be third');
66
+ } finally {
67
+ cleanup(base);
68
+ }
69
+ });
70
+
71
+ test('schema v9: getSliceTasks returns tasks ordered by sequence then id', () => {
72
+ const base = makeTmp();
73
+ openDatabase(join(base, 'gsd.db'));
74
+ try {
75
+ insertMilestone({ id: 'M001', title: 'Test', status: 'active' });
76
+ insertSlice({ id: 'S01', milestoneId: 'M001', title: 'Slice' });
77
+
78
+ // Insert tasks with sequence overriding id order
79
+ insertTask({ id: 'T03', sliceId: 'S01', milestoneId: 'M001', title: 'Third by id', sequence: 1 });
80
+ insertTask({ id: 'T01', sliceId: 'S01', milestoneId: 'M001', title: 'First by id', sequence: 3 });
81
+ insertTask({ id: 'T02', sliceId: 'S01', milestoneId: 'M001', title: 'Second by id', sequence: 2 });
82
+
83
+ const tasks = getSliceTasks('M001', 'S01');
84
+ assert.equal(tasks.length, 3);
85
+ assert.equal(tasks[0]!.id, 'T03', 'sequence=1 should be first');
86
+ assert.equal(tasks[1]!.id, 'T02', 'sequence=2 should be second');
87
+ assert.equal(tasks[2]!.id, 'T01', 'sequence=3 should be third');
88
+ } finally {
89
+ cleanup(base);
90
+ }
91
+ });
92
+
93
+ test('schema v9: default sequence (0) falls back to id-based ordering', () => {
94
+ const base = makeTmp();
95
+ openDatabase(join(base, 'gsd.db'));
96
+ try {
97
+ insertMilestone({ id: 'M001', title: 'Test', status: 'active' });
98
+
99
+ // All slices with default sequence=0 should sort by id
100
+ insertSlice({ id: 'S03', milestoneId: 'M001', title: 'Third' });
101
+ insertSlice({ id: 'S01', milestoneId: 'M001', title: 'First' });
102
+ insertSlice({ id: 'S02', milestoneId: 'M001', title: 'Second' });
103
+
104
+ const slices = getMilestoneSlices('M001');
105
+ assert.equal(slices[0]!.id, 'S01', 'default seq=0: should sort by id');
106
+ assert.equal(slices[1]!.id, 'S02');
107
+ assert.equal(slices[2]!.id, 'S03');
108
+
109
+ // Same for tasks
110
+ insertSlice({ id: 'S04', milestoneId: 'M001', title: 'Container' });
111
+ insertTask({ id: 'T02', sliceId: 'S04', milestoneId: 'M001', title: 'B' });
112
+ insertTask({ id: 'T01', sliceId: 'S04', milestoneId: 'M001', title: 'A' });
113
+ insertTask({ id: 'T03', sliceId: 'S04', milestoneId: 'M001', title: 'C' });
114
+
115
+ const tasks = getSliceTasks('M001', 'S04');
116
+ assert.equal(tasks[0]!.id, 'T01');
117
+ assert.equal(tasks[1]!.id, 'T02');
118
+ assert.equal(tasks[2]!.id, 'T03');
119
+ } finally {
120
+ cleanup(base);
121
+ }
122
+ });
123
+
124
+ test('schema v9: getActiveSliceFromDb respects sequence ordering', () => {
125
+ const base = makeTmp();
126
+ openDatabase(join(base, 'gsd.db'));
127
+ try {
128
+ insertMilestone({ id: 'M001', title: 'Test', status: 'active' });
129
+
130
+ // S02 has lower sequence so should be active first despite higher id than S01
131
+ insertSlice({ id: 'S01', milestoneId: 'M001', title: 'Higher seq', status: 'pending', sequence: 5 });
132
+ insertSlice({ id: 'S02', milestoneId: 'M001', title: 'Lower seq', status: 'pending', sequence: 2 });
133
+
134
+ const active = getActiveSliceFromDb('M001');
135
+ assert.ok(active);
136
+ assert.equal(active!.id, 'S02', 'lower sequence should be active first');
137
+ } finally {
138
+ cleanup(base);
139
+ }
140
+ });
141
+
142
+ test('schema v9: getActiveTaskFromDb respects sequence ordering', () => {
143
+ const base = makeTmp();
144
+ openDatabase(join(base, 'gsd.db'));
145
+ try {
146
+ insertMilestone({ id: 'M001', title: 'Test', status: 'active' });
147
+ insertSlice({ id: 'S01', milestoneId: 'M001', title: 'Slice' });
148
+
149
+ insertTask({ id: 'T01', sliceId: 'S01', milestoneId: 'M001', title: 'Higher seq', status: 'pending', sequence: 10 });
150
+ insertTask({ id: 'T02', sliceId: 'S01', milestoneId: 'M001', title: 'Lower seq', status: 'pending', sequence: 1 });
151
+
152
+ const active = getActiveTaskFromDb('M001', 'S01');
153
+ assert.ok(active);
154
+ assert.equal(active!.id, 'T02', 'lower sequence should be active first');
155
+ } finally {
156
+ cleanup(base);
157
+ }
158
+ });
159
+
160
+ test('schema v9: sequence field defaults to 0 when not provided', () => {
161
+ const base = makeTmp();
162
+ openDatabase(join(base, 'gsd.db'));
163
+ try {
164
+ insertMilestone({ id: 'M001', title: 'Test', status: 'active' });
165
+ insertSlice({ id: 'S01', milestoneId: 'M001', title: 'No seq' });
166
+ insertTask({ id: 'T01', sliceId: 'S01', milestoneId: 'M001', title: 'No seq' });
167
+
168
+ const slices = getMilestoneSlices('M001');
169
+ assert.equal(slices[0]!.sequence, 0, 'slice sequence defaults to 0');
170
+
171
+ const tasks = getSliceTasks('M001', 'S01');
172
+ assert.equal(tasks[0]!.sequence, 0, 'task sequence defaults to 0');
173
+ } finally {
174
+ cleanup(base);
175
+ }
176
+ });
@@ -0,0 +1,216 @@
1
+ // shared-wal.test.ts — Tests for shared WAL DB path resolution and concurrent writes.
2
+ // Verifies: resolveProjectRootDbPath() for worktree/root paths, WAL concurrent writes.
3
+
4
+ import { mkdtempSync, mkdirSync, rmSync } from 'node:fs';
5
+ import { join, sep } from 'node:path';
6
+ import { tmpdir } from 'node:os';
7
+
8
+ import { resolveProjectRootDbPath } from '../bootstrap/dynamic-tools.ts';
9
+ import {
10
+ openDatabase,
11
+ closeDatabase,
12
+ transaction,
13
+ insertMilestone,
14
+ getAllMilestones,
15
+ _getAdapter,
16
+ } from '../gsd-db.ts';
17
+ import { createTestContext } from './test-helpers.ts';
18
+
19
+ const { assertEq, assertTrue, report } = createTestContext();
20
+
21
+ // ─── Helpers ──────────────────────────────────────────────────────────────
22
+
23
+ function createTmpDir(suffix: string): string {
24
+ return mkdtempSync(join(tmpdir(), `gsd-wal-${suffix}-`));
25
+ }
26
+
27
+ function cleanup(dir: string): void {
28
+ rmSync(dir, { recursive: true, force: true });
29
+ }
30
+
31
+ // ─── Tests ────────────────────────────────────────────────────────────────
32
+
33
+ async function main() {
34
+ // ─── Test (a): resolveProjectRootDbPath returns project root DB for worktree path ───
35
+ console.log('\n=== shared-wal: resolve worktree path to project root DB ===');
36
+ {
37
+ const projectRoot = '/home/user/myproject';
38
+ const worktreePath = join(projectRoot, '.gsd', 'worktrees', 'M001');
39
+ const result = resolveProjectRootDbPath(worktreePath);
40
+ assertEq(result, join(projectRoot, '.gsd', 'gsd.db'),
41
+ 'worktree path resolves to project root DB');
42
+ }
43
+
44
+ // ─── Test (b): resolveProjectRootDbPath returns same base for project root ────
45
+ console.log('\n=== shared-wal: resolve project root path ===');
46
+ {
47
+ const projectRoot = '/home/user/myproject';
48
+ const result = resolveProjectRootDbPath(projectRoot);
49
+ assertEq(result, join(projectRoot, '.gsd', 'gsd.db'),
50
+ 'project root path stays at project root DB');
51
+ }
52
+
53
+ // ─── Test (c): resolve nested worktree subdir ──────────────────────────
54
+ console.log('\n=== shared-wal: resolve nested worktree subdir ===');
55
+ {
56
+ const projectRoot = '/home/user/myproject';
57
+ const nestedPath = join(projectRoot, '.gsd', 'worktrees', 'M002', 'src', 'lib');
58
+ const result = resolveProjectRootDbPath(nestedPath);
59
+ assertEq(result, join(projectRoot, '.gsd', 'gsd.db'),
60
+ 'nested worktree subdir resolves to project root DB');
61
+ }
62
+
63
+ // ─── Test (d): resolve with forward slashes (cross-platform) ──────────
64
+ console.log('\n=== shared-wal: resolve forward-slash path ===');
65
+ {
66
+ const result = resolveProjectRootDbPath('/proj/.gsd/worktrees/M001');
67
+ assertEq(result, join('/proj', '.gsd', 'gsd.db'),
68
+ 'forward-slash worktree path resolves correctly');
69
+ }
70
+
71
+ // ─── Test (e): Concurrent writes — 3 connections to same WAL DB ───────
72
+ console.log('\n=== shared-wal: concurrent writes via WAL ===');
73
+ {
74
+ const tmp = createTmpDir('concurrent');
75
+ const dbPath = join(tmp, 'test.db');
76
+ try {
77
+ // Open with openDatabase to init schema + WAL mode
78
+ openDatabase(dbPath);
79
+
80
+ // Insert milestones from the main connection
81
+ insertMilestone({
82
+ id: 'M001', title: 'From conn 1', status: 'active',
83
+ });
84
+
85
+ // Open two additional raw connections via openDatabase in separate calls.
86
+ // Since openDatabase closes the previous connection and opens a new one,
87
+ // we simulate concurrent access by using the transaction() wrapper to
88
+ // verify WAL allows reads while writes are happening.
89
+
90
+ // Write M002
91
+ insertMilestone({
92
+ id: 'M002', title: 'From conn 2', status: 'active',
93
+ });
94
+
95
+ // Write M003
96
+ insertMilestone({
97
+ id: 'M003', title: 'From conn 3', status: 'active',
98
+ });
99
+
100
+ // Verify all 3 milestones are visible
101
+ const all = getAllMilestones();
102
+ assertEq(all.length, 3, 'concurrent: all 3 milestones visible');
103
+ const ids = all.map(m => m.id).sort();
104
+ assertEq(ids, ['M001', 'M002', 'M003'], 'concurrent: correct IDs');
105
+
106
+ closeDatabase();
107
+ } finally {
108
+ closeDatabase();
109
+ cleanup(tmp);
110
+ }
111
+ }
112
+
113
+ // ─── Test (f): WAL concurrent — multiple raw connections to file DB ────
114
+ console.log('\n=== shared-wal: true concurrent connections via raw SQLite ===');
115
+ {
116
+ const tmp = createTmpDir('rawconc');
117
+ const dbPath = join(tmp, 'concurrent.db');
118
+ try {
119
+ // Open first connection and init schema
120
+ openDatabase(dbPath);
121
+ closeDatabase();
122
+
123
+ // To test true concurrent access, we open 3 separate raw connections
124
+ // using the same provider. The openDatabase/closeDatabase cycle proves
125
+ // WAL mode persists and multiple sequential openers see each other's writes.
126
+
127
+ // Connection 1: write M001
128
+ openDatabase(dbPath);
129
+ insertMilestone({ id: 'M001', title: 'Writer 1', status: 'active' });
130
+ closeDatabase();
131
+
132
+ // Connection 2: write M002, verify sees M001
133
+ openDatabase(dbPath);
134
+ const afterConn2Before = getAllMilestones();
135
+ assertTrue(afterConn2Before.some(m => m.id === 'M001'),
136
+ 'rawconc: conn2 sees M001 from conn1');
137
+ insertMilestone({ id: 'M002', title: 'Writer 2', status: 'active' });
138
+ closeDatabase();
139
+
140
+ // Connection 3: write M003, verify sees M001 + M002
141
+ openDatabase(dbPath);
142
+ const afterConn3Before = getAllMilestones();
143
+ assertTrue(afterConn3Before.some(m => m.id === 'M001'),
144
+ 'rawconc: conn3 sees M001');
145
+ assertTrue(afterConn3Before.some(m => m.id === 'M002'),
146
+ 'rawconc: conn3 sees M002');
147
+ insertMilestone({ id: 'M003', title: 'Writer 3', status: 'active' });
148
+
149
+ // Final read: all 3 visible
150
+ const finalAll = getAllMilestones();
151
+ assertEq(finalAll.length, 3, 'rawconc: all 3 milestones visible');
152
+ assertEq(
153
+ finalAll.map(m => m.id).sort(),
154
+ ['M001', 'M002', 'M003'],
155
+ 'rawconc: all IDs present',
156
+ );
157
+
158
+ closeDatabase();
159
+ } finally {
160
+ closeDatabase();
161
+ cleanup(tmp);
162
+ }
163
+ }
164
+
165
+ // ─── Test (g): BUSY retry — transaction wrapper handles contention ─────
166
+ console.log('\n=== shared-wal: transaction rollback on error ===');
167
+ {
168
+ const tmp = createTmpDir('busy');
169
+ const dbPath = join(tmp, 'busy.db');
170
+ try {
171
+ openDatabase(dbPath);
172
+
173
+ // Insert a milestone in a transaction
174
+ transaction(() => {
175
+ insertMilestone({ id: 'M001', title: 'In txn', status: 'active' });
176
+ });
177
+
178
+ // Verify it committed
179
+ const all = getAllMilestones();
180
+ assertEq(all.length, 1, 'busy: M001 committed via transaction');
181
+
182
+ // Verify transaction rolls back on error
183
+ let errorCaught = false;
184
+ try {
185
+ transaction(() => {
186
+ insertMilestone({ id: 'M002', title: 'Will fail', status: 'active' });
187
+ throw new Error('Simulated failure');
188
+ });
189
+ } catch (err) {
190
+ errorCaught = true;
191
+ assertTrue(
192
+ (err as Error).message.includes('Simulated failure'),
193
+ 'busy: error propagated from transaction',
194
+ );
195
+ }
196
+ assertTrue(errorCaught, 'busy: transaction threw on error');
197
+
198
+ // M002 should NOT be visible (rolled back)
199
+ const afterRollback = getAllMilestones();
200
+ assertEq(afterRollback.length, 1, 'busy: M002 rolled back — still only 1 milestone');
201
+ assertEq(afterRollback[0]!.id, 'M001', 'busy: only M001 survives');
202
+
203
+ closeDatabase();
204
+ } finally {
205
+ closeDatabase();
206
+ cleanup(tmp);
207
+ }
208
+ }
209
+
210
+ report();
211
+ }
212
+
213
+ main().catch((error) => {
214
+ console.error(error);
215
+ process.exit(1);
216
+ });