gsd-pi 2.44.0 → 2.45.0

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 (402) hide show
  1. package/README.md +30 -12
  2. package/dist/resources/extensions/gsd/activity-log.js +7 -0
  3. package/dist/resources/extensions/gsd/auto/infra-errors.js +3 -0
  4. package/dist/resources/extensions/gsd/auto/phases.js +37 -36
  5. package/dist/resources/extensions/gsd/auto-prompts.js +24 -1
  6. package/dist/resources/extensions/gsd/auto-start.js +31 -2
  7. package/dist/resources/extensions/gsd/auto-timers.js +57 -3
  8. package/dist/resources/extensions/gsd/auto-worktree-sync.js +4 -0
  9. package/dist/resources/extensions/gsd/auto-worktree.js +9 -6
  10. package/dist/resources/extensions/gsd/auto.js +30 -3
  11. package/dist/resources/extensions/gsd/bootstrap/db-tools.js +156 -0
  12. package/dist/resources/extensions/gsd/bootstrap/system-context.js +46 -12
  13. package/dist/resources/extensions/gsd/commands/catalog.js +7 -1
  14. package/dist/resources/extensions/gsd/commands/handlers/core.js +2 -0
  15. package/dist/resources/extensions/gsd/commands/handlers/ops.js +10 -0
  16. package/dist/resources/extensions/gsd/commands/handlers/workflow.js +5 -0
  17. package/dist/resources/extensions/gsd/commands-mcp-status.js +187 -0
  18. package/dist/resources/extensions/gsd/db-writer.js +34 -16
  19. package/dist/resources/extensions/gsd/doctor.js +8 -0
  20. package/dist/resources/extensions/gsd/git-service.js +8 -3
  21. package/dist/resources/extensions/gsd/gsd-db.js +12 -1
  22. package/dist/resources/extensions/gsd/markdown-renderer.js +1 -1
  23. package/dist/resources/extensions/gsd/preferences.js +9 -1
  24. package/dist/resources/extensions/gsd/prompts/complete-milestone.md +2 -4
  25. package/dist/resources/extensions/gsd/prompts/plan-slice.md +1 -1
  26. package/dist/resources/extensions/gsd/prompts/reassess-roadmap.md +6 -6
  27. package/dist/resources/extensions/gsd/prompts/replan-slice.md +3 -14
  28. package/dist/resources/extensions/gsd/prompts/rethink.md +78 -0
  29. package/dist/resources/extensions/gsd/prompts/validate-milestone.md +7 -37
  30. package/dist/resources/extensions/gsd/provider-error-pause.js +7 -0
  31. package/dist/resources/extensions/gsd/repo-identity.js +45 -7
  32. package/dist/resources/extensions/gsd/rethink.js +115 -0
  33. package/dist/resources/extensions/gsd/state.js +41 -3
  34. package/dist/resources/extensions/gsd/tools/plan-slice.js +1 -0
  35. package/dist/resources/extensions/gsd/tools/plan-task.js +1 -0
  36. package/dist/resources/extensions/gsd/tools/replan-slice.js +2 -0
  37. package/dist/resources/extensions/gsd/tools/validate-milestone.js +88 -0
  38. package/dist/resources/extensions/gsd/worktree-manager.js +32 -2
  39. package/dist/resources/extensions/gsd/worktree-resolver.js +6 -0
  40. package/dist/resources/extensions/mcp-client/index.js +14 -0
  41. package/dist/web/standalone/.next/BUILD_ID +1 -1
  42. package/dist/web/standalone/.next/app-path-routes-manifest.json +7 -7
  43. package/dist/web/standalone/.next/build-manifest.json +3 -3
  44. package/dist/web/standalone/.next/prerender-manifest.json +3 -3
  45. package/dist/web/standalone/.next/react-loadable-manifest.json +2 -2
  46. package/dist/web/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  47. package/dist/web/standalone/.next/server/app/_global-error.html +2 -2
  48. package/dist/web/standalone/.next/server/app/_global-error.rsc +1 -1
  49. package/dist/web/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  50. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  51. package/dist/web/standalone/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  52. package/dist/web/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  53. package/dist/web/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  54. package/dist/web/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  55. package/dist/web/standalone/.next/server/app/_not-found/page.js +1 -1
  56. package/dist/web/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  57. package/dist/web/standalone/.next/server/app/_not-found.html +1 -1
  58. package/dist/web/standalone/.next/server/app/_not-found.rsc +3 -3
  59. package/dist/web/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  60. package/dist/web/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  61. package/dist/web/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  62. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  63. package/dist/web/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  64. package/dist/web/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  65. package/dist/web/standalone/.next/server/app/api/boot/route_client-reference-manifest.js +1 -1
  66. package/dist/web/standalone/.next/server/app/api/bridge-terminal/input/route_client-reference-manifest.js +1 -1
  67. package/dist/web/standalone/.next/server/app/api/bridge-terminal/resize/route_client-reference-manifest.js +1 -1
  68. package/dist/web/standalone/.next/server/app/api/bridge-terminal/stream/route_client-reference-manifest.js +1 -1
  69. package/dist/web/standalone/.next/server/app/api/browse-directories/route_client-reference-manifest.js +1 -1
  70. package/dist/web/standalone/.next/server/app/api/captures/route_client-reference-manifest.js +1 -1
  71. package/dist/web/standalone/.next/server/app/api/cleanup/route_client-reference-manifest.js +1 -1
  72. package/dist/web/standalone/.next/server/app/api/dev-mode/route_client-reference-manifest.js +1 -1
  73. package/dist/web/standalone/.next/server/app/api/doctor/route_client-reference-manifest.js +1 -1
  74. package/dist/web/standalone/.next/server/app/api/export-data/route_client-reference-manifest.js +1 -1
  75. package/dist/web/standalone/.next/server/app/api/files/route_client-reference-manifest.js +1 -1
  76. package/dist/web/standalone/.next/server/app/api/forensics/route_client-reference-manifest.js +1 -1
  77. package/dist/web/standalone/.next/server/app/api/git/route_client-reference-manifest.js +1 -1
  78. package/dist/web/standalone/.next/server/app/api/history/route_client-reference-manifest.js +1 -1
  79. package/dist/web/standalone/.next/server/app/api/hooks/route_client-reference-manifest.js +1 -1
  80. package/dist/web/standalone/.next/server/app/api/inspect/route_client-reference-manifest.js +1 -1
  81. package/dist/web/standalone/.next/server/app/api/knowledge/route_client-reference-manifest.js +1 -1
  82. package/dist/web/standalone/.next/server/app/api/live-state/route_client-reference-manifest.js +1 -1
  83. package/dist/web/standalone/.next/server/app/api/onboarding/route_client-reference-manifest.js +1 -1
  84. package/dist/web/standalone/.next/server/app/api/preferences/route_client-reference-manifest.js +1 -1
  85. package/dist/web/standalone/.next/server/app/api/projects/route_client-reference-manifest.js +1 -1
  86. package/dist/web/standalone/.next/server/app/api/recovery/route_client-reference-manifest.js +1 -1
  87. package/dist/web/standalone/.next/server/app/api/remote-questions/route_client-reference-manifest.js +1 -1
  88. package/dist/web/standalone/.next/server/app/api/session/browser/route_client-reference-manifest.js +1 -1
  89. package/dist/web/standalone/.next/server/app/api/session/command/route_client-reference-manifest.js +1 -1
  90. package/dist/web/standalone/.next/server/app/api/session/events/route_client-reference-manifest.js +1 -1
  91. package/dist/web/standalone/.next/server/app/api/session/manage/route_client-reference-manifest.js +1 -1
  92. package/dist/web/standalone/.next/server/app/api/settings-data/route_client-reference-manifest.js +1 -1
  93. package/dist/web/standalone/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  94. package/dist/web/standalone/.next/server/app/api/skill-health/route_client-reference-manifest.js +1 -1
  95. package/dist/web/standalone/.next/server/app/api/steer/route_client-reference-manifest.js +1 -1
  96. package/dist/web/standalone/.next/server/app/api/switch-root/route_client-reference-manifest.js +1 -1
  97. package/dist/web/standalone/.next/server/app/api/terminal/input/route_client-reference-manifest.js +1 -1
  98. package/dist/web/standalone/.next/server/app/api/terminal/resize/route_client-reference-manifest.js +1 -1
  99. package/dist/web/standalone/.next/server/app/api/terminal/sessions/route_client-reference-manifest.js +1 -1
  100. package/dist/web/standalone/.next/server/app/api/terminal/stream/route_client-reference-manifest.js +1 -1
  101. package/dist/web/standalone/.next/server/app/api/terminal/upload/route_client-reference-manifest.js +1 -1
  102. package/dist/web/standalone/.next/server/app/api/undo/route_client-reference-manifest.js +1 -1
  103. package/dist/web/standalone/.next/server/app/api/update/route_client-reference-manifest.js +1 -1
  104. package/dist/web/standalone/.next/server/app/api/visualizer/route_client-reference-manifest.js +1 -1
  105. package/dist/web/standalone/.next/server/app/index.html +1 -1
  106. package/dist/web/standalone/.next/server/app/index.rsc +4 -4
  107. package/dist/web/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  108. package/dist/web/standalone/.next/server/app/index.segments/_full.segment.rsc +4 -4
  109. package/dist/web/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  110. package/dist/web/standalone/.next/server/app/index.segments/_index.segment.rsc +2 -2
  111. package/dist/web/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  112. package/dist/web/standalone/.next/server/app/page.js +1 -1
  113. package/dist/web/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  114. package/dist/web/standalone/.next/server/app-paths-manifest.json +7 -7
  115. package/dist/web/standalone/.next/server/middleware-build-manifest.js +1 -1
  116. package/dist/web/standalone/.next/server/middleware-react-loadable-manifest.js +1 -1
  117. package/dist/web/standalone/.next/server/pages/404.html +1 -1
  118. package/dist/web/standalone/.next/server/pages/500.html +2 -2
  119. package/dist/web/standalone/.next/server/server-reference-manifest.json +1 -1
  120. package/dist/web/standalone/.next/static/chunks/4024.11ca5c01938e5948.js +9 -0
  121. package/dist/web/standalone/.next/static/chunks/{3721.bf31263de6d5fa46.js → 485.243af25f0cdf50d6.js} +2 -2
  122. package/dist/web/standalone/.next/static/chunks/app/{page-7e9530a7122506c5.js → page-12dd5ece0df4badc.js} +1 -1
  123. package/dist/web/standalone/.next/static/chunks/webpack-0a4cd455ec4197d2.js +1 -0
  124. package/dist/web/standalone/.next/static/css/dd4ae3f58ac9b600.css +1 -0
  125. package/package.json +1 -1
  126. package/packages/native/dist/stream-process/index.js +2 -2
  127. package/packages/native/src/__tests__/stream-process.test.mjs +34 -0
  128. package/packages/native/src/stream-process/index.ts +2 -2
  129. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts +3 -1
  130. package/packages/pi-coding-agent/dist/core/auth-storage.d.ts.map +1 -1
  131. package/packages/pi-coding-agent/dist/core/auth-storage.js +15 -1
  132. package/packages/pi-coding-agent/dist/core/auth-storage.js.map +1 -1
  133. package/packages/pi-coding-agent/dist/core/auth-storage.test.js +6 -8
  134. package/packages/pi-coding-agent/dist/core/auth-storage.test.js.map +1 -1
  135. package/packages/pi-coding-agent/dist/core/extensions/runner.test.js +24 -26
  136. package/packages/pi-coding-agent/dist/core/extensions/runner.test.js.map +1 -1
  137. package/packages/pi-coding-agent/dist/core/fs-utils.test.js +29 -48
  138. package/packages/pi-coding-agent/dist/core/fs-utils.test.js.map +1 -1
  139. package/packages/pi-coding-agent/dist/core/local-model-check.d.ts +15 -0
  140. package/packages/pi-coding-agent/dist/core/local-model-check.d.ts.map +1 -0
  141. package/packages/pi-coding-agent/dist/core/local-model-check.js +41 -0
  142. package/packages/pi-coding-agent/dist/core/local-model-check.js.map +1 -0
  143. package/packages/pi-coding-agent/dist/core/model-registry.d.ts +11 -0
  144. package/packages/pi-coding-agent/dist/core/model-registry.d.ts.map +1 -1
  145. package/packages/pi-coding-agent/dist/core/model-registry.js +20 -1
  146. package/packages/pi-coding-agent/dist/core/model-registry.js.map +1 -1
  147. package/packages/pi-coding-agent/dist/core/resolve-config-value.test.js +34 -44
  148. package/packages/pi-coding-agent/dist/core/resolve-config-value.test.js.map +1 -1
  149. package/packages/pi-coding-agent/dist/core/session-manager.test.js +30 -34
  150. package/packages/pi-coding-agent/dist/core/session-manager.test.js.map +1 -1
  151. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts +3 -0
  152. package/packages/pi-coding-agent/dist/core/settings-manager.d.ts.map +1 -1
  153. package/packages/pi-coding-agent/dist/core/settings-manager.js +6 -0
  154. package/packages/pi-coding-agent/dist/core/settings-manager.js.map +1 -1
  155. package/packages/pi-coding-agent/dist/core/tools/edit-diff.test.js +10 -12
  156. package/packages/pi-coding-agent/dist/core/tools/edit-diff.test.js.map +1 -1
  157. package/packages/pi-coding-agent/dist/main.d.ts.map +1 -1
  158. package/packages/pi-coding-agent/dist/main.js +17 -0
  159. package/packages/pi-coding-agent/dist/main.js.map +1 -1
  160. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/timestamp.test.d.ts +2 -0
  161. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/timestamp.test.d.ts.map +1 -0
  162. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/timestamp.test.js +32 -0
  163. package/packages/pi-coding-agent/dist/modes/interactive/components/__tests__/timestamp.test.js.map +1 -0
  164. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts +3 -1
  165. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.d.ts.map +1 -1
  166. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js +8 -1
  167. package/packages/pi-coding-agent/dist/modes/interactive/components/assistant-message.js.map +1 -1
  168. package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.d.ts +2 -0
  169. package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.d.ts.map +1 -1
  170. package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.js +12 -0
  171. package/packages/pi-coding-agent/dist/modes/interactive/components/settings-selector.js.map +1 -1
  172. package/packages/pi-coding-agent/dist/modes/interactive/components/timestamp.d.ts +15 -0
  173. package/packages/pi-coding-agent/dist/modes/interactive/components/timestamp.d.ts.map +1 -0
  174. package/packages/pi-coding-agent/dist/modes/interactive/components/timestamp.js +40 -0
  175. package/packages/pi-coding-agent/dist/modes/interactive/components/timestamp.js.map +1 -0
  176. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.d.ts.map +1 -1
  177. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js +4 -1
  178. package/packages/pi-coding-agent/dist/modes/interactive/components/tool-execution.js.map +1 -1
  179. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts +5 -2
  180. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.d.ts.map +1 -1
  181. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js +13 -2
  182. package/packages/pi-coding-agent/dist/modes/interactive/components/user-message.js.map +1 -1
  183. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.d.ts.map +1 -1
  184. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js +17 -8
  185. package/packages/pi-coding-agent/dist/modes/interactive/controllers/chat-controller.js.map +1 -1
  186. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.d.ts.map +1 -1
  187. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js +7 -3
  188. package/packages/pi-coding-agent/dist/modes/interactive/interactive-mode.js.map +1 -1
  189. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage.test.js +43 -47
  190. package/packages/pi-coding-agent/dist/resources/extensions/memory/storage.test.js.map +1 -1
  191. package/packages/pi-coding-agent/package.json +1 -1
  192. package/packages/pi-coding-agent/src/core/auth-storage.test.ts +7 -7
  193. package/packages/pi-coding-agent/src/core/auth-storage.ts +15 -1
  194. package/packages/pi-coding-agent/src/core/extensions/runner.test.ts +26 -26
  195. package/packages/pi-coding-agent/src/core/fs-utils.test.ts +31 -43
  196. package/packages/pi-coding-agent/src/core/local-model-check.ts +45 -0
  197. package/packages/pi-coding-agent/src/core/model-registry.ts +21 -1
  198. package/packages/pi-coding-agent/src/core/resolve-config-value.test.ts +40 -45
  199. package/packages/pi-coding-agent/src/core/session-manager.test.ts +33 -33
  200. package/packages/pi-coding-agent/src/core/settings-manager.ts +9 -0
  201. package/packages/pi-coding-agent/src/core/tools/edit-diff.test.ts +17 -17
  202. package/packages/pi-coding-agent/src/main.ts +19 -0
  203. package/packages/pi-coding-agent/src/modes/interactive/components/__tests__/timestamp.test.ts +38 -0
  204. package/packages/pi-coding-agent/src/modes/interactive/components/assistant-message.ts +10 -0
  205. package/packages/pi-coding-agent/src/modes/interactive/components/settings-selector.ts +15 -0
  206. package/packages/pi-coding-agent/src/modes/interactive/components/timestamp.ts +48 -0
  207. package/packages/pi-coding-agent/src/modes/interactive/components/tool-execution.ts +3 -1
  208. package/packages/pi-coding-agent/src/modes/interactive/components/user-message.ts +18 -3
  209. package/packages/pi-coding-agent/src/modes/interactive/controllers/chat-controller.ts +16 -7
  210. package/packages/pi-coding-agent/src/modes/interactive/interactive-mode.ts +8 -1
  211. package/packages/pi-coding-agent/src/resources/extensions/memory/storage.test.ts +74 -74
  212. package/pkg/package.json +1 -1
  213. package/src/resources/extensions/gsd/activity-log.ts +1 -0
  214. package/src/resources/extensions/gsd/auto/infra-errors.ts +3 -0
  215. package/src/resources/extensions/gsd/auto/phases.ts +46 -48
  216. package/src/resources/extensions/gsd/auto-prompts.ts +24 -1
  217. package/src/resources/extensions/gsd/auto-start.ts +39 -2
  218. package/src/resources/extensions/gsd/auto-timers.ts +64 -3
  219. package/src/resources/extensions/gsd/auto-worktree-sync.ts +5 -0
  220. package/src/resources/extensions/gsd/auto-worktree.ts +9 -6
  221. package/src/resources/extensions/gsd/auto.ts +37 -3
  222. package/src/resources/extensions/gsd/bootstrap/db-tools.ts +148 -0
  223. package/src/resources/extensions/gsd/bootstrap/system-context.ts +48 -11
  224. package/src/resources/extensions/gsd/commands/catalog.ts +7 -1
  225. package/src/resources/extensions/gsd/commands/handlers/core.ts +2 -0
  226. package/src/resources/extensions/gsd/commands/handlers/ops.ts +10 -0
  227. package/src/resources/extensions/gsd/commands/handlers/workflow.ts +8 -0
  228. package/src/resources/extensions/gsd/commands-mcp-status.ts +247 -0
  229. package/src/resources/extensions/gsd/db-writer.ts +39 -17
  230. package/src/resources/extensions/gsd/doctor.ts +7 -1
  231. package/src/resources/extensions/gsd/git-service.ts +6 -2
  232. package/src/resources/extensions/gsd/gsd-db.ts +16 -1
  233. package/src/resources/extensions/gsd/markdown-renderer.ts +1 -1
  234. package/src/resources/extensions/gsd/preferences.ts +11 -1
  235. package/src/resources/extensions/gsd/prompts/complete-milestone.md +2 -4
  236. package/src/resources/extensions/gsd/prompts/plan-slice.md +1 -1
  237. package/src/resources/extensions/gsd/prompts/reassess-roadmap.md +6 -6
  238. package/src/resources/extensions/gsd/prompts/replan-slice.md +3 -14
  239. package/src/resources/extensions/gsd/prompts/rethink.md +78 -0
  240. package/src/resources/extensions/gsd/prompts/validate-milestone.md +7 -37
  241. package/src/resources/extensions/gsd/provider-error-pause.ts +9 -0
  242. package/src/resources/extensions/gsd/repo-identity.ts +46 -7
  243. package/src/resources/extensions/gsd/rethink.ts +154 -0
  244. package/src/resources/extensions/gsd/state.ts +41 -1
  245. package/src/resources/extensions/gsd/tests/all-milestones-complete-merge.test.ts +99 -99
  246. package/src/resources/extensions/gsd/tests/auto-lock-creation.test.ts +14 -16
  247. package/src/resources/extensions/gsd/tests/auto-paused-session-validation.test.ts +43 -57
  248. package/src/resources/extensions/gsd/tests/auto-pr-bugs.test.ts +88 -0
  249. package/src/resources/extensions/gsd/tests/auto-preflight.test.ts +11 -13
  250. package/src/resources/extensions/gsd/tests/auto-recovery.test.ts +465 -523
  251. package/src/resources/extensions/gsd/tests/auto-secrets-gate.test.ts +73 -75
  252. package/src/resources/extensions/gsd/tests/auto-start-needs-discussion.test.ts +34 -56
  253. package/src/resources/extensions/gsd/tests/auto-worktree-milestone-merge.test.ts +533 -656
  254. package/src/resources/extensions/gsd/tests/auto-worktree.test.ts +165 -143
  255. package/src/resources/extensions/gsd/tests/cache-staleness-regression.test.ts +29 -52
  256. package/src/resources/extensions/gsd/tests/captures.test.ts +148 -176
  257. package/src/resources/extensions/gsd/tests/claude-import-tui.test.ts +32 -33
  258. package/src/resources/extensions/gsd/tests/collect-from-manifest.test.ts +141 -143
  259. package/src/resources/extensions/gsd/tests/commands-inspect-open-db.test.ts +25 -25
  260. package/src/resources/extensions/gsd/tests/commands-logs.test.ts +81 -81
  261. package/src/resources/extensions/gsd/tests/complete-milestone.test.ts +38 -59
  262. package/src/resources/extensions/gsd/tests/complete-slice.test.ts +228 -263
  263. package/src/resources/extensions/gsd/tests/complete-task.test.ts +250 -302
  264. package/src/resources/extensions/gsd/tests/completed-units-metrics-sync.test.ts +114 -0
  265. package/src/resources/extensions/gsd/tests/context-store.test.ts +354 -367
  266. package/src/resources/extensions/gsd/tests/continue-here.test.ts +68 -72
  267. package/src/resources/extensions/gsd/tests/cost-projection.test.ts +92 -106
  268. package/src/resources/extensions/gsd/tests/crash-recovery.test.ts +27 -35
  269. package/src/resources/extensions/gsd/tests/dashboard-budget.test.ts +220 -237
  270. package/src/resources/extensions/gsd/tests/db-writer.test.ts +465 -416
  271. package/src/resources/extensions/gsd/tests/definition-loader.test.ts +76 -92
  272. package/src/resources/extensions/gsd/tests/derive-state-crossval.test.ts +68 -83
  273. package/src/resources/extensions/gsd/tests/derive-state-db-disk-reconcile.test.ts +121 -0
  274. package/src/resources/extensions/gsd/tests/derive-state-db.test.ts +210 -181
  275. package/src/resources/extensions/gsd/tests/derive-state-deps.test.ts +78 -101
  276. package/src/resources/extensions/gsd/tests/derive-state.test.ts +192 -227
  277. package/src/resources/extensions/gsd/tests/detection.test.ts +232 -278
  278. package/src/resources/extensions/gsd/tests/dev-engine-wrapper.test.ts +30 -34
  279. package/src/resources/extensions/gsd/tests/dispatch-guard.test.ts +164 -180
  280. package/src/resources/extensions/gsd/tests/dispatch-missing-task-plans.test.ts +43 -49
  281. package/src/resources/extensions/gsd/tests/dispatch-uat-last-completed.test.ts +28 -32
  282. package/src/resources/extensions/gsd/tests/doctor-completion-deferral.test.ts +27 -29
  283. package/src/resources/extensions/gsd/tests/doctor-delimiter-fix.test.ts +34 -38
  284. package/src/resources/extensions/gsd/tests/doctor-enhancements.test.ts +54 -75
  285. package/src/resources/extensions/gsd/tests/doctor-environment-worktree.test.ts +21 -32
  286. package/src/resources/extensions/gsd/tests/doctor-environment.test.ts +72 -97
  287. package/src/resources/extensions/gsd/tests/doctor-fixlevel.test.ts +38 -44
  288. package/src/resources/extensions/gsd/tests/doctor-git.test.ts +104 -145
  289. package/src/resources/extensions/gsd/tests/doctor-proactive.test.ts +84 -106
  290. package/src/resources/extensions/gsd/tests/doctor-roadmap-summary-atomicity.test.ts +54 -60
  291. package/src/resources/extensions/gsd/tests/doctor-runtime.test.ts +72 -93
  292. package/src/resources/extensions/gsd/tests/doctor.test.ts +104 -134
  293. package/src/resources/extensions/gsd/tests/ensure-db-open.test.ts +123 -131
  294. package/src/resources/extensions/gsd/tests/est-annotation-timeout.test.ts +120 -0
  295. package/src/resources/extensions/gsd/tests/exit-command.test.ts +20 -24
  296. package/src/resources/extensions/gsd/tests/feature-branch-lifecycle-integration.test.ts +48 -57
  297. package/src/resources/extensions/gsd/tests/files-loadfile-eisdir.test.ts +5 -7
  298. package/src/resources/extensions/gsd/tests/flag-file-db.test.ts +30 -42
  299. package/src/resources/extensions/gsd/tests/freeform-decisions.test.ts +198 -206
  300. package/src/resources/extensions/gsd/tests/git-locale.test.ts +13 -27
  301. package/src/resources/extensions/gsd/tests/git-service.test.ts +285 -388
  302. package/src/resources/extensions/gsd/tests/gitignore-tracked-gsd.test.ts +31 -39
  303. package/src/resources/extensions/gsd/tests/graph-operations.test.ts +63 -69
  304. package/src/resources/extensions/gsd/tests/gsd-db.test.ts +255 -264
  305. package/src/resources/extensions/gsd/tests/gsd-inspect.test.ts +108 -119
  306. package/src/resources/extensions/gsd/tests/gsd-recover.test.ts +81 -103
  307. package/src/resources/extensions/gsd/tests/gsd-tools.test.ts +229 -262
  308. package/src/resources/extensions/gsd/tests/headless-answers.test.ts +13 -13
  309. package/src/resources/extensions/gsd/tests/health-widget.test.ts +29 -37
  310. package/src/resources/extensions/gsd/tests/idle-recovery.test.ts +81 -102
  311. package/src/resources/extensions/gsd/tests/infra-error.test.ts +20 -2
  312. package/src/resources/extensions/gsd/tests/inherited-repo-home-dir.test.ts +121 -0
  313. package/src/resources/extensions/gsd/tests/init-wizard.test.ts +16 -18
  314. package/src/resources/extensions/gsd/tests/integration-edge.test.ts +41 -46
  315. package/src/resources/extensions/gsd/tests/integration-lifecycle.test.ts +42 -53
  316. package/src/resources/extensions/gsd/tests/integration-mixed-milestones.test.ts +75 -91
  317. package/src/resources/extensions/gsd/tests/integration-proof.test.ts +18 -18
  318. package/src/resources/extensions/gsd/tests/knowledge.test.ts +89 -0
  319. package/src/resources/extensions/gsd/tests/markdown-renderer.test.ts +150 -194
  320. package/src/resources/extensions/gsd/tests/mcp-status.test.ts +103 -0
  321. package/src/resources/extensions/gsd/tests/md-importer.test.ts +101 -125
  322. package/src/resources/extensions/gsd/tests/memory-extractor.test.ts +45 -54
  323. package/src/resources/extensions/gsd/tests/memory-store.test.ts +80 -93
  324. package/src/resources/extensions/gsd/tests/merge-conflict-stops-loop.test.ts +66 -0
  325. package/src/resources/extensions/gsd/tests/migrate-command.test.ts +57 -66
  326. package/src/resources/extensions/gsd/tests/migrate-hierarchy.test.ts +83 -93
  327. package/src/resources/extensions/gsd/tests/migrate-parser.test.ts +161 -170
  328. package/src/resources/extensions/gsd/tests/migrate-transformer.test.ts +125 -141
  329. package/src/resources/extensions/gsd/tests/migrate-validator-parsers.test.ts +107 -131
  330. package/src/resources/extensions/gsd/tests/migrate-writer-integration.test.ts +87 -96
  331. package/src/resources/extensions/gsd/tests/migrate-writer.test.ts +125 -164
  332. package/src/resources/extensions/gsd/tests/must-have-parser.test.ts +81 -94
  333. package/src/resources/extensions/gsd/tests/none-mode-gates.test.ts +35 -36
  334. package/src/resources/extensions/gsd/tests/overrides.test.ts +99 -106
  335. package/src/resources/extensions/gsd/tests/parallel-crash-recovery.test.ts +40 -47
  336. package/src/resources/extensions/gsd/tests/parallel-worker-monitoring.test.ts +25 -28
  337. package/src/resources/extensions/gsd/tests/parallel-workers-multi-milestone-e2e.test.ts +66 -83
  338. package/src/resources/extensions/gsd/tests/park-edge-cases.test.ts +54 -77
  339. package/src/resources/extensions/gsd/tests/park-milestone.test.ts +68 -115
  340. package/src/resources/extensions/gsd/tests/parsers.test.ts +546 -611
  341. package/src/resources/extensions/gsd/tests/paths.test.ts +72 -87
  342. package/src/resources/extensions/gsd/tests/post-unit-hooks.test.ts +77 -117
  343. package/src/resources/extensions/gsd/tests/preferences.test.ts +27 -0
  344. package/src/resources/extensions/gsd/tests/prompt-contracts.test.ts +11 -7
  345. package/src/resources/extensions/gsd/tests/prompt-db.test.ts +56 -56
  346. package/src/resources/extensions/gsd/tests/queue-draft-detection.test.ts +93 -119
  347. package/src/resources/extensions/gsd/tests/queue-order.test.ts +70 -82
  348. package/src/resources/extensions/gsd/tests/queue-reorder-e2e.test.ts +42 -55
  349. package/src/resources/extensions/gsd/tests/quick-auto-guard.test.ts +100 -0
  350. package/src/resources/extensions/gsd/tests/quick-branch-lifecycle.test.ts +45 -73
  351. package/src/resources/extensions/gsd/tests/reassess-prompt.test.ts +28 -38
  352. package/src/resources/extensions/gsd/tests/recovery-attempts-reset.test.ts +176 -0
  353. package/src/resources/extensions/gsd/tests/replan-slice.test.ts +73 -80
  354. package/src/resources/extensions/gsd/tests/repo-identity-worktree.test.ts +71 -74
  355. package/src/resources/extensions/gsd/tests/requirements.test.ts +70 -75
  356. package/src/resources/extensions/gsd/tests/retry-state-reset.test.ts +44 -66
  357. package/src/resources/extensions/gsd/tests/roadmap-parse-regression.test.ts +114 -181
  358. package/src/resources/extensions/gsd/tests/rule-registry.test.ts +63 -65
  359. package/src/resources/extensions/gsd/tests/run-uat.test.ts +66 -128
  360. package/src/resources/extensions/gsd/tests/session-lock-multipath.test.ts +18 -25
  361. package/src/resources/extensions/gsd/tests/session-lock-regression.test.ts +37 -44
  362. package/src/resources/extensions/gsd/tests/shared-wal.test.ts +19 -26
  363. package/src/resources/extensions/gsd/tests/sqlite-unavailable-gate.test.ts +63 -0
  364. package/src/resources/extensions/gsd/tests/stalled-tool-recovery.test.ts +6 -8
  365. package/src/resources/extensions/gsd/tests/stop-auto-merge-back.test.ts +67 -0
  366. package/src/resources/extensions/gsd/tests/survivor-branch-complete.test.ts +108 -0
  367. package/src/resources/extensions/gsd/tests/symlink-numbered-variants.test.ts +22 -28
  368. package/src/resources/extensions/gsd/tests/terminated-transient.test.ts +49 -0
  369. package/src/resources/extensions/gsd/tests/token-savings.test.ts +54 -56
  370. package/src/resources/extensions/gsd/tests/tool-call-loop-guard.test.ts +23 -25
  371. package/src/resources/extensions/gsd/tests/tool-naming.test.ts +10 -11
  372. package/src/resources/extensions/gsd/tests/unique-milestone-ids.test.ts +66 -82
  373. package/src/resources/extensions/gsd/tests/unit-runtime.test.ts +46 -47
  374. package/src/resources/extensions/gsd/tests/visualizer-critical-path.test.ts +20 -22
  375. package/src/resources/extensions/gsd/tests/visualizer-data.test.ts +84 -86
  376. package/src/resources/extensions/gsd/tests/visualizer-overlay.test.ts +41 -43
  377. package/src/resources/extensions/gsd/tests/visualizer-views.test.ts +94 -96
  378. package/src/resources/extensions/gsd/tests/windows-path-normalization.test.ts +11 -13
  379. package/src/resources/extensions/gsd/tests/worker-registry.test.ts +27 -29
  380. package/src/resources/extensions/gsd/tests/workflow-templates.test.ts +50 -52
  381. package/src/resources/extensions/gsd/tests/worktree-bugfix.test.ts +10 -13
  382. package/src/resources/extensions/gsd/tests/worktree-db-integration.test.ts +14 -18
  383. package/src/resources/extensions/gsd/tests/worktree-db.test.ts +38 -39
  384. package/src/resources/extensions/gsd/tests/worktree-e2e.test.ts +17 -21
  385. package/src/resources/extensions/gsd/tests/worktree-health.test.ts +25 -30
  386. package/src/resources/extensions/gsd/tests/worktree-integration.test.ts +30 -37
  387. package/src/resources/extensions/gsd/tests/worktree-submodule-safety.test.ts +65 -0
  388. package/src/resources/extensions/gsd/tests/worktree-symlink-removal.test.ts +15 -22
  389. package/src/resources/extensions/gsd/tests/worktree-sync-milestones.test.ts +59 -66
  390. package/src/resources/extensions/gsd/tests/worktree.test.ts +44 -50
  391. package/src/resources/extensions/gsd/tools/plan-slice.ts +2 -0
  392. package/src/resources/extensions/gsd/tools/plan-task.ts +2 -0
  393. package/src/resources/extensions/gsd/tools/replan-slice.ts +3 -0
  394. package/src/resources/extensions/gsd/tools/validate-milestone.ts +127 -0
  395. package/src/resources/extensions/gsd/worktree-manager.ts +43 -2
  396. package/src/resources/extensions/gsd/worktree-resolver.ts +7 -0
  397. package/src/resources/extensions/mcp-client/index.ts +20 -0
  398. package/dist/web/standalone/.next/static/chunks/4024.0de81b543b28b9fe.js +0 -9
  399. package/dist/web/standalone/.next/static/chunks/webpack-9014b5adb127a98a.js +0 -1
  400. package/dist/web/standalone/.next/static/css/8a727f372cf53002.css +0 -1
  401. /package/dist/web/standalone/.next/static/{mgkxN0mGP6gSUmGPEzbk_ → wUzEX1U3CmFcMry2SUDJn}/_buildManifest.js +0 -0
  402. /package/dist/web/standalone/.next/static/{mgkxN0mGP6gSUmGPEzbk_ → wUzEX1U3CmFcMry2SUDJn}/_ssgManifest.js +0 -0
@@ -36,176 +36,156 @@ function makeTempDir(prefix: string): string {
36
36
 
37
37
  // ─── appendCapture ────────────────────────────────────────────────────────────
38
38
 
39
- test("captures: appendCapture creates CAPTURES.md on first call", () => {
39
+ test("captures: appendCapture creates CAPTURES.md on first call", (t) => {
40
40
  const tmp = makeTempDir("cap-create");
41
- try {
42
- const id = appendCapture(tmp, "first thought");
43
- assert.ok(id.startsWith("CAP-"), "ID should start with CAP-");
44
- assert.ok(
45
- existsSync(join(tmp, ".gsd", "CAPTURES.md")),
46
- "CAPTURES.md should exist",
47
- );
48
- const content = readFileSync(join(tmp, ".gsd", "CAPTURES.md"), "utf-8");
49
- assert.ok(content.includes("# Captures"), "should have header");
50
- assert.ok(content.includes(`### ${id}`), "should have entry heading");
51
- assert.ok(
52
- content.includes("**Text:** first thought"),
53
- "should have text field",
54
- );
55
- assert.ok(
56
- content.includes("**Status:** pending"),
57
- "should have pending status",
58
- );
59
- } finally {
60
- rmSync(tmp, { recursive: true, force: true });
61
- }
41
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
42
+
43
+ const id = appendCapture(tmp, "first thought");
44
+ assert.ok(id.startsWith("CAP-"), "ID should start with CAP-");
45
+ assert.ok(
46
+ existsSync(join(tmp, ".gsd", "CAPTURES.md")),
47
+ "CAPTURES.md should exist",
48
+ );
49
+ const content = readFileSync(join(tmp, ".gsd", "CAPTURES.md"), "utf-8");
50
+ assert.ok(content.includes("# Captures"), "should have header");
51
+ assert.ok(content.includes(`### ${id}`), "should have entry heading");
52
+ assert.ok(
53
+ content.includes("**Text:** first thought"),
54
+ "should have text field",
55
+ );
56
+ assert.ok(
57
+ content.includes("**Status:** pending"),
58
+ "should have pending status",
59
+ );
62
60
  });
63
61
 
64
- test("captures: appendCapture appends to existing file", () => {
62
+ test("captures: appendCapture appends to existing file", (t) => {
65
63
  const tmp = makeTempDir("cap-append");
66
- try {
67
- const id1 = appendCapture(tmp, "thought one");
68
- const id2 = appendCapture(tmp, "thought two");
69
- assert.notStrictEqual(id1, id2, "IDs should be unique");
70
-
71
- const content = readFileSync(join(tmp, ".gsd", "CAPTURES.md"), "utf-8");
72
- assert.ok(content.includes(`### ${id1}`), "should have first entry");
73
- assert.ok(content.includes(`### ${id2}`), "should have second entry");
74
- assert.ok(
75
- content.includes("**Text:** thought one"),
76
- "should have first text",
77
- );
78
- assert.ok(
79
- content.includes("**Text:** thought two"),
80
- "should have second text",
81
- );
82
- } finally {
83
- rmSync(tmp, { recursive: true, force: true });
84
- }
64
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
65
+
66
+ const id1 = appendCapture(tmp, "thought one");
67
+ const id2 = appendCapture(tmp, "thought two");
68
+ assert.notStrictEqual(id1, id2, "IDs should be unique");
69
+
70
+ const content = readFileSync(join(tmp, ".gsd", "CAPTURES.md"), "utf-8");
71
+ assert.ok(content.includes(`### ${id1}`), "should have first entry");
72
+ assert.ok(content.includes(`### ${id2}`), "should have second entry");
73
+ assert.ok(
74
+ content.includes("**Text:** thought one"),
75
+ "should have first text",
76
+ );
77
+ assert.ok(
78
+ content.includes("**Text:** thought two"),
79
+ "should have second text",
80
+ );
85
81
  });
86
82
 
87
83
  // ─── loadAllCaptures / loadPendingCaptures ────────────────────────────────────
88
84
 
89
- test("captures: loadAllCaptures parses entries correctly", () => {
85
+ test("captures: loadAllCaptures parses entries correctly", (t) => {
90
86
  const tmp = makeTempDir("cap-load");
91
- try {
92
- appendCapture(tmp, "alpha");
93
- appendCapture(tmp, "beta");
94
-
95
- const all = loadAllCaptures(tmp);
96
- assert.strictEqual(all.length, 2, "should have 2 entries");
97
- assert.strictEqual(all[0].text, "alpha");
98
- assert.strictEqual(all[1].text, "beta");
99
- assert.strictEqual(all[0].status, "pending");
100
- assert.strictEqual(all[1].status, "pending");
101
- } finally {
102
- rmSync(tmp, { recursive: true, force: true });
103
- }
87
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
88
+
89
+ appendCapture(tmp, "alpha");
90
+ appendCapture(tmp, "beta");
91
+
92
+ const all = loadAllCaptures(tmp);
93
+ assert.strictEqual(all.length, 2, "should have 2 entries");
94
+ assert.strictEqual(all[0].text, "alpha");
95
+ assert.strictEqual(all[1].text, "beta");
96
+ assert.strictEqual(all[0].status, "pending");
97
+ assert.strictEqual(all[1].status, "pending");
104
98
  });
105
99
 
106
- test("captures: loadAllCaptures returns empty array when no file", () => {
100
+ test("captures: loadAllCaptures returns empty array when no file", (t) => {
107
101
  const tmp = makeTempDir("cap-nofile");
108
- try {
109
- const all = loadAllCaptures(tmp);
110
- assert.strictEqual(all.length, 0);
111
- } finally {
112
- rmSync(tmp, { recursive: true, force: true });
113
- }
102
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
103
+
104
+ const all = loadAllCaptures(tmp);
105
+ assert.strictEqual(all.length, 0);
114
106
  });
115
107
 
116
- test("captures: loadPendingCaptures filters resolved entries", () => {
108
+ test("captures: loadPendingCaptures filters resolved entries", (t) => {
117
109
  const tmp = makeTempDir("cap-pending");
118
- try {
119
- const id1 = appendCapture(tmp, "pending one");
120
- appendCapture(tmp, "pending two");
110
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
121
111
 
122
- markCaptureResolved(tmp, id1, "note", "acknowledged", "just a note");
112
+ const id1 = appendCapture(tmp, "pending one");
113
+ appendCapture(tmp, "pending two");
123
114
 
124
- const pending = loadPendingCaptures(tmp);
125
- assert.strictEqual(pending.length, 1, "should have 1 pending");
126
- assert.strictEqual(pending[0].text, "pending two");
127
- } finally {
128
- rmSync(tmp, { recursive: true, force: true });
129
- }
115
+ markCaptureResolved(tmp, id1, "note", "acknowledged", "just a note");
116
+
117
+ const pending = loadPendingCaptures(tmp);
118
+ assert.strictEqual(pending.length, 1, "should have 1 pending");
119
+ assert.strictEqual(pending[0].text, "pending two");
130
120
  });
131
121
 
132
- test("captures: loadAllCaptures preserves resolved entries", () => {
122
+ test("captures: loadAllCaptures preserves resolved entries", (t) => {
133
123
  const tmp = makeTempDir("cap-all-resolved");
134
- try {
135
- const id1 = appendCapture(tmp, "pending one");
136
- appendCapture(tmp, "pending two");
137
-
138
- markCaptureResolved(tmp, id1, "note", "acknowledged", "just a note");
139
-
140
- const all = loadAllCaptures(tmp);
141
- assert.strictEqual(all.length, 2, "all should still have 2");
142
- assert.strictEqual(all[0].status, "resolved");
143
- assert.strictEqual(all[1].status, "pending");
144
- } finally {
145
- rmSync(tmp, { recursive: true, force: true });
146
- }
124
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
125
+
126
+ const id1 = appendCapture(tmp, "pending one");
127
+ appendCapture(tmp, "pending two");
128
+
129
+ markCaptureResolved(tmp, id1, "note", "acknowledged", "just a note");
130
+
131
+ const all = loadAllCaptures(tmp);
132
+ assert.strictEqual(all.length, 2, "all should still have 2");
133
+ assert.strictEqual(all[0].status, "resolved");
134
+ assert.strictEqual(all[1].status, "pending");
147
135
  });
148
136
 
149
137
  // ─── hasPendingCaptures ───────────────────────────────────────────────────────
150
138
 
151
- test("captures: hasPendingCaptures returns false when no file", () => {
139
+ test("captures: hasPendingCaptures returns false when no file", (t) => {
152
140
  const tmp = makeTempDir("cap-has-nofile");
153
- try {
154
- assert.strictEqual(hasPendingCaptures(tmp), false);
155
- } finally {
156
- rmSync(tmp, { recursive: true, force: true });
157
- }
141
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
142
+
143
+ assert.strictEqual(hasPendingCaptures(tmp), false);
158
144
  });
159
145
 
160
- test("captures: hasPendingCaptures returns true with pending entries", () => {
146
+ test("captures: hasPendingCaptures returns true with pending entries", (t) => {
161
147
  const tmp = makeTempDir("cap-has-true");
162
- try {
163
- appendCapture(tmp, "something");
164
- assert.strictEqual(hasPendingCaptures(tmp), true);
165
- } finally {
166
- rmSync(tmp, { recursive: true, force: true });
167
- }
148
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
149
+
150
+ appendCapture(tmp, "something");
151
+ assert.strictEqual(hasPendingCaptures(tmp), true);
168
152
  });
169
153
 
170
- test("captures: hasPendingCaptures returns false when all resolved", () => {
154
+ test("captures: hasPendingCaptures returns false when all resolved", (t) => {
171
155
  const tmp = makeTempDir("cap-has-false");
172
- try {
173
- const id = appendCapture(tmp, "will resolve");
174
- markCaptureResolved(tmp, id, "note", "done", "resolved it");
175
- assert.strictEqual(hasPendingCaptures(tmp), false);
176
- } finally {
177
- rmSync(tmp, { recursive: true, force: true });
178
- }
156
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
157
+
158
+ const id = appendCapture(tmp, "will resolve");
159
+ markCaptureResolved(tmp, id, "note", "done", "resolved it");
160
+ assert.strictEqual(hasPendingCaptures(tmp), false);
179
161
  });
180
162
 
181
163
  // ─── markCaptureResolved ──────────────────────────────────────────────────────
182
164
 
183
- test("captures: markCaptureResolved updates entry in place", () => {
165
+ test("captures: markCaptureResolved updates entry in place", (t) => {
184
166
  const tmp = makeTempDir("cap-resolve");
185
- try {
186
- const id1 = appendCapture(tmp, "keep pending");
187
- const id2 = appendCapture(tmp, "will resolve");
188
- appendCapture(tmp, "also pending");
189
-
190
- markCaptureResolved(tmp, id2, "quick-task", "executed inline", "small fix");
191
-
192
- const all = loadAllCaptures(tmp);
193
- assert.strictEqual(all.length, 3, "should still have 3 entries");
194
-
195
- const resolved = all.find((c) => c.id === id2)!;
196
- assert.strictEqual(resolved.status, "resolved");
197
- assert.strictEqual(resolved.classification, "quick-task");
198
- assert.strictEqual(resolved.resolution, "executed inline");
199
- assert.strictEqual(resolved.rationale, "small fix");
200
- assert.ok(resolved.resolvedAt, "should have resolved timestamp");
201
-
202
- // Others should be unaffected
203
- const kept = all.find((c) => c.id === id1)!;
204
- assert.strictEqual(kept.status, "pending");
205
- assert.strictEqual(kept.classification, undefined);
206
- } finally {
207
- rmSync(tmp, { recursive: true, force: true });
208
- }
167
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
168
+
169
+ const id1 = appendCapture(tmp, "keep pending");
170
+ const id2 = appendCapture(tmp, "will resolve");
171
+ appendCapture(tmp, "also pending");
172
+
173
+ markCaptureResolved(tmp, id2, "quick-task", "executed inline", "small fix");
174
+
175
+ const all = loadAllCaptures(tmp);
176
+ assert.strictEqual(all.length, 3, "should still have 3 entries");
177
+
178
+ const resolved = all.find((c) => c.id === id2)!;
179
+ assert.strictEqual(resolved.status, "resolved");
180
+ assert.strictEqual(resolved.classification, "quick-task");
181
+ assert.strictEqual(resolved.resolution, "executed inline");
182
+ assert.strictEqual(resolved.rationale, "small fix");
183
+ assert.ok(resolved.resolvedAt, "should have resolved timestamp");
184
+
185
+ // Others should be unaffected
186
+ const kept = all.find((c) => c.id === id1)!;
187
+ assert.strictEqual(kept.status, "pending");
188
+ assert.strictEqual(kept.classification, undefined);
209
189
  });
210
190
 
211
191
  // ─── resolveCapturesPath ──────────────────────────────────────────────────────
@@ -371,58 +351,50 @@ test("triage: parseTriageOutput handles all five classification types", () => {
371
351
 
372
352
  // ─── Edge Cases ───────────────────────────────────────────────────────────────
373
353
 
374
- test("captures: appendCapture handles special characters in text", () => {
354
+ test("captures: appendCapture handles special characters in text", (t) => {
375
355
  const tmp = makeTempDir("cap-special");
376
- try {
377
- const id = appendCapture(tmp, 'text with "quotes" and **bold** and `code`');
378
- const all = loadAllCaptures(tmp);
379
- assert.strictEqual(all.length, 1);
380
- assert.ok(all[0].text.includes('"quotes"'), "should preserve quotes");
381
- assert.ok(all[0].text.includes("**bold**"), "should preserve bold");
382
- } finally {
383
- rmSync(tmp, { recursive: true, force: true });
384
- }
356
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
357
+
358
+ const id = appendCapture(tmp, 'text with "quotes" and **bold** and `code`');
359
+ const all = loadAllCaptures(tmp);
360
+ assert.strictEqual(all.length, 1);
361
+ assert.ok(all[0].text.includes('"quotes"'), "should preserve quotes");
362
+ assert.ok(all[0].text.includes("**bold**"), "should preserve bold");
385
363
  });
386
364
 
387
- test("captures: markCaptureResolved is no-op for non-existent ID", () => {
365
+ test("captures: markCaptureResolved is no-op for non-existent ID", (t) => {
388
366
  const tmp = makeTempDir("cap-noop");
389
- try {
390
- appendCapture(tmp, "real capture");
391
- // Should not throw
392
- markCaptureResolved(tmp, "CAP-nonexistent", "note", "test", "test");
393
- const all = loadAllCaptures(tmp);
394
- assert.strictEqual(all.length, 1);
395
- assert.strictEqual(all[0].status, "pending", "original should be unchanged");
396
- } finally {
397
- rmSync(tmp, { recursive: true, force: true });
398
- }
367
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
368
+
369
+ appendCapture(tmp, "real capture");
370
+ // Should not throw
371
+ markCaptureResolved(tmp, "CAP-nonexistent", "note", "test", "test");
372
+ const all = loadAllCaptures(tmp);
373
+ assert.strictEqual(all.length, 1);
374
+ assert.strictEqual(all[0].status, "pending", "original should be unchanged");
399
375
  });
400
376
 
401
- test("captures: markCaptureResolved is no-op when no file exists", () => {
377
+ test("captures: markCaptureResolved is no-op when no file exists", (t) => {
402
378
  const tmp = makeTempDir("cap-nofile-resolve");
403
- try {
404
- // Should not throw
405
- markCaptureResolved(tmp, "CAP-abc", "note", "test", "test");
406
- } finally {
407
- rmSync(tmp, { recursive: true, force: true });
408
- }
379
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
380
+
381
+ // Should not throw
382
+ markCaptureResolved(tmp, "CAP-abc", "note", "test", "test");
409
383
  });
410
384
 
411
- test("captures: re-resolving a capture overwrites previous resolution", () => {
385
+ test("captures: re-resolving a capture overwrites previous resolution", (t) => {
412
386
  const tmp = makeTempDir("cap-reresolve");
413
- try {
414
- const id = appendCapture(tmp, "will re-resolve");
415
- markCaptureResolved(tmp, id, "note", "first resolution", "first rationale");
416
- markCaptureResolved(tmp, id, "inject", "second resolution", "second rationale");
417
-
418
- const all = loadAllCaptures(tmp);
419
- assert.strictEqual(all.length, 1);
420
- assert.strictEqual(all[0].classification, "inject", "should have updated classification");
421
- assert.strictEqual(all[0].resolution, "second resolution");
422
- assert.strictEqual(all[0].rationale, "second rationale");
423
- } finally {
424
- rmSync(tmp, { recursive: true, force: true });
425
- }
387
+ t.after(() => rmSync(tmp, { recursive: true, force: true }));
388
+
389
+ const id = appendCapture(tmp, "will re-resolve");
390
+ markCaptureResolved(tmp, id, "note", "first resolution", "first rationale");
391
+ markCaptureResolved(tmp, id, "inject", "second resolution", "second rationale");
392
+
393
+ const all = loadAllCaptures(tmp);
394
+ assert.strictEqual(all.length, 1);
395
+ assert.strictEqual(all[0].classification, "inject", "should have updated classification");
396
+ assert.strictEqual(all[0].resolution, "second resolution");
397
+ assert.strictEqual(all[0].rationale, "second rationale");
426
398
  });
427
399
 
428
400
  test("triage: parseTriageOutput preserves affectedFiles and targetSlice", () => {
@@ -8,7 +8,6 @@
8
8
  * `/plugin marketplace add ...` source model.
9
9
  */
10
10
 
11
-
12
11
  import { describe, it, before, after, mock } from 'node:test';
13
12
  import assert from 'node:assert';
14
13
  import { existsSync, mkdtempSync, rmSync, writeFileSync, readFileSync, mkdirSync } from 'node:fs';
@@ -306,45 +305,45 @@ describe(
306
305
  });
307
306
  });
308
307
 
309
- it('should not persist marketplace agent directories into package sources', async () => {
308
+ it('should not persist marketplace agent directories into package sources', async (t) => {
310
309
  const isolatedAgentDir = join(tempDir, '.gsd', 'agent');
311
310
  const settingsPath = join(isolatedAgentDir, 'settings.json');
312
311
  rmSync(isolatedAgentDir, { recursive: true, force: true });
313
312
  process.env.GSD_CODING_AGENT_DIR = isolatedAgentDir;
314
313
 
315
- try {
316
- mkdirSync(isolatedAgentDir, { recursive: true });
317
- const tempSettings: Record<string, unknown> = { packages: [] };
318
- writeFileSync(settingsPath, JSON.stringify(tempSettings, null, 2));
319
-
320
- const { ctx } = createMockContext([
321
- 'Plugins only',
322
- 'Yes - discover plugins and select components',
323
- 'Import all components',
324
- 'Yes, continue',
325
- ]);
326
-
327
- const readPrefs = () => ({ ...prefs });
328
- const writePrefs = async (p: Record<string, unknown>) => {
329
- Object.assign(prefs, p);
330
- };
331
-
332
- await runClaudeImportFlow(ctx, 'global', readPrefs, writePrefs);
333
-
334
- const settings = JSON.parse(readFileSync(settingsPath, 'utf8')) as { packages?: unknown[] };
335
- const packageEntries = Array.isArray(settings.packages) ? settings.packages : [];
336
- const hasAgentsDirPackage = packageEntries.some((entry) => {
337
- const source = typeof entry === 'string'
338
- ? entry
339
- : (entry && typeof entry === 'object' ? (entry as { source?: unknown }).source : undefined);
340
- return typeof source === 'string' && source.endsWith('/agents');
341
- });
342
-
343
- assert.strictEqual(hasAgentsDirPackage, false, 'Marketplace agent directories should not be persisted as package sources');
344
- } finally {
314
+ t.after(() => {
345
315
  delete process.env.GSD_CODING_AGENT_DIR;
346
316
  rmSync(isolatedAgentDir, { recursive: true, force: true });
347
- }
317
+ });
318
+
319
+ mkdirSync(isolatedAgentDir, { recursive: true });
320
+ const tempSettings: Record<string, unknown> = { packages: [] };
321
+ writeFileSync(settingsPath, JSON.stringify(tempSettings, null, 2));
322
+
323
+ const { ctx } = createMockContext([
324
+ 'Plugins only',
325
+ 'Yes - discover plugins and select components',
326
+ 'Import all components',
327
+ 'Yes, continue',
328
+ ]);
329
+
330
+ const readPrefs = () => ({ ...prefs });
331
+ const writePrefs = async (p: Record<string, unknown>) => {
332
+ Object.assign(prefs, p);
333
+ };
334
+
335
+ await runClaudeImportFlow(ctx, 'global', readPrefs, writePrefs);
336
+
337
+ const settings = JSON.parse(readFileSync(settingsPath, 'utf8')) as { packages?: unknown[] };
338
+ const packageEntries = Array.isArray(settings.packages) ? settings.packages : [];
339
+ const hasAgentsDirPackage = packageEntries.some((entry) => {
340
+ const source = typeof entry === 'string'
341
+ ? entry
342
+ : (entry && typeof entry === 'object' ? (entry as { source?: unknown }).source : undefined);
343
+ return typeof source === 'string' && source.endsWith('/agents');
344
+ });
345
+
346
+ assert.strictEqual(hasAgentsDirPackage, false, 'Marketplace agent directories should not be persisted as package sources');
348
347
  });
349
348
  });
350
349
  }