woozlit 2.3.0 → 2.3.1

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 (1118) hide show
  1. package/{src/skill/compose/LICENSE-superpowers → LICENSE} +21 -26
  2. package/package.json +18 -191
  3. package/AGENTS.md +0 -134
  4. package/Dockerfile +0 -18
  5. package/README.md +0 -15
  6. package/bunfig.toml +0 -7
  7. package/drizzle.config.ts +0 -10
  8. package/git +0 -0
  9. package/migration/20260127222353_familiar_lady_ursula/migration.sql +0 -90
  10. package/migration/20260127222353_familiar_lady_ursula/snapshot.json +0 -796
  11. package/migration/20260211171708_add_project_commands/migration.sql +0 -1
  12. package/migration/20260211171708_add_project_commands/snapshot.json +0 -806
  13. package/migration/20260213144116_wakeful_the_professor/migration.sql +0 -11
  14. package/migration/20260213144116_wakeful_the_professor/snapshot.json +0 -897
  15. package/migration/20260225215848_workspace/migration.sql +0 -7
  16. package/migration/20260225215848_workspace/snapshot.json +0 -959
  17. package/migration/20260227213759_add_session_workspace_id/migration.sql +0 -2
  18. package/migration/20260227213759_add_session_workspace_id/snapshot.json +0 -983
  19. package/migration/20260228203230_blue_harpoon/migration.sql +0 -17
  20. package/migration/20260228203230_blue_harpoon/snapshot.json +0 -1102
  21. package/migration/20260303231226_add_workspace_fields/migration.sql +0 -5
  22. package/migration/20260303231226_add_workspace_fields/snapshot.json +0 -1013
  23. package/migration/20260309230000_move_org_to_state/migration.sql +0 -3
  24. package/migration/20260309230000_move_org_to_state/snapshot.json +0 -1156
  25. package/migration/20260312043431_session_message_cursor/migration.sql +0 -4
  26. package/migration/20260312043431_session_message_cursor/snapshot.json +0 -1168
  27. package/migration/20260323234822_events/migration.sql +0 -13
  28. package/migration/20260323234822_events/snapshot.json +0 -1271
  29. package/migration/20260410174513_workspace-name/migration.sql +0 -16
  30. package/migration/20260410174513_workspace-name/snapshot.json +0 -1271
  31. package/migration/20260413175956_chief_energizer/migration.sql +0 -13
  32. package/migration/20260413175956_chief_energizer/snapshot.json +0 -1399
  33. package/migration/20260422160000_context_inheritance/migration.sql +0 -3
  34. package/migration/20260422170000_task_registry/migration.sql +0 -18
  35. package/migration/20260423145421_remove_session_entry/migration.sql +0 -4
  36. package/migration/20260515000000_actor_rename/migration.sql +0 -7
  37. package/migration/20260515010000_memory_fts/migration.sql +0 -33
  38. package/migration/20260515020000_user_task/migration.sql +0 -29
  39. package/migration/20260519000000_last_checkpoint_message_id/migration.sql +0 -1
  40. package/migration/20260521000000_message_agent_id/migration.sql +0 -2
  41. package/migration/20260521000100_actor_registry_v6/migration.sql +0 -25
  42. package/migration/20260521010000_memory_fts_v6/migration.sql +0 -33
  43. package/migration/20260521020000_memory_fts_triggers/migration.sql +0 -17
  44. package/migration/20260526000000_agent_id_main/migration.sql +0 -14
  45. package/migration/20260527000000_actor_lifecycle/migration.sql +0 -8
  46. package/migration/20260527000100_inbox/migration.sql +0 -12
  47. package/migration/20260529000000_task_todo_redesign/migration.sql +0 -16
  48. package/migration/20260603000000_task_in_progress_owner/migration.sql +0 -1
  49. package/migration/20260603000000_workflow_run/migration.sql +0 -17
  50. package/migration/20260604000000_workflow_script_sha/migration.sql +0 -1
  51. package/migration/20260608000000_claude_import/migration.sql +0 -7
  52. package/migration/20260608010000_claude_import_message_ids/migration.sql +0 -1
  53. package/migration/20260609000000_history_fts/migration.sql +0 -29
  54. package/migration/20260609230000_workflow_agent_timeout/migration.sql +0 -1
  55. package/parsers-config.ts +0 -290
  56. package/script/build.ts +0 -269
  57. package/script/check-migrations.ts +0 -16
  58. package/script/fix-node-pty.ts +0 -28
  59. package/script/generate.ts +0 -23
  60. package/script/publish.ts +0 -75
  61. package/script/run-workspace-server +0 -106
  62. package/script/schema.ts +0 -63
  63. package/script/time.ts +0 -6
  64. package/script/trace-imports.ts +0 -153
  65. package/script/upgrade-opentui.ts +0 -64
  66. package/src/account/account.sql.ts +0 -39
  67. package/src/account/account.ts +0 -456
  68. package/src/account/repo.ts +0 -166
  69. package/src/account/schema.ts +0 -99
  70. package/src/account/url.ts +0 -8
  71. package/src/acp/README.md +0 -174
  72. package/src/acp/agent.ts +0 -1783
  73. package/src/acp/session.ts +0 -116
  74. package/src/acp/types.ts +0 -24
  75. package/src/actor/actor.sql.ts +0 -38
  76. package/src/actor/events.ts +0 -67
  77. package/src/actor/index.ts +0 -2
  78. package/src/actor/registry.ts +0 -412
  79. package/src/actor/return-header.ts +0 -24
  80. package/src/actor/schema.ts +0 -47
  81. package/src/actor/spawn-ref.ts +0 -16
  82. package/src/actor/spawn.ts +0 -741
  83. package/src/actor/turn.ts +0 -49
  84. package/src/actor/waiter.ts +0 -166
  85. package/src/agent/agent.ts +0 -554
  86. package/src/agent/config.ts +0 -5
  87. package/src/agent/generate.txt +0 -75
  88. package/src/agent/prompt/checkpoint-writer.txt +0 -167
  89. package/src/agent/prompt/compaction.txt +0 -9
  90. package/src/agent/prompt/distill.txt +0 -199
  91. package/src/agent/prompt/dream.txt +0 -155
  92. package/src/agent/prompt/explore.txt +0 -18
  93. package/src/agent/prompt/summary.txt +0 -11
  94. package/src/agent/prompt/title.txt +0 -44
  95. package/src/audio.d.ts +0 -9
  96. package/src/auth/index.ts +0 -106
  97. package/src/bus/bus-event.ts +0 -33
  98. package/src/bus/global.ts +0 -12
  99. package/src/bus/index.ts +0 -193
  100. package/src/cli/bootstrap.ts +0 -33
  101. package/src/cli/cmd/account.ts +0 -258
  102. package/src/cli/cmd/acp.ts +0 -70
  103. package/src/cli/cmd/agent.ts +0 -248
  104. package/src/cli/cmd/cmd.ts +0 -7
  105. package/src/cli/cmd/db.ts +0 -120
  106. package/src/cli/cmd/debug/agent.ts +0 -192
  107. package/src/cli/cmd/debug/config.ts +0 -17
  108. package/src/cli/cmd/debug/file.ts +0 -100
  109. package/src/cli/cmd/debug/index.ts +0 -48
  110. package/src/cli/cmd/debug/lsp.ts +0 -61
  111. package/src/cli/cmd/debug/ripgrep.ts +0 -105
  112. package/src/cli/cmd/debug/scrap.ts +0 -16
  113. package/src/cli/cmd/debug/skill.ts +0 -23
  114. package/src/cli/cmd/debug/snapshot.ts +0 -53
  115. package/src/cli/cmd/export.ts +0 -306
  116. package/src/cli/cmd/generate.ts +0 -50
  117. package/src/cli/cmd/github.ts +0 -1647
  118. package/src/cli/cmd/import.ts +0 -208
  119. package/src/cli/cmd/mcp.ts +0 -812
  120. package/src/cli/cmd/models.ts +0 -88
  121. package/src/cli/cmd/plug.ts +0 -233
  122. package/src/cli/cmd/pr.ts +0 -138
  123. package/src/cli/cmd/providers.ts +0 -689
  124. package/src/cli/cmd/run-completion.ts +0 -77
  125. package/src/cli/cmd/run.ts +0 -694
  126. package/src/cli/cmd/serve.ts +0 -21
  127. package/src/cli/cmd/session.ts +0 -181
  128. package/src/cli/cmd/stats.ts +0 -413
  129. package/src/cli/cmd/tui/app.tsx +0 -1349
  130. package/src/cli/cmd/tui/asset/TEN_VAD_LICENSE +0 -12
  131. package/src/cli/cmd/tui/asset/charge.wav +0 -0
  132. package/src/cli/cmd/tui/asset/pulse-a.wav +0 -0
  133. package/src/cli/cmd/tui/asset/pulse-b.wav +0 -0
  134. package/src/cli/cmd/tui/asset/pulse-c.wav +0 -0
  135. package/src/cli/cmd/tui/asset/ten_vad.wasm +0 -0
  136. package/src/cli/cmd/tui/asset/ten_vad_loader.js +0 -30
  137. package/src/cli/cmd/tui/attach.ts +0 -83
  138. package/src/cli/cmd/tui/component/background-image.tsx +0 -150
  139. package/src/cli/cmd/tui/component/bg-pulse.tsx +0 -130
  140. package/src/cli/cmd/tui/component/border.tsx +0 -21
  141. package/src/cli/cmd/tui/component/dialog-agent.tsx +0 -31
  142. package/src/cli/cmd/tui/component/dialog-command.tsx +0 -208
  143. package/src/cli/cmd/tui/component/dialog-console-org.tsx +0 -103
  144. package/src/cli/cmd/tui/component/dialog-go-upsell.tsx +0 -157
  145. package/src/cli/cmd/tui/component/dialog-image-list.tsx +0 -111
  146. package/src/cli/cmd/tui/component/dialog-logo-design.tsx +0 -37
  147. package/src/cli/cmd/tui/component/dialog-mcp.tsx +0 -86
  148. package/src/cli/cmd/tui/component/dialog-model.tsx +0 -260
  149. package/src/cli/cmd/tui/component/dialog-provider.tsx +0 -454
  150. package/src/cli/cmd/tui/component/dialog-session-delete-failed.tsx +0 -101
  151. package/src/cli/cmd/tui/component/dialog-session-list.tsx +0 -269
  152. package/src/cli/cmd/tui/component/dialog-session-rename.tsx +0 -31
  153. package/src/cli/cmd/tui/component/dialog-skill.tsx +0 -42
  154. package/src/cli/cmd/tui/component/dialog-stash.tsx +0 -87
  155. package/src/cli/cmd/tui/component/dialog-status.tsx +0 -170
  156. package/src/cli/cmd/tui/component/dialog-tag.tsx +0 -44
  157. package/src/cli/cmd/tui/component/dialog-theme-list.tsx +0 -50
  158. package/src/cli/cmd/tui/component/dialog-variant.tsx +0 -39
  159. package/src/cli/cmd/tui/component/dialog-woozlit-login.tsx +0 -206
  160. package/src/cli/cmd/tui/component/dialog-workflows.tsx +0 -62
  161. package/src/cli/cmd/tui/component/dialog-workspace-create.tsx +0 -289
  162. package/src/cli/cmd/tui/component/dialog-workspace-unavailable.tsx +0 -81
  163. package/src/cli/cmd/tui/component/dialog-worktree.tsx +0 -90
  164. package/src/cli/cmd/tui/component/error-component.tsx +0 -92
  165. package/src/cli/cmd/tui/component/logo.tsx +0 -961
  166. package/src/cli/cmd/tui/component/plugin-route-missing.tsx +0 -14
  167. package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +0 -684
  168. package/src/cli/cmd/tui/component/prompt/cwd.ts +0 -0
  169. package/src/cli/cmd/tui/component/prompt/frecency.tsx +0 -90
  170. package/src/cli/cmd/tui/component/prompt/history.tsx +0 -108
  171. package/src/cli/cmd/tui/component/prompt/index.tsx +0 -1829
  172. package/src/cli/cmd/tui/component/prompt/part.ts +0 -16
  173. package/src/cli/cmd/tui/component/prompt/stash.tsx +0 -101
  174. package/src/cli/cmd/tui/component/spinner.tsx +0 -24
  175. package/src/cli/cmd/tui/component/starry-background.tsx +0 -305
  176. package/src/cli/cmd/tui/component/startup-loading.tsx +0 -67
  177. package/src/cli/cmd/tui/component/task-item.tsx +0 -63
  178. package/src/cli/cmd/tui/component/textarea-keybindings.ts +0 -73
  179. package/src/cli/cmd/tui/component/todo-item.tsx +0 -32
  180. package/src/cli/cmd/tui/config/cwd.ts +0 -5
  181. package/src/cli/cmd/tui/config/tui-migrate.ts +0 -151
  182. package/src/cli/cmd/tui/config/tui-schema.ts +0 -38
  183. package/src/cli/cmd/tui/config/tui.ts +0 -219
  184. package/src/cli/cmd/tui/context/args.tsx +0 -16
  185. package/src/cli/cmd/tui/context/directory.ts +0 -15
  186. package/src/cli/cmd/tui/context/event.ts +0 -45
  187. package/src/cli/cmd/tui/context/exit.tsx +0 -65
  188. package/src/cli/cmd/tui/context/helper.tsx +0 -25
  189. package/src/cli/cmd/tui/context/keybind.tsx +0 -105
  190. package/src/cli/cmd/tui/context/kv.tsx +0 -76
  191. package/src/cli/cmd/tui/context/language.tsx +0 -91
  192. package/src/cli/cmd/tui/context/local.tsx +0 -455
  193. package/src/cli/cmd/tui/context/plugin-keybinds.ts +0 -41
  194. package/src/cli/cmd/tui/context/project.tsx +0 -109
  195. package/src/cli/cmd/tui/context/prompt.tsx +0 -18
  196. package/src/cli/cmd/tui/context/route.tsx +0 -61
  197. package/src/cli/cmd/tui/context/sdk.tsx +0 -150
  198. package/src/cli/cmd/tui/context/sync.tsx +0 -828
  199. package/src/cli/cmd/tui/context/theme/aura.json +0 -69
  200. package/src/cli/cmd/tui/context/theme/ayu.json +0 -80
  201. package/src/cli/cmd/tui/context/theme/carbonfox.json +0 -248
  202. package/src/cli/cmd/tui/context/theme/catppuccin-frappe.json +0 -230
  203. package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +0 -230
  204. package/src/cli/cmd/tui/context/theme/catppuccin.json +0 -112
  205. package/src/cli/cmd/tui/context/theme/cobalt2.json +0 -225
  206. package/src/cli/cmd/tui/context/theme/cursor.json +0 -249
  207. package/src/cli/cmd/tui/context/theme/dracula.json +0 -219
  208. package/src/cli/cmd/tui/context/theme/everforest.json +0 -241
  209. package/src/cli/cmd/tui/context/theme/flexoki.json +0 -237
  210. package/src/cli/cmd/tui/context/theme/github.json +0 -233
  211. package/src/cli/cmd/tui/context/theme/gruvbox.json +0 -242
  212. package/src/cli/cmd/tui/context/theme/kanagawa.json +0 -77
  213. package/src/cli/cmd/tui/context/theme/lucent-orng.json +0 -232
  214. package/src/cli/cmd/tui/context/theme/material.json +0 -235
  215. package/src/cli/cmd/tui/context/theme/matrix.json +0 -77
  216. package/src/cli/cmd/tui/context/theme/mercury.json +0 -252
  217. package/src/cli/cmd/tui/context/theme/mimocode.json +0 -245
  218. package/src/cli/cmd/tui/context/theme/monokai.json +0 -221
  219. package/src/cli/cmd/tui/context/theme/nightowl.json +0 -221
  220. package/src/cli/cmd/tui/context/theme/nord.json +0 -223
  221. package/src/cli/cmd/tui/context/theme/one-dark.json +0 -84
  222. package/src/cli/cmd/tui/context/theme/orng.json +0 -247
  223. package/src/cli/cmd/tui/context/theme/osaka-jade.json +0 -93
  224. package/src/cli/cmd/tui/context/theme/palenight.json +0 -222
  225. package/src/cli/cmd/tui/context/theme/rosepine.json +0 -234
  226. package/src/cli/cmd/tui/context/theme/solarized.json +0 -223
  227. package/src/cli/cmd/tui/context/theme/synthwave84.json +0 -226
  228. package/src/cli/cmd/tui/context/theme/tokyonight.json +0 -243
  229. package/src/cli/cmd/tui/context/theme/vercel.json +0 -245
  230. package/src/cli/cmd/tui/context/theme/vesper.json +0 -218
  231. package/src/cli/cmd/tui/context/theme/woozlit.json +0 -245
  232. package/src/cli/cmd/tui/context/theme/zenburn.json +0 -223
  233. package/src/cli/cmd/tui/context/theme.tsx +0 -1298
  234. package/src/cli/cmd/tui/context/thinking.ts +0 -48
  235. package/src/cli/cmd/tui/context/tui-config.tsx +0 -9
  236. package/src/cli/cmd/tui/event.ts +0 -56
  237. package/src/cli/cmd/tui/feature-plugins/home/footer.tsx +0 -93
  238. package/src/cli/cmd/tui/feature-plugins/home/tips-view.tsx +0 -193
  239. package/src/cli/cmd/tui/feature-plugins/home/tips.tsx +0 -54
  240. package/src/cli/cmd/tui/feature-plugins/sidebar/context.tsx +0 -169
  241. package/src/cli/cmd/tui/feature-plugins/sidebar/cwd.tsx +0 -45
  242. package/src/cli/cmd/tui/feature-plugins/sidebar/files.tsx +0 -62
  243. package/src/cli/cmd/tui/feature-plugins/sidebar/footer.tsx +0 -93
  244. package/src/cli/cmd/tui/feature-plugins/sidebar/goal.tsx +0 -84
  245. package/src/cli/cmd/tui/feature-plugins/sidebar/instructions.tsx +0 -54
  246. package/src/cli/cmd/tui/feature-plugins/sidebar/lsp.tsx +0 -66
  247. package/src/cli/cmd/tui/feature-plugins/sidebar/mcp.tsx +0 -98
  248. package/src/cli/cmd/tui/feature-plugins/sidebar/task.tsx +0 -95
  249. package/src/cli/cmd/tui/feature-plugins/sidebar/todo.tsx +0 -51
  250. package/src/cli/cmd/tui/feature-plugins/sidebar/tps.ts +0 -31
  251. package/src/cli/cmd/tui/feature-plugins/system/plugins.tsx +0 -274
  252. package/src/cli/cmd/tui/i18n/en.ts +0 -397
  253. package/src/cli/cmd/tui/i18n/es.ts +0 -433
  254. package/src/cli/cmd/tui/i18n/fr.ts +0 -440
  255. package/src/cli/cmd/tui/i18n/ja.ts +0 -392
  256. package/src/cli/cmd/tui/i18n/locales.ts +0 -82
  257. package/src/cli/cmd/tui/i18n/ru.ts +0 -452
  258. package/src/cli/cmd/tui/i18n/zh.ts +0 -390
  259. package/src/cli/cmd/tui/i18n/zht.ts +0 -360
  260. package/src/cli/cmd/tui/layer.ts +0 -6
  261. package/src/cli/cmd/tui/plugin/api.tsx +0 -405
  262. package/src/cli/cmd/tui/plugin/index.ts +0 -3
  263. package/src/cli/cmd/tui/plugin/internal.ts +0 -35
  264. package/src/cli/cmd/tui/plugin/runtime.ts +0 -1030
  265. package/src/cli/cmd/tui/plugin/slots.tsx +0 -60
  266. package/src/cli/cmd/tui/routes/home.tsx +0 -172
  267. package/src/cli/cmd/tui/routes/session/dialog-fork-from-timeline.tsx +0 -76
  268. package/src/cli/cmd/tui/routes/session/dialog-message.tsx +0 -116
  269. package/src/cli/cmd/tui/routes/session/dialog-subagent.tsx +0 -47
  270. package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +0 -47
  271. package/src/cli/cmd/tui/routes/session/footer.tsx +0 -91
  272. package/src/cli/cmd/tui/routes/session/index.tsx +0 -2532
  273. package/src/cli/cmd/tui/routes/session/permission.tsx +0 -691
  274. package/src/cli/cmd/tui/routes/session/question.tsx +0 -488
  275. package/src/cli/cmd/tui/routes/session/sidebar.tsx +0 -97
  276. package/src/cli/cmd/tui/routes/session/subagent-footer.tsx +0 -142
  277. package/src/cli/cmd/tui/thread.ts +0 -246
  278. package/src/cli/cmd/tui/ui/dialog-alert.tsx +0 -61
  279. package/src/cli/cmd/tui/ui/dialog-confirm.tsx +0 -95
  280. package/src/cli/cmd/tui/ui/dialog-export-options.tsx +0 -223
  281. package/src/cli/cmd/tui/ui/dialog-help.tsx +0 -42
  282. package/src/cli/cmd/tui/ui/dialog-prompt.tsx +0 -123
  283. package/src/cli/cmd/tui/ui/dialog-select.tsx +0 -452
  284. package/src/cli/cmd/tui/ui/dialog.tsx +0 -207
  285. package/src/cli/cmd/tui/ui/link.tsx +0 -28
  286. package/src/cli/cmd/tui/ui/spinner.ts +0 -378
  287. package/src/cli/cmd/tui/ui/toast.tsx +0 -102
  288. package/src/cli/cmd/tui/util/clipboard.ts +0 -203
  289. package/src/cli/cmd/tui/util/editor.ts +0 -35
  290. package/src/cli/cmd/tui/util/image-protocol.ts +0 -35
  291. package/src/cli/cmd/tui/util/index.ts +0 -6
  292. package/src/cli/cmd/tui/util/model.ts +0 -23
  293. package/src/cli/cmd/tui/util/provider-origin.ts +0 -7
  294. package/src/cli/cmd/tui/util/revert-diff.ts +0 -18
  295. package/src/cli/cmd/tui/util/scroll.ts +0 -23
  296. package/src/cli/cmd/tui/util/selection.ts +0 -23
  297. package/src/cli/cmd/tui/util/signal.ts +0 -41
  298. package/src/cli/cmd/tui/util/sound.ts +0 -154
  299. package/src/cli/cmd/tui/util/system-locale.ts +0 -209
  300. package/src/cli/cmd/tui/util/terminal.ts +0 -110
  301. package/src/cli/cmd/tui/util/transcript.ts +0 -112
  302. package/src/cli/cmd/tui/util/vad.ts +0 -229
  303. package/src/cli/cmd/tui/util/voice.ts +0 -360
  304. package/src/cli/cmd/tui/win32.ts +0 -130
  305. package/src/cli/cmd/tui/worker.ts +0 -104
  306. package/src/cli/cmd/uninstall.ts +0 -351
  307. package/src/cli/cmd/upgrade.ts +0 -79
  308. package/src/cli/cmd/web.ts +0 -81
  309. package/src/cli/effect/prompt.ts +0 -25
  310. package/src/cli/error.ts +0 -82
  311. package/src/cli/heap.ts +0 -59
  312. package/src/cli/i18n.ts +0 -15
  313. package/src/cli/logo.ts +0 -59
  314. package/src/cli/network.ts +0 -62
  315. package/src/cli/ui.ts +0 -133
  316. package/src/cli/upgrade.ts +0 -41
  317. package/src/command/index.ts +0 -276
  318. package/src/command/template/initialize.txt +0 -66
  319. package/src/command/template/review.txt +0 -101
  320. package/src/config/agent.ts +0 -197
  321. package/src/config/command.ts +0 -69
  322. package/src/config/config.ts +0 -1024
  323. package/src/config/console-state.ts +0 -16
  324. package/src/config/entry-name.ts +0 -16
  325. package/src/config/error.ts +0 -21
  326. package/src/config/formatter.ts +0 -17
  327. package/src/config/history.ts +0 -21
  328. package/src/config/index.ts +0 -16
  329. package/src/config/keybinds.ts +0 -127
  330. package/src/config/layout.ts +0 -10
  331. package/src/config/lsp.ts +0 -45
  332. package/src/config/managed.ts +0 -70
  333. package/src/config/markdown.ts +0 -97
  334. package/src/config/mcp.ts +0 -172
  335. package/src/config/model-id.ts +0 -14
  336. package/src/config/parse.ts +0 -44
  337. package/src/config/paths.ts +0 -73
  338. package/src/config/permission.ts +0 -76
  339. package/src/config/plugin.ts +0 -88
  340. package/src/config/provider.ts +0 -118
  341. package/src/config/server.ts +0 -20
  342. package/src/config/skills.ts +0 -16
  343. package/src/config/variable.ts +0 -90
  344. package/src/control-plane/adaptors/index.ts +0 -52
  345. package/src/control-plane/adaptors/worktree.ts +0 -47
  346. package/src/control-plane/dev/debug-workspace-plugin.ts +0 -73
  347. package/src/control-plane/schema.ts +0 -19
  348. package/src/control-plane/sse.ts +0 -66
  349. package/src/control-plane/types.ts +0 -34
  350. package/src/control-plane/util.ts +0 -37
  351. package/src/control-plane/workspace-context.ts +0 -26
  352. package/src/control-plane/workspace.sql.ts +0 -17
  353. package/src/control-plane/workspace.ts +0 -615
  354. package/src/effect/app-runtime.ts +0 -146
  355. package/src/effect/bootstrap-runtime.ts +0 -33
  356. package/src/effect/bridge.ts +0 -48
  357. package/src/effect/cross-spawn-spawner.ts +0 -514
  358. package/src/effect/index.ts +0 -5
  359. package/src/effect/instance-ref.ts +0 -11
  360. package/src/effect/instance-registry.ts +0 -12
  361. package/src/effect/instance-state.ts +0 -81
  362. package/src/effect/logger.ts +0 -73
  363. package/src/effect/memo-map.ts +0 -3
  364. package/src/effect/observability.ts +0 -107
  365. package/src/effect/run-service.ts +0 -52
  366. package/src/effect/runner.ts +0 -210
  367. package/src/effect/runtime.ts +0 -19
  368. package/src/env/index.ts +0 -37
  369. package/src/file/ignore.ts +0 -81
  370. package/src/file/index.ts +0 -664
  371. package/src/file/protected.ts +0 -59
  372. package/src/file/ripgrep.ts +0 -485
  373. package/src/file/watcher.ts +0 -163
  374. package/src/flag/flag.ts +0 -172
  375. package/src/format/formatter.ts +0 -403
  376. package/src/format/index.ts +0 -203
  377. package/src/git/index.ts +0 -260
  378. package/src/global/index.ts +0 -54
  379. package/src/history/backfill.ts +0 -162
  380. package/src/history/extract.ts +0 -67
  381. package/src/history/fts-query.ts +0 -15
  382. package/src/history/fts.sql.ts +0 -20
  383. package/src/history/index.ts +0 -10
  384. package/src/history/resolve.ts +0 -65
  385. package/src/history/service.ts +0 -258
  386. package/src/history/writer.ts +0 -112
  387. package/src/id/id.ts +0 -87
  388. package/src/ide/index.ts +0 -73
  389. package/src/inbox/inbox-ref.ts +0 -38
  390. package/src/inbox/inbox.sql.ts +0 -26
  391. package/src/inbox/inbox.ts +0 -223
  392. package/src/inbox/index.ts +0 -3
  393. package/src/inbox/render.ts +0 -40
  394. package/src/index.ts +0 -260
  395. package/src/installation/index.ts +0 -351
  396. package/src/installation/version.ts +0 -8
  397. package/src/lsp/client.ts +0 -249
  398. package/src/lsp/diagnostic.ts +0 -29
  399. package/src/lsp/index.ts +0 -3
  400. package/src/lsp/language.ts +0 -120
  401. package/src/lsp/launch.ts +0 -21
  402. package/src/lsp/lsp.ts +0 -519
  403. package/src/lsp/server.ts +0 -1956
  404. package/src/mcp/auth.ts +0 -144
  405. package/src/mcp/index.ts +0 -944
  406. package/src/mcp/oauth-callback.ts +0 -232
  407. package/src/mcp/oauth-provider.ts +0 -214
  408. package/src/memory/fts-query.ts +0 -37
  409. package/src/memory/fts.sql.ts +0 -19
  410. package/src/memory/index.ts +0 -1
  411. package/src/memory/paths.ts +0 -116
  412. package/src/memory/reconcile.ts +0 -144
  413. package/src/memory/service.ts +0 -144
  414. package/src/metrics/client.ts +0 -35
  415. package/src/metrics/event.ts +0 -43
  416. package/src/metrics/index.ts +0 -5
  417. package/src/metrics/installation.ts +0 -18
  418. package/src/metrics/subscriber.ts +0 -58
  419. package/src/metrics/util.ts +0 -9
  420. package/src/node.ts +0 -6
  421. package/src/npm/config.ts +0 -0
  422. package/src/npm/index.ts +0 -293
  423. package/src/npmcli-config.d.ts +0 -43
  424. package/src/patch/index.ts +0 -680
  425. package/src/permission/arity.ts +0 -163
  426. package/src/permission/evaluate.ts +0 -15
  427. package/src/permission/index.ts +0 -379
  428. package/src/permission/schema.ts +0 -17
  429. package/src/plugin/checkpoint-splitover.ts +0 -60
  430. package/src/plugin/cloudflare.ts +0 -76
  431. package/src/plugin/codex.ts +0 -607
  432. package/src/plugin/github-copilot/copilot.ts +0 -368
  433. package/src/plugin/github-copilot/models.ts +0 -153
  434. package/src/plugin/index.ts +0 -500
  435. package/src/plugin/install.ts +0 -439
  436. package/src/plugin/loader.ts +0 -216
  437. package/src/plugin/matcher.ts +0 -33
  438. package/src/plugin/meta.ts +0 -188
  439. package/src/plugin/shared.ts +0 -323
  440. package/src/plugin/subagent-progress-checker.ts +0 -147
  441. package/src/plugin/woozlit-free.ts +0 -164
  442. package/src/plugin/woozlit.ts +0 -440
  443. package/src/project/bootstrap.ts +0 -59
  444. package/src/project/index.ts +0 -2
  445. package/src/project/instance.ts +0 -190
  446. package/src/project/project-id.ts +0 -48
  447. package/src/project/project.sql.ts +0 -16
  448. package/src/project/project.ts +0 -501
  449. package/src/project/schema.ts +0 -15
  450. package/src/project/vcs.ts +0 -227
  451. package/src/provider/auth.ts +0 -234
  452. package/src/provider/error.ts +0 -216
  453. package/src/provider/index.ts +0 -5
  454. package/src/provider/models.ts +0 -180
  455. package/src/provider/provider.ts +0 -1788
  456. package/src/provider/schema.ts +0 -36
  457. package/src/provider/sdk/copilot/README.md +0 -5
  458. package/src/provider/sdk/copilot/chat/convert-to-openai-compatible-chat-messages.ts +0 -170
  459. package/src/provider/sdk/copilot/chat/get-response-metadata.ts +0 -15
  460. package/src/provider/sdk/copilot/chat/map-openai-compatible-finish-reason.ts +0 -19
  461. package/src/provider/sdk/copilot/chat/openai-compatible-api-types.ts +0 -64
  462. package/src/provider/sdk/copilot/chat/openai-compatible-chat-language-model.ts +0 -815
  463. package/src/provider/sdk/copilot/chat/openai-compatible-chat-options.ts +0 -28
  464. package/src/provider/sdk/copilot/chat/openai-compatible-metadata-extractor.ts +0 -44
  465. package/src/provider/sdk/copilot/chat/openai-compatible-prepare-tools.ts +0 -83
  466. package/src/provider/sdk/copilot/copilot-provider.ts +0 -100
  467. package/src/provider/sdk/copilot/index.ts +0 -2
  468. package/src/provider/sdk/copilot/openai-compatible-error.ts +0 -27
  469. package/src/provider/sdk/copilot/responses/convert-to-openai-responses-input.ts +0 -335
  470. package/src/provider/sdk/copilot/responses/map-openai-responses-finish-reason.ts +0 -22
  471. package/src/provider/sdk/copilot/responses/openai-config.ts +0 -18
  472. package/src/provider/sdk/copilot/responses/openai-error.ts +0 -22
  473. package/src/provider/sdk/copilot/responses/openai-responses-api-types.ts +0 -214
  474. package/src/provider/sdk/copilot/responses/openai-responses-language-model.ts +0 -1770
  475. package/src/provider/sdk/copilot/responses/openai-responses-prepare-tools.ts +0 -173
  476. package/src/provider/sdk/copilot/responses/openai-responses-settings.ts +0 -1
  477. package/src/provider/sdk/copilot/responses/tool/code-interpreter.ts +0 -87
  478. package/src/provider/sdk/copilot/responses/tool/file-search.ts +0 -127
  479. package/src/provider/sdk/copilot/responses/tool/image-generation.ts +0 -114
  480. package/src/provider/sdk/copilot/responses/tool/local-shell.ts +0 -64
  481. package/src/provider/sdk/copilot/responses/tool/web-search-preview.ts +0 -103
  482. package/src/provider/sdk/copilot/responses/tool/web-search.ts +0 -102
  483. package/src/provider/transform.ts +0 -1350
  484. package/src/pty/index.ts +0 -364
  485. package/src/pty/pty.bun.ts +0 -26
  486. package/src/pty/pty.node.ts +0 -27
  487. package/src/pty/pty.ts +0 -25
  488. package/src/pty/schema.ts +0 -17
  489. package/src/question/index.ts +0 -252
  490. package/src/question/schema.ts +0 -17
  491. package/src/server/adapter.bun.ts +0 -40
  492. package/src/server/adapter.node.ts +0 -66
  493. package/src/server/adapter.ts +0 -21
  494. package/src/server/error.ts +0 -53
  495. package/src/server/event.ts +0 -7
  496. package/src/server/fence.ts +0 -81
  497. package/src/server/mdns.ts +0 -60
  498. package/src/server/middleware.ts +0 -92
  499. package/src/server/projectors.ts +0 -28
  500. package/src/server/proxy.ts +0 -171
  501. package/src/server/routes/control/index.ts +0 -218
  502. package/src/server/routes/control/workspace.ts +0 -203
  503. package/src/server/routes/global.ts +0 -287
  504. package/src/server/routes/instance/bash-interactive.ts +0 -82
  505. package/src/server/routes/instance/config.ts +0 -89
  506. package/src/server/routes/instance/event.ts +0 -88
  507. package/src/server/routes/instance/experimental.ts +0 -408
  508. package/src/server/routes/instance/file.ts +0 -190
  509. package/src/server/routes/instance/httpapi/config.ts +0 -51
  510. package/src/server/routes/instance/httpapi/permission.ts +0 -72
  511. package/src/server/routes/instance/httpapi/project.ts +0 -62
  512. package/src/server/routes/instance/httpapi/provider.ts +0 -150
  513. package/src/server/routes/instance/httpapi/question.ts +0 -121
  514. package/src/server/routes/instance/httpapi/server.ts +0 -136
  515. package/src/server/routes/instance/index.ts +0 -301
  516. package/src/server/routes/instance/mcp.ts +0 -260
  517. package/src/server/routes/instance/middleware.ts +0 -35
  518. package/src/server/routes/instance/permission.ts +0 -73
  519. package/src/server/routes/instance/project.ts +0 -122
  520. package/src/server/routes/instance/provider.ts +0 -158
  521. package/src/server/routes/instance/pty.ts +0 -247
  522. package/src/server/routes/instance/question.ts +0 -162
  523. package/src/server/routes/instance/session.ts +0 -1296
  524. package/src/server/routes/instance/sync.ts +0 -143
  525. package/src/server/routes/instance/trace.ts +0 -59
  526. package/src/server/routes/instance/tui.ts +0 -384
  527. package/src/server/routes/instance/workflows.ts +0 -72
  528. package/src/server/routes/ui.ts +0 -55
  529. package/src/server/server.ts +0 -136
  530. package/src/server/workspace.ts +0 -122
  531. package/src/session/auto-dream.ts +0 -123
  532. package/src/session/boundary.ts +0 -77
  533. package/src/session/budgeted-read.ts +0 -118
  534. package/src/session/checkpoint-align.ts +0 -29
  535. package/src/session/checkpoint-context.ts +0 -36
  536. package/src/session/checkpoint-paths.ts +0 -86
  537. package/src/session/checkpoint-progress-reconcile.ts +0 -111
  538. package/src/session/checkpoint-retry.ts +0 -192
  539. package/src/session/checkpoint-templates.ts +0 -114
  540. package/src/session/checkpoint-validator.ts +0 -259
  541. package/src/session/checkpoint.ts +0 -1478
  542. package/src/session/classify.ts +0 -92
  543. package/src/session/claude-import.sql.ts +0 -13
  544. package/src/session/claude-import.ts +0 -379
  545. package/src/session/compaction.ts +0 -543
  546. package/src/session/goal.ts +0 -232
  547. package/src/session/index.ts +0 -1
  548. package/src/session/instruction.ts +0 -314
  549. package/src/session/last-message-info.ts +0 -32
  550. package/src/session/llm-request-prefix.ts +0 -82
  551. package/src/session/llm.ts +0 -735
  552. package/src/session/max-mode.ts +0 -397
  553. package/src/session/message-v2.ts +0 -1136
  554. package/src/session/message.ts +0 -191
  555. package/src/session/overflow.ts +0 -53
  556. package/src/session/prefix-capture-ref.ts +0 -48
  557. package/src/session/processor.ts +0 -972
  558. package/src/session/projectors.ts +0 -137
  559. package/src/session/prompt/anthropic.txt +0 -154
  560. package/src/session/prompt/beast.txt +0 -155
  561. package/src/session/prompt/build-switch.txt +0 -5
  562. package/src/session/prompt/codex.txt +0 -79
  563. package/src/session/prompt/compose.txt +0 -115
  564. package/src/session/prompt/copilot-gpt-5.txt +0 -143
  565. package/src/session/prompt/default.txt +0 -151
  566. package/src/session/prompt/gemini.txt +0 -155
  567. package/src/session/prompt/gpt.txt +0 -107
  568. package/src/session/prompt/kimi.txt +0 -95
  569. package/src/session/prompt/max-steps.txt +0 -16
  570. package/src/session/prompt/trinity.txt +0 -97
  571. package/src/session/prompt.ts +0 -3362
  572. package/src/session/prune.ts +0 -481
  573. package/src/session/retry.ts +0 -166
  574. package/src/session/revert.ts +0 -161
  575. package/src/session/run-state.ts +0 -135
  576. package/src/session/schema.ts +0 -36
  577. package/src/session/session.sql.ts +0 -110
  578. package/src/session/session.ts +0 -908
  579. package/src/session/status.ts +0 -89
  580. package/src/session/summary.ts +0 -163
  581. package/src/session/system.ts +0 -86
  582. package/src/session/todo.ts +0 -77
  583. package/src/share/index.ts +0 -2
  584. package/src/share/session.ts +0 -57
  585. package/src/share/share-next.ts +0 -381
  586. package/src/share/share.sql.ts +0 -13
  587. package/src/shell/shell.ts +0 -110
  588. package/src/skill/compose/.bundle/ask/SKILL.md +0 -58
  589. package/src/skill/compose/.bundle/brainstorm/SKILL.md +0 -220
  590. package/src/skill/compose/.bundle/brainstorm/scripts/frame-template.html +0 -214
  591. package/src/skill/compose/.bundle/brainstorm/scripts/helper.js +0 -88
  592. package/src/skill/compose/.bundle/brainstorm/scripts/server.cjs +0 -354
  593. package/src/skill/compose/.bundle/brainstorm/scripts/start-server.sh +0 -148
  594. package/src/skill/compose/.bundle/brainstorm/scripts/stop-server.sh +0 -56
  595. package/src/skill/compose/.bundle/brainstorm/spec-document-reviewer-prompt.md +0 -50
  596. package/src/skill/compose/.bundle/brainstorm/visual-companion.md +0 -287
  597. package/src/skill/compose/.bundle/debug/CREATION-LOG.md +0 -119
  598. package/src/skill/compose/.bundle/debug/SKILL.md +0 -297
  599. package/src/skill/compose/.bundle/debug/condition-based-waiting-example.ts +0 -158
  600. package/src/skill/compose/.bundle/debug/condition-based-waiting.md +0 -115
  601. package/src/skill/compose/.bundle/debug/defense-in-depth.md +0 -122
  602. package/src/skill/compose/.bundle/debug/find-polluter.sh +0 -63
  603. package/src/skill/compose/.bundle/debug/root-cause-tracing.md +0 -169
  604. package/src/skill/compose/.bundle/debug/test-academic.md +0 -14
  605. package/src/skill/compose/.bundle/debug/test-pressure-1.md +0 -58
  606. package/src/skill/compose/.bundle/debug/test-pressure-2.md +0 -68
  607. package/src/skill/compose/.bundle/debug/test-pressure-3.md +0 -69
  608. package/src/skill/compose/.bundle/execute/SKILL.md +0 -71
  609. package/src/skill/compose/.bundle/feedback/SKILL.md +0 -214
  610. package/src/skill/compose/.bundle/merge/SKILL.md +0 -252
  611. package/src/skill/compose/.bundle/new-skill/SKILL.md +0 -656
  612. package/src/skill/compose/.bundle/new-skill/anthropic-best-practices.md +0 -1150
  613. package/src/skill/compose/.bundle/new-skill/examples/CLAUDE_MD_TESTING.md +0 -189
  614. package/src/skill/compose/.bundle/new-skill/graphviz-conventions.dot +0 -172
  615. package/src/skill/compose/.bundle/new-skill/persuasion-principles.md +0 -187
  616. package/src/skill/compose/.bundle/new-skill/render-graphs.js +0 -168
  617. package/src/skill/compose/.bundle/new-skill/testing-skills-with-subagents.md +0 -384
  618. package/src/skill/compose/.bundle/parallel/SKILL.md +0 -182
  619. package/src/skill/compose/.bundle/plan/SKILL.md +0 -161
  620. package/src/skill/compose/.bundle/plan/plan-document-reviewer-prompt.md +0 -50
  621. package/src/skill/compose/.bundle/report/SKILL.md +0 -180
  622. package/src/skill/compose/.bundle/review/SKILL.md +0 -104
  623. package/src/skill/compose/.bundle/review/code-reviewer.md +0 -171
  624. package/src/skill/compose/.bundle/subagent/SKILL.md +0 -344
  625. package/src/skill/compose/.bundle/subagent/code-quality-reviewer-prompt.md +0 -24
  626. package/src/skill/compose/.bundle/subagent/implementer-prompt.md +0 -126
  627. package/src/skill/compose/.bundle/subagent/spec-reviewer-prompt.md +0 -112
  628. package/src/skill/compose/.bundle/tdd/SKILL.md +0 -372
  629. package/src/skill/compose/.bundle/tdd/testing-anti-patterns.md +0 -299
  630. package/src/skill/compose/.bundle/verify/SKILL.md +0 -140
  631. package/src/skill/compose/.bundle/worktree/SKILL.md +0 -234
  632. package/src/skill/compose/LICENSE-karpathy +0 -28
  633. package/src/skill/compose/bundle.macro.ts +0 -30
  634. package/src/skill/compose/extract.ts +0 -85
  635. package/src/skill/discovery.ts +0 -116
  636. package/src/skill/index.ts +0 -311
  637. package/src/snapshot/index.ts +0 -777
  638. package/src/sql.d.ts +0 -4
  639. package/src/storage/db.bun.ts +0 -8
  640. package/src/storage/db.node.ts +0 -8
  641. package/src/storage/db.ts +0 -172
  642. package/src/storage/index.ts +0 -26
  643. package/src/storage/json-migration.ts +0 -426
  644. package/src/storage/schema.sql.ts +0 -10
  645. package/src/storage/schema.ts +0 -7
  646. package/src/storage/storage.ts +0 -331
  647. package/src/sync/README.md +0 -179
  648. package/src/sync/event.sql.ts +0 -16
  649. package/src/sync/index.ts +0 -278
  650. package/src/sync/schema.ts +0 -14
  651. package/src/task/events.ts +0 -28
  652. package/src/task/gate-state.ts +0 -54
  653. package/src/task/gate.ts +0 -116
  654. package/src/task/index.ts +0 -1
  655. package/src/task/registry.ts +0 -387
  656. package/src/task/schema.ts +0 -43
  657. package/src/task/task.sql.ts +0 -50
  658. package/src/team/events.ts +0 -22
  659. package/src/team/index.ts +0 -113
  660. package/src/team/schema.ts +0 -31
  661. package/src/temporary.ts +0 -33
  662. package/src/tool/actor.shell.txt +0 -72
  663. package/src/tool/actor.ts +0 -803
  664. package/src/tool/actor.txt +0 -103
  665. package/src/tool/apply_patch.ts +0 -308
  666. package/src/tool/apply_patch.txt +0 -33
  667. package/src/tool/bash-interactive.ts +0 -183
  668. package/src/tool/bash.ts +0 -696
  669. package/src/tool/bash.txt +0 -123
  670. package/src/tool/change-directory.ts +0 -91
  671. package/src/tool/codesearch.ts +0 -63
  672. package/src/tool/codesearch.txt +0 -12
  673. package/src/tool/edit.ts +0 -685
  674. package/src/tool/edit.txt +0 -10
  675. package/src/tool/external-directory.ts +0 -132
  676. package/src/tool/glob.ts +0 -100
  677. package/src/tool/glob.txt +0 -6
  678. package/src/tool/grep.ts +0 -145
  679. package/src/tool/grep.txt +0 -8
  680. package/src/tool/history.ts +0 -146
  681. package/src/tool/history.txt +0 -17
  682. package/src/tool/index.ts +0 -4
  683. package/src/tool/invalid.ts +0 -20
  684. package/src/tool/invocation-style.ts +0 -17
  685. package/src/tool/lsp.ts +0 -91
  686. package/src/tool/lsp.txt +0 -19
  687. package/src/tool/mcp-exa.ts +0 -78
  688. package/src/tool/memory-path-guard.ts +0 -162
  689. package/src/tool/memory.ts +0 -81
  690. package/src/tool/memory.txt +0 -69
  691. package/src/tool/multiedit.ts +0 -61
  692. package/src/tool/multiedit.txt +0 -41
  693. package/src/tool/plan-enter.txt +0 -14
  694. package/src/tool/plan-exit.txt +0 -13
  695. package/src/tool/plan.ts +0 -90
  696. package/src/tool/question.ts +0 -67
  697. package/src/tool/question.txt +0 -10
  698. package/src/tool/read.ts +0 -327
  699. package/src/tool/read.txt +0 -14
  700. package/src/tool/registry.ts +0 -415
  701. package/src/tool/schema.ts +0 -17
  702. package/src/tool/session-cwd.ts +0 -35
  703. package/src/tool/shell-tokenize.ts +0 -346
  704. package/src/tool/shell-wrap.ts +0 -190
  705. package/src/tool/skill.ts +0 -76
  706. package/src/tool/skill.txt +0 -5
  707. package/src/tool/task.shell.txt +0 -57
  708. package/src/tool/task.ts +0 -456
  709. package/src/tool/task.txt +0 -56
  710. package/src/tool/tool.ts +0 -153
  711. package/src/tool/truncate.ts +0 -201
  712. package/src/tool/truncation-dir.ts +0 -4
  713. package/src/tool/webfetch.ts +0 -199
  714. package/src/tool/webfetch.txt +0 -13
  715. package/src/tool/websearch/index.ts +0 -111
  716. package/src/tool/websearch/mimo.ts +0 -120
  717. package/src/tool/websearch/websearch.txt +0 -14
  718. package/src/tool/workflow.ts +0 -164
  719. package/src/tool/workflow.txt +0 -25
  720. package/src/tool/write.ts +0 -88
  721. package/src/tool/write.txt +0 -9
  722. package/src/util/abort.ts +0 -35
  723. package/src/util/archive.ts +0 -15
  724. package/src/util/color.ts +0 -17
  725. package/src/util/data-url.ts +0 -9
  726. package/src/util/defer.ts +0 -10
  727. package/src/util/effect-http-client.ts +0 -11
  728. package/src/util/effect-zod.ts +0 -367
  729. package/src/util/error.ts +0 -78
  730. package/src/util/filesystem.ts +0 -243
  731. package/src/util/fn.ts +0 -21
  732. package/src/util/format.ts +0 -20
  733. package/src/util/iife.ts +0 -3
  734. package/src/util/index.ts +0 -12
  735. package/src/util/keybind.ts +0 -101
  736. package/src/util/lazy.ts +0 -18
  737. package/src/util/local-context.ts +0 -23
  738. package/src/util/locale.ts +0 -79
  739. package/src/util/lock.ts +0 -96
  740. package/src/util/log.ts +0 -197
  741. package/src/util/media.ts +0 -26
  742. package/src/util/mimo-process.ts +0 -24
  743. package/src/util/network.ts +0 -9
  744. package/src/util/process.ts +0 -174
  745. package/src/util/queue.ts +0 -32
  746. package/src/util/record.ts +0 -3
  747. package/src/util/rpc.ts +0 -64
  748. package/src/util/schema.ts +0 -53
  749. package/src/util/scrap.ts +0 -10
  750. package/src/util/signal.ts +0 -12
  751. package/src/util/timeout.ts +0 -14
  752. package/src/util/token.ts +0 -5
  753. package/src/util/update-schema.ts +0 -13
  754. package/src/util/which.ts +0 -14
  755. package/src/util/wildcard.ts +0 -57
  756. package/src/workflow/builtin/deep-research.js +0 -391
  757. package/src/workflow/builtin.ts +0 -54
  758. package/src/workflow/events.ts +0 -72
  759. package/src/workflow/meta.ts +0 -335
  760. package/src/workflow/persistence.ts +0 -312
  761. package/src/workflow/resolve.ts +0 -45
  762. package/src/workflow/runtime-ref.ts +0 -18
  763. package/src/workflow/runtime.ts +0 -1234
  764. package/src/workflow/sandbox.ts +0 -280
  765. package/src/workflow/workflow.sql.ts +0 -31
  766. package/src/workflow/workspace.ts +0 -69
  767. package/src/worktree/index.ts +0 -614
  768. package/sst-env.d.ts +0 -10
  769. package/test/AGENTS.md +0 -133
  770. package/test/account/repo.test.ts +0 -352
  771. package/test/account/service.test.ts +0 -456
  772. package/test/acp/agent-interface.test.ts +0 -51
  773. package/test/acp/event-subscription.test.ts +0 -725
  774. package/test/actor/cancel-cascade.test.ts +0 -432
  775. package/test/actor/no-completion-listener.test.ts +0 -41
  776. package/test/actor/poststop-progress-write-permission.repro.test.ts +0 -414
  777. package/test/actor/registry-render.test.ts +0 -113
  778. package/test/actor/registry-status.test.ts +0 -111
  779. package/test/actor/registry.test.ts +0 -619
  780. package/test/actor/return-header.test.ts +0 -40
  781. package/test/actor/spawn-lifecycle.test.ts +0 -346
  782. package/test/actor/spawn-no-deadlock.test.ts +0 -340
  783. package/test/actor/spawn-notification.test.ts +0 -393
  784. package/test/actor/spawn-task-autostart.test.ts +0 -530
  785. package/test/actor/spawn.test.ts +0 -1072
  786. package/test/actor/status-event-payload.test.ts +0 -132
  787. package/test/actor/terminology.test.ts +0 -39
  788. package/test/actor/turn.test.ts +0 -125
  789. package/test/actor/waiter.test.ts +0 -246
  790. package/test/agent/agent.test.ts +0 -874
  791. package/test/agent/allowlist.test.ts +0 -45
  792. package/test/auth/auth.test.ts +0 -86
  793. package/test/bus/bus-effect.test.ts +0 -162
  794. package/test/bus/bus-integration.test.ts +0 -87
  795. package/test/bus/bus.test.ts +0 -219
  796. package/test/cli/account.test.ts +0 -26
  797. package/test/cli/cmd/tui/prompt-part.test.ts +0 -47
  798. package/test/cli/error.test.ts +0 -18
  799. package/test/cli/github-action.test.ts +0 -198
  800. package/test/cli/github-remote.test.ts +0 -80
  801. package/test/cli/import.test.ts +0 -54
  802. package/test/cli/plugin-auth-picker.test.ts +0 -120
  803. package/test/cli/run-completion.test.ts +0 -131
  804. package/test/cli/tui/keybind-plugin.test.ts +0 -90
  805. package/test/cli/tui/plugin-add.test.ts +0 -111
  806. package/test/cli/tui/plugin-install.test.ts +0 -87
  807. package/test/cli/tui/plugin-lifecycle.test.ts +0 -224
  808. package/test/cli/tui/plugin-loader-entrypoint.test.ts +0 -484
  809. package/test/cli/tui/plugin-loader-pure.test.ts +0 -71
  810. package/test/cli/tui/plugin-loader.test.ts +0 -816
  811. package/test/cli/tui/plugin-toggle.test.ts +0 -157
  812. package/test/cli/tui/revert-diff.test.ts +0 -35
  813. package/test/cli/tui/route-agent-id.test.ts +0 -26
  814. package/test/cli/tui/sidebar-tps.test.ts +0 -63
  815. package/test/cli/tui/slot-replace.test.tsx +0 -47
  816. package/test/cli/tui/sync-bucket.test.ts +0 -29
  817. package/test/cli/tui/theme-store.test.ts +0 -51
  818. package/test/cli/tui/thread.test.ts +0 -121
  819. package/test/cli/tui/transcript.test.ts +0 -426
  820. package/test/cli/tui/use-event.test.tsx +0 -175
  821. package/test/cli/tui/voice.test.ts +0 -269
  822. package/test/command/deep-research-command.test.ts +0 -16
  823. package/test/config/agent-color.test.ts +0 -77
  824. package/test/config/checkpoint-fork.test.ts +0 -21
  825. package/test/config/config.test.ts +0 -2577
  826. package/test/config/fixtures/empty-frontmatter.md +0 -4
  827. package/test/config/fixtures/frontmatter.md +0 -28
  828. package/test/config/fixtures/markdown-header.md +0 -11
  829. package/test/config/fixtures/no-frontmatter.md +0 -1
  830. package/test/config/fixtures/weird-model-id.md +0 -13
  831. package/test/config/lsp.test.ts +0 -87
  832. package/test/config/markdown.test.ts +0 -228
  833. package/test/config/plugin.test.ts +0 -0
  834. package/test/config/tui.test.ts +0 -627
  835. package/test/control-plane/adaptors.test.ts +0 -71
  836. package/test/control-plane/sse.test.ts +0 -56
  837. package/test/effect/app-runtime-logger.test.ts +0 -92
  838. package/test/effect/cross-spawn-spawner.test.ts +0 -411
  839. package/test/effect/instance-state.test.ts +0 -482
  840. package/test/effect/observability.test.ts +0 -46
  841. package/test/effect/run-service.test.ts +0 -46
  842. package/test/effect/runner-warn-log.test.ts +0 -111
  843. package/test/effect/runner.test.ts +0 -494
  844. package/test/fake/provider.ts +0 -90
  845. package/test/file/fsmonitor.test.ts +0 -68
  846. package/test/file/ignore.test.ts +0 -10
  847. package/test/file/index.test.ts +0 -956
  848. package/test/file/path-traversal.test.ts +0 -204
  849. package/test/file/ripgrep.test.ts +0 -214
  850. package/test/file/watcher.test.ts +0 -249
  851. package/test/filesystem/filesystem.test.ts +0 -319
  852. package/test/fixture/db.ts +0 -11
  853. package/test/fixture/fixture.test.ts +0 -58
  854. package/test/fixture/fixture.ts +0 -190
  855. package/test/fixture/flock-worker.ts +0 -72
  856. package/test/fixture/lsp/fake-lsp-server.js +0 -75
  857. package/test/fixture/plug-worker.ts +0 -93
  858. package/test/fixture/plugin-meta-worker.ts +0 -19
  859. package/test/fixture/skills/agents-sdk/SKILL.md +0 -152
  860. package/test/fixture/skills/agents-sdk/references/callable.md +0 -92
  861. package/test/fixture/skills/cloudflare/SKILL.md +0 -211
  862. package/test/fixture/skills/index.json +0 -6
  863. package/test/fixture/tui-plugin.ts +0 -329
  864. package/test/fixture/tui-runtime.ts +0 -31
  865. package/test/format/format.test.ts +0 -244
  866. package/test/git/git.test.ts +0 -128
  867. package/test/global/fixture/global-paths-worker.ts +0 -17
  868. package/test/global/mimocode-home.test.ts +0 -143
  869. package/test/history/backfill.test.ts +0 -149
  870. package/test/history/extract.test.ts +0 -106
  871. package/test/history/fts-query.test.ts +0 -30
  872. package/test/history/resolve.test.ts +0 -130
  873. package/test/history/service.test.ts +0 -210
  874. package/test/history/writer.test.ts +0 -163
  875. package/test/ide/ide.test.ts +0 -82
  876. package/test/inbox/drain-in-loop.test.ts +0 -230
  877. package/test/inbox/fork-agent-compat.test.ts +0 -387
  878. package/test/inbox/gc-on-init.test.ts +0 -167
  879. package/test/inbox/send-no-block.test.ts +0 -120
  880. package/test/inbox/sender-cancel-independence.test.ts +0 -160
  881. package/test/inbox/wake-matrix.test.ts +0 -141
  882. package/test/installation/installation.test.ts +0 -226
  883. package/test/keybind.test.ts +0 -421
  884. package/test/lib/effect.ts +0 -53
  885. package/test/lib/filesystem.ts +0 -10
  886. package/test/lib/llm-server.ts +0 -770
  887. package/test/lib/scripted-llm-server.ts +0 -245
  888. package/test/lsp/client.test.ts +0 -98
  889. package/test/lsp/index.test.ts +0 -109
  890. package/test/lsp/launch.test.ts +0 -22
  891. package/test/lsp/lifecycle.test.ts +0 -184
  892. package/test/mcp/headers.test.ts +0 -178
  893. package/test/mcp/lifecycle.test.ts +0 -824
  894. package/test/mcp/oauth-auto-connect.test.ts +0 -281
  895. package/test/mcp/oauth-browser.test.ts +0 -268
  896. package/test/mcp/oauth-callback.test.ts +0 -34
  897. package/test/memory/abort-leak-webfetch.ts +0 -49
  898. package/test/memory/abort-leak.test.ts +0 -127
  899. package/test/memory/cc-frontmatter.test.ts +0 -85
  900. package/test/memory/cc-paths.test.ts +0 -60
  901. package/test/memory/cc-reconcile.test.ts +0 -239
  902. package/test/memory/cc-search.test.ts +0 -151
  903. package/test/memory/fts-query.test.ts +0 -48
  904. package/test/memory/fts-rowid-stability.test.ts +0 -271
  905. package/test/memory/paths.test.ts +0 -210
  906. package/test/memory/reconcile.test.ts +0 -115
  907. package/test/memory/service.test.ts +0 -169
  908. package/test/npm.test.ts +0 -18
  909. package/test/patch/patch.test.ts +0 -348
  910. package/test/permission/abort.test.ts +0 -116
  911. package/test/permission/arity.test.ts +0 -33
  912. package/test/permission/disabled.test.ts +0 -51
  913. package/test/permission/next.test.ts +0 -1080
  914. package/test/permission/non-interactive.test.ts +0 -55
  915. package/test/permission-task.test.ts +0 -326
  916. package/test/plugin/actor-hooks.test.ts +0 -1471
  917. package/test/plugin/auth-override.test.ts +0 -79
  918. package/test/plugin/checkpoint-splitover.test.ts +0 -434
  919. package/test/plugin/cloudflare.test.ts +0 -68
  920. package/test/plugin/codex.test.ts +0 -123
  921. package/test/plugin/github-copilot-models.test.ts +0 -163
  922. package/test/plugin/install-concurrency.test.ts +0 -140
  923. package/test/plugin/install.test.ts +0 -570
  924. package/test/plugin/loader-shared.test.ts +0 -1169
  925. package/test/plugin/matcher.test.ts +0 -97
  926. package/test/plugin/meta.test.ts +0 -137
  927. package/test/plugin/shared.test.ts +0 -88
  928. package/test/plugin/subagent-progress-checker.test.ts +0 -227
  929. package/test/plugin/trigger.test.ts +0 -116
  930. package/test/plugin/woozlit.test.ts +0 -68
  931. package/test/plugin/workspace-adaptor.test.ts +0 -109
  932. package/test/preload.ts +0 -102
  933. package/test/project/migrate-global.test.ts +0 -150
  934. package/test/project/project-id.test.ts +0 -64
  935. package/test/project/project.test.ts +0 -481
  936. package/test/project/vcs.test.ts +0 -286
  937. package/test/project/worktree-remove.test.ts +0 -126
  938. package/test/project/worktree.test.ts +0 -214
  939. package/test/provider/amazon-bedrock.test.ts +0 -462
  940. package/test/provider/copilot/convert-to-copilot-messages.test.ts +0 -523
  941. package/test/provider/copilot/copilot-chat-model.test.ts +0 -592
  942. package/test/provider/error.test.ts +0 -160
  943. package/test/provider/gitlab-duo.test.ts +0 -413
  944. package/test/provider/model-groups.test.ts +0 -389
  945. package/test/provider/provider-chunk-timeout.test.ts +0 -23
  946. package/test/provider/provider.test.ts +0 -2648
  947. package/test/provider/transform.test.ts +0 -3379
  948. package/test/pty/pty-output-isolation.test.ts +0 -146
  949. package/test/pty/pty-session.test.ts +0 -102
  950. package/test/pty/pty-shell.test.ts +0 -69
  951. package/test/question/question.test.ts +0 -464
  952. package/test/server/global-session-list.test.ts +0 -105
  953. package/test/server/project-init-git.test.ts +0 -122
  954. package/test/server/session-actions.test.ts +0 -49
  955. package/test/server/session-list.test.ts +0 -110
  956. package/test/server/session-messages.test.ts +0 -220
  957. package/test/server/session-prompt-busy.test.ts +0 -146
  958. package/test/server/session-select.test.ts +0 -100
  959. package/test/server/session-task-route.test.ts +0 -165
  960. package/test/server/summarize-route-main-slice.test.ts +0 -99
  961. package/test/server/trace-attributes.test.ts +0 -76
  962. package/test/server/workflows-route.test.ts +0 -279
  963. package/test/session/bootstrap-skip-system.test.ts +0 -121
  964. package/test/session/boundary.test.ts +0 -33
  965. package/test/session/budgeted-read.test.ts +0 -74
  966. package/test/session/checkpoint-align.test.ts +0 -58
  967. package/test/session/checkpoint-boundary.test.ts +0 -186
  968. package/test/session/checkpoint-child-session.test.ts +0 -508
  969. package/test/session/checkpoint-context.test.ts +0 -141
  970. package/test/session/checkpoint-drain.test.ts +0 -188
  971. package/test/session/checkpoint-extract-titles.test.ts +0 -58
  972. package/test/session/checkpoint-fork-mode.test.ts +0 -576
  973. package/test/session/checkpoint-main-slice.test.ts +0 -259
  974. package/test/session/checkpoint-paths.test.ts +0 -78
  975. package/test/session/checkpoint-permission.test.ts +0 -136
  976. package/test/session/checkpoint-progress-reconcile.test.ts +0 -219
  977. package/test/session/checkpoint-rebuild-unify.test.ts +0 -143
  978. package/test/session/checkpoint-rebuild-v3.test.ts +0 -248
  979. package/test/session/checkpoint-render-verify.test.ts +0 -512
  980. package/test/session/checkpoint-retry.test.ts +0 -150
  981. package/test/session/checkpoint-splitover-integration.test.ts +0 -533
  982. package/test/session/checkpoint-templates.test.ts +0 -51
  983. package/test/session/checkpoint-thresholds.test.ts +0 -120
  984. package/test/session/checkpoint-validator.test.ts +0 -189
  985. package/test/session/classify-integration.test.ts +0 -476
  986. package/test/session/classify.test.ts +0 -335
  987. package/test/session/compaction-agent-scope.test.ts +0 -164
  988. package/test/session/context-inheritance.test.ts +0 -46
  989. package/test/session/fork-prefix-invariant.test.ts +0 -116
  990. package/test/session/goal.test.ts +0 -106
  991. package/test/session/instruction.test.ts +0 -387
  992. package/test/session/invalid-output-continuation.test.ts +0 -150
  993. package/test/session/last-message-info.test.ts +0 -47
  994. package/test/session/length-tool-safety.test.ts +0 -121
  995. package/test/session/llm-request-prefix.test.ts +0 -197
  996. package/test/session/llm-retry.test.ts +0 -59
  997. package/test/session/llm-system-prompt.test.ts +0 -479
  998. package/test/session/llm.test.ts +0 -1272
  999. package/test/session/main-lifecycle.test.ts +0 -51
  1000. package/test/session/main-runloop-history-invariant.test.ts +0 -182
  1001. package/test/session/max-mode-econnreset.test.ts +0 -229
  1002. package/test/session/max-mode.test.ts +0 -54
  1003. package/test/session/message-v2-filter.test.ts +0 -197
  1004. package/test/session/message-v2.test.ts +0 -1119
  1005. package/test/session/messages-default-main.test.ts +0 -105
  1006. package/test/session/messages-pagination.test.ts +0 -888
  1007. package/test/session/overflow.test.ts +0 -576
  1008. package/test/session/processor-effect.test.ts +0 -853
  1009. package/test/session/prompt-effect.test.ts +0 -1574
  1010. package/test/session/prompt-rebuild-loop.test.ts +0 -108
  1011. package/test/session/prompt-rebuild-reset.test.ts +0 -67
  1012. package/test/session/prompt-sweep.test.ts +0 -145
  1013. package/test/session/prompt-task-gate.test.ts +0 -127
  1014. package/test/session/prompt.test.ts +0 -703
  1015. package/test/session/prune-main-slice.test.ts +0 -272
  1016. package/test/session/prune-skip-system.test.ts +0 -346
  1017. package/test/session/prune.test.ts +0 -419
  1018. package/test/session/rebuild-microcompact.test.ts +0 -318
  1019. package/test/session/recall-reminder.test.ts +0 -37
  1020. package/test/session/retry.test.ts +0 -410
  1021. package/test/session/revert-compact.test.ts +0 -639
  1022. package/test/session/run-state-tuple-key.test.ts +0 -152
  1023. package/test/session/session-create-registers-main.test.ts +0 -70
  1024. package/test/session/session.test.ts +0 -181
  1025. package/test/session/snapshot-tool-race.test.ts +0 -301
  1026. package/test/session/structured-output-integration.test.ts +0 -264
  1027. package/test/session/structured-output-retry.test.ts +0 -127
  1028. package/test/session/structured-output.test.ts +0 -397
  1029. package/test/session/summary-main-slice.test.ts +0 -170
  1030. package/test/session/system.test.ts +0 -72
  1031. package/test/share/share-next.test.ts +0 -332
  1032. package/test/shell/shell.test.ts +0 -73
  1033. package/test/skill/compose-review.test.ts +0 -141
  1034. package/test/skill/discovery.test.ts +0 -116
  1035. package/test/skill/skill.test.ts +0 -465
  1036. package/test/snapshot/snapshot.test.ts +0 -1531
  1037. package/test/storage/db.test.ts +0 -16
  1038. package/test/storage/json-migration.test.ts +0 -831
  1039. package/test/storage/storage.test.ts +0 -293
  1040. package/test/sync/index.test.ts +0 -237
  1041. package/test/task/gate-state.test.ts +0 -66
  1042. package/test/task/gate.test.ts +0 -167
  1043. package/test/task/registry.test.ts +0 -152
  1044. package/test/task/state-machine.test.ts +0 -292
  1045. package/test/team/migrate-to-inbox.test.ts +0 -124
  1046. package/test/team/team.test.ts +0 -75
  1047. package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
  1048. package/test/tool/actor-cancel.test.ts +0 -206
  1049. package/test/tool/actor-recover.test.ts +0 -50
  1050. package/test/tool/actor-send.test.ts +0 -200
  1051. package/test/tool/actor-status.test.ts +0 -296
  1052. package/test/tool/actor-wait.test.ts +0 -193
  1053. package/test/tool/actor.shell.test.ts +0 -250
  1054. package/test/tool/actor.test.ts +0 -748
  1055. package/test/tool/apply_patch.test.ts +0 -626
  1056. package/test/tool/bash.test.ts +0 -1195
  1057. package/test/tool/describe-workflow.test.ts +0 -12
  1058. package/test/tool/edit.test.ts +0 -691
  1059. package/test/tool/external-directory.test.ts +0 -207
  1060. package/test/tool/fixtures/large-image.png +0 -0
  1061. package/test/tool/fixtures/models-api.json +0 -65179
  1062. package/test/tool/glob.test.ts +0 -81
  1063. package/test/tool/grep.test.ts +0 -114
  1064. package/test/tool/history.test.ts +0 -144
  1065. package/test/tool/invocation-style.test.ts +0 -30
  1066. package/test/tool/memory-edit-ask-skip.test.ts +0 -62
  1067. package/test/tool/memory-path-guard.test.ts +0 -594
  1068. package/test/tool/memory.test.ts +0 -71
  1069. package/test/tool/question.test.ts +0 -167
  1070. package/test/tool/read.test.ts +0 -483
  1071. package/test/tool/registry-invocation-style.test.ts +0 -121
  1072. package/test/tool/registry.test.ts +0 -164
  1073. package/test/tool/shell-tokenize.test.ts +0 -273
  1074. package/test/tool/shell-wrap-missing-script.test.ts +0 -128
  1075. package/test/tool/shell-wrap.test.ts +0 -257
  1076. package/test/tool/skill.test.ts +0 -99
  1077. package/test/tool/task-recover.test.ts +0 -36
  1078. package/test/tool/task.shell.test.ts +0 -234
  1079. package/test/tool/task.test.ts +0 -296
  1080. package/test/tool/tool-def-shell-shape.test.ts +0 -23
  1081. package/test/tool/tool-define.test.ts +0 -59
  1082. package/test/tool/truncation.test.ts +0 -253
  1083. package/test/tool/webfetch.test.ts +0 -103
  1084. package/test/tool/whitelist.test.ts +0 -373
  1085. package/test/tool/write.test.ts +0 -244
  1086. package/test/util/data-url.test.ts +0 -14
  1087. package/test/util/effect-zod.test.ts +0 -869
  1088. package/test/util/error.test.ts +0 -38
  1089. package/test/util/filesystem.test.ts +0 -656
  1090. package/test/util/format.test.ts +0 -59
  1091. package/test/util/glob.test.ts +0 -164
  1092. package/test/util/iife.test.ts +0 -36
  1093. package/test/util/lazy.test.ts +0 -50
  1094. package/test/util/lock.test.ts +0 -72
  1095. package/test/util/log.test.ts +0 -44
  1096. package/test/util/module.test.ts +0 -59
  1097. package/test/util/process.test.ts +0 -128
  1098. package/test/util/timeout.test.ts +0 -21
  1099. package/test/util/which.test.ts +0 -100
  1100. package/test/util/wildcard.test.ts +0 -90
  1101. package/test/workflow/builtin.test.ts +0 -22
  1102. package/test/workflow/deep-research-cluster.test.ts +0 -47
  1103. package/test/workflow/lib.ts +0 -243
  1104. package/test/workflow/meta.test.ts +0 -142
  1105. package/test/workflow/model-routing.test.ts +0 -68
  1106. package/test/workflow/persistence.test.ts +0 -229
  1107. package/test/workflow/resolve.test.ts +0 -37
  1108. package/test/workflow/runtime-nested.test.ts +0 -419
  1109. package/test/workflow/runtime-worktree.test.ts +0 -261
  1110. package/test/workflow/runtime.test.ts +0 -1078
  1111. package/test/workflow/sandbox.test.ts +0 -259
  1112. package/test/workflow/tool.test.ts +0 -473
  1113. package/test/workflow/verify-wow.test.ts +0 -144
  1114. package/test/workflow/workspace.test.ts +0 -88
  1115. package/test/workspace/workspace-restore.test.ts +0 -281
  1116. package/test/worktree/index.test.ts +0 -30
  1117. package/tsconfig.json +0 -24
  1118. /package/{script/postinstall.mjs → postinstall.mjs} +0 -0
@@ -1,1078 +0,0 @@
1
- import { describe, expect, afterEach } from "bun:test"
2
- import { Effect } from "effect"
3
- import { Session } from "../../src/session"
4
- import { Instance } from "../../src/project/instance"
5
- import { provideTmpdirServer } from "../fixture/fixture"
6
- import { testEffect } from "../lib/effect"
7
- import { reply } from "../lib/llm-server"
8
- import { WorkflowRuntime } from "../../src/workflow/runtime"
9
- import { WorkflowAgentFailed } from "../../src/workflow/events"
10
- import { WorkflowPersistence } from "../../src/workflow/persistence"
11
- import { ActorRegistry } from "../../src/actor/registry"
12
- import { Bus } from "../../src/bus"
13
- import { makeLayer, ref, providerCfg } from "./lib"
14
-
15
- afterEach(async () => {
16
- await Instance.disposeAll()
17
- })
18
-
19
- const it = testEffect(makeLayer())
20
-
21
- describe("WorkflowRuntime agent() fan-out", () => {
22
- it.live("runs a script that fans out 3 agents and returns their results", () =>
23
- provideTmpdirServer(
24
- Effect.fnUntraced(function* ({ llm }) {
25
- const runtime = yield* WorkflowRuntime.Service
26
- const session = yield* Session.Service
27
- const parent = yield* session.create({
28
- title: "wf fanout",
29
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
30
- })
31
- yield* llm.text("done")
32
- yield* llm.text("done")
33
- yield* llm.text("done")
34
- const script = [
35
- `export const meta = { name: "t", description: "d" }`,
36
- `const r = await parallel([() => agent("a"), () => agent("b"), () => agent("c")])`,
37
- `return r`,
38
- ].join("\n")
39
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
40
- const outcome = yield* runtime.wait({ runID })
41
- expect(outcome.status).toBe("completed")
42
- expect((outcome as { result: string[] }).result.filter((x) => x === "done").length).toBe(3)
43
- }),
44
- { git: true, config: providerCfg },
45
- ),
46
- )
47
- })
48
-
49
- describe("WorkflowRuntime concurrency + resilience", () => {
50
- it.live("8 agents under cap=2 all complete", () =>
51
- provideTmpdirServer(
52
- Effect.fnUntraced(function* ({ llm }) {
53
- const runtime = yield* WorkflowRuntime.Service
54
- const session = yield* Session.Service
55
- const parent = yield* session.create({
56
- title: "wf cap",
57
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
58
- })
59
- for (let i = 0; i < 8; i++) yield* llm.text("done")
60
- const script = [
61
- `export const meta = { name: "t", description: "d" }`,
62
- `const ts = []`,
63
- `for (let i = 0; i < 8; i++) ts.push(() => agent("x" + i))`,
64
- `return (await parallel(ts)).length`,
65
- ].join("\n")
66
- const { runID } = yield* runtime.start({
67
- script,
68
- sessionID: parent.id,
69
- parentActorID: "main",
70
- model: ref,
71
- maxConcurrentAgents: 2,
72
- })
73
- const outcome = yield* runtime.wait({ runID })
74
- expect(outcome.status).toBe("completed")
75
- expect((outcome as { result: number }).result).toBe(8)
76
- }),
77
- { git: true, config: providerCfg },
78
- ),
79
- )
80
-
81
- it.live("a failing child yields null; the run still completes", () =>
82
- provideTmpdirServer(
83
- Effect.fnUntraced(function* ({ llm }) {
84
- const runtime = yield* WorkflowRuntime.Service
85
- const session = yield* Session.Service
86
- const parent = yield* session.create({
87
- title: "wf null",
88
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
89
- })
90
- // A 400 is a non-retryable client error (see llm.retryable): the child
91
- // that receives it finishes with no assistant text, so its AgentOutcome
92
- // carries no finalText and agent() resolves to null. The other child gets
93
- // "ok". agent() must NEVER throw the failure into the guest — both the run
94
- // and the sibling agent must still complete. Assertions are
95
- // order-independent, so the FIFO race over which child lands first is
96
- // benign. (Each agent() is a subagent sharing the run's session, so
97
- // result isolation rides on the agent-scoped lastAssistant fix — each
98
- // child's outcome is extracted by its own agentID, so concurrent
99
- // same-session children do not cross-contaminate — see runtime.ts.)
100
- yield* llm.error(400, { error: { message: "bad request" } })
101
- yield* llm.text("ok")
102
- // A failed agent() resolves to a nullish value in the guest (the host
103
- // returns null; the sandbox marshals host null → guest undefined). Treat
104
- // both as the failure sentinel.
105
- const script = [
106
- `export const meta = { name: "t", description: "d" }`,
107
- `const r = await parallel([() => agent("a"), () => agent("b")])`,
108
- `return r.map((x) => (x === null || x === undefined) ? "null" : x)`,
109
- ].join("\n")
110
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
111
- const outcome = yield* runtime.wait({ runID })
112
- expect(outcome.status).toBe("completed")
113
- const r = (outcome as { result: string[] }).result
114
- expect(r).toContain("null")
115
- expect(r).toContain("ok")
116
- }),
117
- { git: true, config: providerCfg },
118
- ),
119
- )
120
- })
121
-
122
- describe("WorkflowRuntime convergence (scout drives fan-out)", () => {
123
- // The scout is an ordinary agent() call with a schema → it returns structured
124
- // data. The mock LLM answers its turn with a StructuredOutput tool call; the
125
- // runtime spawns it under format:{type:"json_schema"} (runtime.ts:199) and
126
- // agent() resolves to the validated object (runtime.ts:205).
127
- const scoutSchema = {
128
- type: "object",
129
- additionalProperties: false,
130
- properties: { todo: { type: "array", items: { type: "string" } } },
131
- required: ["todo"],
132
- }
133
-
134
- // Drives the real runtime with a mock LLM: scout reports `todo`, the script
135
- // fans out one worker per todo. Asserts the run result and the run's cumulative
136
- // agent-spawn tally (agentCount = +1 per agent() call, never decremented —
137
- // runtime.ts:301), the deterministic observable immune to LLM-queue races.
138
- const runWithTodo = (todo: string[], expectedAgentCount: number) =>
139
- provideTmpdirServer(
140
- Effect.fnUntraced(function* ({ llm }) {
141
- const runtime = yield* WorkflowRuntime.Service
142
- const session = yield* Session.Service
143
- const parent = yield* session.create({
144
- title: "wf converge",
145
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
146
- })
147
- // Scout turn FIRST: it is awaited before the fan-out, so it consumes this
148
- // StructuredOutput reply before any worker dequeues — ordering is stable.
149
- yield* llm.push(reply().tool("StructuredOutput", { todo }))
150
- // One plain text reply per worker (no schema → finalText, runtime.ts:205).
151
- for (let i = 0; i < todo.length; i++) yield* llm.text("done")
152
- const script = [
153
- `export const meta = { name: "t", description: "d" }`,
154
- `const s = await agent("scout", { schema: ${JSON.stringify(scoutSchema)} })`,
155
- `const todo = (s && s.todo) || []`,
156
- `await parallel(todo.map((u) => () => agent("work " + u)))`,
157
- `return todo.length`,
158
- ].join("\n")
159
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
160
- const outcome = yield* runtime.wait({ runID })
161
- expect(outcome.status).toBe("completed")
162
- expect((outcome as { result: number }).result).toBe(todo.length)
163
- // The load-bearing assertion: scout's reported todo count drives the
164
- // worker fan-out → 1 scout + N workers spawned.
165
- const snap = yield* runtime.status({ runID })
166
- expect(snap.agentCount).toBe(expectedAgentCount)
167
- }),
168
- { git: true, config: providerCfg },
169
- )
170
-
171
- it.live("4 todo → 1 scout + 4 workers spawned", () => runWithTodo(["a", "b", "c", "d"], 5))
172
-
173
- it.live("2 todo → 1 scout + 2 workers spawned (a re-run with fewer undone units does less work)", () =>
174
- runWithTodo(["a", "b"], 3),
175
- )
176
- })
177
-
178
- describe("WorkflowRuntime schema contract (schema'd agent never returns prose)", () => {
179
- // A schema'd agent() whose model NEVER calls StructuredOutput (answers with plain
180
- // prose, exhausting the format.retryCount=2 retries) MUST resolve to `null`, NOT
181
- // the prose finalText. Returning prose breaks scripts that do `r.fields.map(...)`
182
- // (the prose is a truthy non-object) and our pipeline's catch then injects a bare
183
- // null that bypasses the script's own `r ? … : []` guard — exactly the full-tree
184
- // Phase-0 Verify crash. So: schema requested + structured-output failed ⇒ null.
185
- const fieldsSchema = {
186
- type: "object",
187
- additionalProperties: false,
188
- properties: { fields: { type: "array", items: { type: "string" } } },
189
- required: ["fields"],
190
- }
191
-
192
- it.live("schema'd agent that only returns prose resolves to null, not the prose", () =>
193
- provideTmpdirServer(
194
- Effect.fnUntraced(function* ({ llm }) {
195
- const runtime = yield* WorkflowRuntime.Service
196
- const session = yield* Session.Service
197
- const parent = yield* session.create({
198
- title: "wf schema-contract",
199
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
200
- })
201
- // The model refuses structured output every turn: original + 2 retries
202
- // (format.retryCount=2) all answer with prose, never a StructuredOutput call.
203
- yield* llm.text("I cannot call StructuredOutput; here is prose instead.")
204
- yield* llm.text("Still prose, no tool call.")
205
- yield* llm.text("Prose again.")
206
- // The script returns typeof the agent result. With the fix it must be
207
- // "object" (null is typeof "object") and specifically === null — NOT "string".
208
- const script = [
209
- `export const meta = { name: "t", description: "d" }`,
210
- `const r = await agent("classify", { schema: ${JSON.stringify(fieldsSchema)} })`,
211
- `return { isFailure: r === null || r === undefined, isProse: typeof r === "string" }`,
212
- ].join("\n")
213
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
214
- const outcome = yield* runtime.wait({ runID })
215
- expect(outcome.status).toBe("completed")
216
- const result = (outcome as { result: { isFailure: boolean; isProse: boolean } }).result
217
- expect(result.isProse).toBe(false) // never the prose string
218
- expect(result.isFailure).toBe(true) // schema-fail ⇒ null/undefined sentinel
219
- }),
220
- { git: true, config: providerCfg },
221
- ),
222
- )
223
- })
224
-
225
- describe("WorkflowRuntime error visibility", () => {
226
- // A script-logic error (a TypeError downstream of a never-throw agent()) must
227
- // fail the run with a VISIBLE error — the real guest message — not the opaque
228
- // Effect wrapper. Bare Effect.tryPromise wraps the sandbox rejection as an
229
- // UnknownError whose .message is literally "An error occurred in
230
- // Effect.tryPromise" (the real error is buried in .cause), so runtime.ts:547's
231
- // `failure.message` extract emitted that useless string. The object-form
232
- // tryPromise makes result.failure the raw sandbox Error, whose .message already
233
- // carries the guest {name,message,stack} (vm.dump preserves it through the
234
- // throw site). This is the test that would have caught the 3 opaque crashes.
235
- it.live("a script-logic TypeError fails the run with a visible error (not the Effect wrapper)", () =>
236
- provideTmpdirServer(
237
- Effect.fnUntraced(function* ({ llm }) {
238
- const runtime = yield* WorkflowRuntime.Service
239
- const session = yield* Session.Service
240
- const parent = yield* session.create({
241
- title: "wf err-visible",
242
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
243
- })
244
- yield* llm.text("ok")
245
- // agent("a") → "ok"; r = ["ok"]; r.map(x => x.nope.deeper) derefs a
246
- // property of undefined downstream of the (now never-catching) parallel.
247
- const script = [
248
- `export const meta = { name: "t", description: "d" }`,
249
- `const r = await parallel([() => agent("a")])`,
250
- `return r.map((x) => x.nope.deeper)`,
251
- ].join("\n")
252
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
253
- const outcome = yield* runtime.wait({ runID })
254
- expect(outcome.status).toBe("failed")
255
- const error = (outcome as { error: string }).error
256
- // NOT the opaque Effect wrapper, and carries a script-logic token.
257
- expect(error).not.toBe("An error occurred in Effect.tryPromise")
258
- expect(error).toMatch(/nope|deeper|undefined|not an object|TypeError/)
259
- }),
260
- { git: true, config: providerCfg },
261
- ),
262
- )
263
- })
264
-
265
- describe("WorkflowRuntime cancel cascade", () => {
266
- it.live("cancel stops in-flight child agents and marks the run cancelled", () =>
267
- provideTmpdirServer(
268
- Effect.fnUntraced(function* ({ llm }) {
269
- const runtime = yield* WorkflowRuntime.Service
270
- const session = yield* Session.Service
271
- const parent = yield* session.create({
272
- title: "wf cancel",
273
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
274
- })
275
- yield* llm.hang // children hang so they're in-flight at cancel time
276
- const script = [
277
- `export const meta = { name: "t", description: "d" }`,
278
- `return await parallel([() => agent("a"), () => agent("b"), () => agent("c")])`,
279
- ].join("\n")
280
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
281
- yield* Effect.sleep("250 millis") // let the fan-out spawn children
282
- yield* runtime.cancel({ runID })
283
- const s = yield* runtime.status({ runID })
284
- expect(s.status).toBe("cancelled")
285
- }),
286
- { git: true, config: providerCfg },
287
- ),
288
- // Headroom over the default 5s: this cancel test can run concurrently with the
289
- // heavyweight real-Instance worktree-isolation tests, where CI load occasionally
290
- // pushed it past 5s. Generous margin keeps it deterministic without masking hangs.
291
- 15000,
292
- )
293
-
294
- // MR104 #2 — orphan-on-cancel race. The bug: spawnShared added the child's
295
- // actorID to the run's reclaim set (entry.childActorIDs) only AFTER actor.spawn
296
- // RESOLVED across the quickjs Promise bridge. A cancel landing during that gap
297
- // reclaimed a STALE (empty) set, then interrupted the workflow fiber — but each
298
- // child runs DETACHED in the actor scope (background:true + forkIn), so the
299
- // interrupt never reaches it. Result: registered children that reclaim never
300
- // cancels — orphans holding subscriptions/tokens/worktrees. Fix: register the id
301
- // INSIDE the spawn Effect (onActorID), before the work fiber detaches.
302
- //
303
- // Observable: reclaim graceful-cancels every id in childActorIDs, and
304
- // Actor.cancel writes lastOutcome="cancelled" on each (registry.test cancel
305
- // cascade). So immediately after cancel returns, EVERY spawned child must carry
306
- // lastOutcome="cancelled" — proof that reclaim saw it. Pre-fix the set is empty
307
- // at reclaim time, so the children are never cancelled (lastOutcome stays unset).
308
- // NOTE: we assert at the instant cancel returns, BEFORE any further sleep — a
309
- // graceful-cancelled child can be re-driven by the auto-answering test LLM and
310
- // bounce back to running:success later, which is a mock artifact unrelated to
311
- // the orphan bug; the cancel-stamp at t0 is the stable signal.
312
- it.live("cancel during an in-flight fan-out reclaims every child (no orphan)", () =>
313
- provideTmpdirServer(
314
- Effect.fnUntraced(function* ({ llm }) {
315
- const runtime = yield* WorkflowRuntime.Service
316
- const session = yield* Session.Service
317
- const registry = yield* ActorRegistry.Service
318
- const parent = yield* session.create({
319
- title: "wf cancel no-orphan",
320
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
321
- })
322
- yield* llm.hang // every child hangs at the LLM → in-flight at cancel time
323
- // A wide fan-out keeps spawns resolving across the bridge so the cancel
324
- // lands while children are registered but the post-resolve add (the bug)
325
- // has not run.
326
- const script = [
327
- `export const meta = { name: "t", description: "d" }`,
328
- `const ts = []`,
329
- `for (let i = 0; i < 8; i++) ts.push(() => agent("child" + i))`,
330
- `return await parallel(ts)`,
331
- ].join("\n")
332
- const { runID } = yield* runtime.start({
333
- script,
334
- sessionID: parent.id,
335
- parentActorID: "main",
336
- model: ref,
337
- maxConcurrentAgents: 8,
338
- })
339
- // Let the fan-out register its children, then cancel mid-flight.
340
- yield* Effect.sleep("150 millis")
341
- yield* runtime.cancel({ runID })
342
-
343
- const s = yield* runtime.status({ runID })
344
- expect(s.status).toBe("cancelled")
345
-
346
- // At least one child was actually spawned (else the test proves nothing).
347
- const children = (yield* registry.listBySession(parent.id)).filter((a) => a.actorID !== "main")
348
- expect(children.length).toBeGreaterThan(0)
349
- // Every spawned child was reclaimed: cancel stamped lastOutcome="cancelled"
350
- // on each. An orphan (never reclaimed) would have lastOutcome unset here.
351
- expect(children.filter((a) => a.lastOutcome !== "cancelled")).toEqual([])
352
- }),
353
- { git: true, config: providerCfg },
354
- ),
355
- 20000,
356
- )
357
- })
358
-
359
- describe("WorkflowRuntime concurrency clamp", () => {
360
- it.live("a request above 2x cores is clamped (run still completes)", () =>
361
- provideTmpdirServer(
362
- Effect.fnUntraced(function* ({ llm }) {
363
- const runtime = yield* WorkflowRuntime.Service
364
- const session = yield* Session.Service
365
- const parent = yield* session.create({ title: "wf clamp", permission: [{ permission: "*", pattern: "*", action: "allow" }] })
366
- yield* llm.text("done"); yield* llm.text("done")
367
- const script = [
368
- `export const meta = { name: "t", description: "d" }`,
369
- `return (await parallel([() => agent("a"), () => agent("b")])).length`,
370
- ].join("\n")
371
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref, maxConcurrentAgents: 100000 })
372
- const o = yield* runtime.wait({ runID })
373
- expect(o.status).toBe("completed")
374
- expect((o as { result: number }).result).toBe(2)
375
- }),
376
- { git: true, config: providerCfg },
377
- ),
378
- )
379
- })
380
-
381
- describe("WorkflowRuntime per-agent timeout (straggler-abort)", () => {
382
- // A single hung agent (e.g. a persistent mimo TTFT wall) must not stall the whole
383
- // parallel/pipeline barrier indefinitely. With agentTimeoutMs set, the hung agent
384
- // is gracefully cancelled and resolves to the never-throw null sentinel, so the
385
- // sibling's "ok" and the run COMPLETE — bounded by the per-agent timeout, NOT the
386
- // far-larger global scriptDeadline (a PASS proves the per-agent path fired).
387
- it.live("a hung agent times out to null under agentTimeoutMs; the run completes", () =>
388
- provideTmpdirServer(
389
- Effect.fnUntraced(function* ({ llm }) {
390
- const runtime = yield* WorkflowRuntime.Service
391
- const session = yield* Session.Service
392
- const parent = yield* session.create({
393
- title: "wf agent-timeout",
394
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
395
- })
396
- // Queue ONE hang. The two agents race to dequeue it: whichever pulls it hangs
397
- // forever; the other finds the queue empty and gets the server's auto-"ok".
398
- // So exactly 1 hangs (→ times out → null) and 1 returns "ok", regardless of
399
- // FIFO order — the assertion counts totals, so it's order-independent.
400
- yield* llm.hang
401
- const script = [
402
- `export const meta = { name: "t", description: "d" }`,
403
- `const r = await parallel([() => agent("a"), () => agent("b")])`,
404
- `return r.map((x) => (x === null || x === undefined) ? "null" : "ok")`,
405
- ].join("\n")
406
- const { runID } = yield* runtime.start({
407
- script,
408
- sessionID: parent.id,
409
- parentActorID: "main",
410
- model: ref,
411
- agentTimeoutMs: 1500,
412
- scriptDeadlineMs: 60000, // far above the per-agent timeout
413
- })
414
- const outcome = yield* runtime.wait({ runID })
415
- expect(outcome.status).toBe("completed")
416
- const r = (outcome as { result: string[] }).result
417
- expect(r.filter((x) => x === "null").length).toBe(1)
418
- expect(r.filter((x) => x === "ok").length).toBe(1)
419
- }),
420
- { git: true, config: providerCfg },
421
- ),
422
- 20000, // budget >> the 1500ms per-agent timeout, well under any true hang
423
- )
424
- })
425
-
426
- describe("WorkflowRuntime lifecycle cap", () => {
427
- // Hitting the lifecycle agent cap is an EXPECTED steady-state for a large
428
- // fan-out (lifetime-classify caps its own verify sample to stay under it), not
429
- // a programming error. So an over-cap agent() must return the never-throw null
430
- // sentinel (graceful degradation) — NOT throw, which post-NC-1 (combinators no
431
- // longer catch) would reject the whole batch and waste every completed agent.
432
- // maxLifecycleAgents parameterizes the cap so this is unit-testable at cap=2.
433
- it.live("over-cap agent() returns null; the run still completes (cap=2, fan-out 3)", () =>
434
- provideTmpdirServer(
435
- Effect.fnUntraced(function* ({ llm }) {
436
- const runtime = yield* WorkflowRuntime.Service
437
- const session = yield* Session.Service
438
- const parent = yield* session.create({
439
- title: "wf cap-null",
440
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
441
- })
442
- // The check-then-increment is synchronous (no await between), so exactly 2
443
- // of the 3 spawn (count 0→1, 1→2) and the 3rd sees count 2 ≥ cap → null.
444
- // Two replies for the two that spawn; the 3rd never reaches the LLM.
445
- yield* llm.text("done")
446
- yield* llm.text("done")
447
- const script = [
448
- `export const meta = { name: "t", description: "d" }`,
449
- `const r = await parallel([() => agent("a"), () => agent("b"), () => agent("c")])`,
450
- `return r.map((x) => (x === null || x === undefined) ? "null" : "ok")`,
451
- ].join("\n")
452
- const { runID } = yield* runtime.start({
453
- script,
454
- sessionID: parent.id,
455
- parentActorID: "main",
456
- model: ref,
457
- maxLifecycleAgents: 2,
458
- })
459
- const outcome = yield* runtime.wait({ runID })
460
- expect(outcome.status).toBe("completed")
461
- const r = (outcome as { result: string[] }).result
462
- expect(r.filter((x) => x === "ok").length).toBe(2)
463
- expect(r.filter((x) => x === "null").length).toBe(1)
464
- }),
465
- { git: true, config: providerCfg },
466
- ),
467
- )
468
- })
469
-
470
- describe("WorkflowRuntime deadline", () => {
471
- it.live("a script that exceeds scriptDeadlineMs is interrupted, not hung", () =>
472
- provideTmpdirServer(
473
- Effect.fnUntraced(function* ({ llm }) {
474
- const runtime = yield* WorkflowRuntime.Service
475
- const session = yield* Session.Service
476
- const parent = yield* session.create({
477
- title: "wf deadline",
478
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
479
- })
480
- yield* llm.hang // the single agent hangs forever
481
- const script = [
482
- `export const meta = { name: "t", description: "d" }`,
483
- `return await agent("x")`,
484
- ].join("\n")
485
- const { runID } = yield* runtime.start({
486
- script,
487
- sessionID: parent.id,
488
- parentActorID: "main",
489
- model: ref,
490
- scriptDeadlineMs: 1500,
491
- })
492
- const outcome = yield* runtime.wait({ runID })
493
- // The deadline fires inside the sandbox; the run resolves failed (not completed, not hung).
494
- expect(outcome.status).toBe("failed")
495
- }),
496
- { git: true, config: providerCfg },
497
- ),
498
- )
499
- })
500
-
501
- describe("WorkflowRuntime counters", () => {
502
- it.live("running/succeeded/failed tracked separately and persisted", () =>
503
- provideTmpdirServer(
504
- Effect.fnUntraced(function* ({ llm }) {
505
- const runtime = yield* WorkflowRuntime.Service
506
- const session = yield* Session.Service
507
- const parent = yield* session.create({ title: "wf counters", permission: [{ permission: "*", pattern: "*", action: "allow" }] })
508
- yield* llm.error(400, { error: { message: "bad" } })
509
- yield* llm.text("ok")
510
- const script = [
511
- `export const meta = { name: "t", description: "d" }`,
512
- `return await parallel([() => agent("a"), () => agent("b")])`,
513
- ].join("\n")
514
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
515
- yield* runtime.wait({ runID })
516
- const row = yield* WorkflowPersistence.load(runID)
517
- expect(row?.succeeded).toBe(1)
518
- expect(row?.failed).toBe(1)
519
- expect(row?.running).toBe(0)
520
- expect(row?.status).toBe("completed")
521
- }),
522
- { git: true, config: providerCfg },
523
- ),
524
- )
525
- })
526
-
527
- describe("WorkflowRuntime list + resume", () => {
528
- it.live("list returns persisted runs newest-first, filtered by session", () =>
529
- provideTmpdirServer(
530
- Effect.fnUntraced(function* ({ llm }) {
531
- const runtime = yield* WorkflowRuntime.Service
532
- const session = yield* Session.Service
533
- const parent = yield* session.create({ title: "wf list", permission: [{ permission: "*", pattern: "*", action: "allow" }] })
534
- yield* llm.text("done"); yield* llm.text("done")
535
- const mk = () => [`export const meta = { name: "t", description: "d" }`, `return await agent("x")`].join("\n")
536
- const r1 = yield* runtime.start({ script: mk(), sessionID: parent.id, parentActorID: "main", model: ref })
537
- yield* runtime.wait({ runID: r1.runID })
538
- const r2 = yield* runtime.start({ script: mk(), sessionID: parent.id, parentActorID: "main", model: ref })
539
- yield* runtime.wait({ runID: r2.runID })
540
- const rows = yield* runtime.list({ sessionID: parent.id })
541
- expect(rows.length).toBe(2)
542
- expect(rows[0].runID).toBe(r2.runID) // newest first
543
- }),
544
- { git: true, config: providerCfg },
545
- ),
546
- )
547
-
548
- it.live("resume re-launches the persisted script under the same runID (cached replay, zero new spawns)", () =>
549
- provideTmpdirServer(
550
- Effect.fnUntraced(function* ({ llm }) {
551
- const runtime = yield* WorkflowRuntime.Service
552
- const session = yield* Session.Service
553
- const parent = yield* session.create({ title: "wf resume", permission: [{ permission: "*", pattern: "*", action: "allow" }] })
554
- yield* llm.text("done")
555
- const script = [`export const meta = { name: "t", description: "d" }`, `return await agent("x")`].join("\n")
556
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
557
- const out1 = yield* runtime.wait({ runID })
558
- expect(out1.status).toBe("completed")
559
- // Resume: agent("x") is journaled, so it replays from cache. No reply is
560
- // queued — and even if a stray spawn happened the test server would
561
- // auto-"ok", so agentCount (not queue state) is the assertion that matters.
562
- const resumed = yield* runtime.resume({ runID })
563
- expect(resumed.runID).toBe(runID) // SAME runID
564
- expect(resumed.resumed).toBe(true)
565
- const out = yield* runtime.wait({ runID })
566
- expect(out.status).toBe("completed")
567
- expect((out as { result: unknown }).result).toBe("done") // replayed cached value
568
- const st = yield* runtime.status({ runID })
569
- expect(st.agentCount).toBe(0) // resume spawned nothing — pure replay
570
- }),
571
- { git: true, config: providerCfg },
572
- ),
573
- )
574
-
575
- it.live("resume refuses a still-running run", () =>
576
- provideTmpdirServer(
577
- Effect.fnUntraced(function* ({ llm }) {
578
- const runtime = yield* WorkflowRuntime.Service
579
- const session = yield* Session.Service
580
- const parent = yield* session.create({ title: "wf resume live", permission: [{ permission: "*", pattern: "*", action: "allow" }] })
581
- yield* llm.hang
582
- const script = [`export const meta = { name: "t", description: "d" }`, `return await agent("x")`].join("\n")
583
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
584
- yield* Effect.sleep("200 millis") // let it be running
585
- const r = yield* runtime.resume({ runID })
586
- expect(r.resumed).toBe(false)
587
- yield* runtime.cancel({ runID })
588
- }),
589
- { git: true, config: providerCfg },
590
- ),
591
- )
592
-
593
- // MR104 P2-1 — in-process double-resume race. The bug: resume()'s live-guard
594
- // (runs.get(runID).status === "running") is a check-then-act, not atomic. Two
595
- // concurrent resume(sameRunID) of a COMPLETED run BOTH read status "completed",
596
- // BOTH pass the guard, BOTH launch() — and launch does runs.set(runID, entry),
597
- // so the second clobbers the first (orphaned fiber, raced counter flush) and
598
- // both fibers append to the SAME .jsonl journal (interleaved).
599
- //
600
- // The fix serializes the resume critical section (live-guard THROUGH launch's
601
- // runs.set) with an in-process Lock.write keyed on the runID. The first waiter
602
- // launches and flips the entry to "running" before releasing; the second waiter
603
- // then sees status "running" at the guard and bails with resumed:false.
604
- //
605
- // DISCRIMINATING ASSERTION: with the lock, EXACTLY ONE of the two concurrent
606
- // resumes returns resumed:true (the other resumed:false). Unlocked, BOTH pass
607
- // the guard and BOTH re-launch → resumed:true twice. This is the direct, clean
608
- // signal that the launch ran once, not twice, and it is DETERMINISTIC: Effect.all
609
- // forks both resumes; both reach resume's first yield before either reaches
610
- // launch, so unlocked they both observe status "completed" and both relaunch.
611
- // (Verified empirically: against the unlocked code this assertion fails with
612
- // Received: 2, fast and repeatably — not flaky.)
613
- it.live("two concurrent resumes of the same completed run launch exactly once (no double-launch)", () =>
614
- provideTmpdirServer(
615
- Effect.fnUntraced(function* ({ llm }) {
616
- const runtime = yield* WorkflowRuntime.Service
617
- const session = yield* Session.Service
618
- const parent = yield* session.create({
619
- title: "wf resume race",
620
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
621
- })
622
- // First run: one real spawn for agent("x"). It is journaled, so every resume
623
- // replays from cache (zero new spawns).
624
- yield* llm.text("done")
625
- const script = [`export const meta = { name: "t", description: "d" }`, `return await agent("x")`].join("\n")
626
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
627
- const first = yield* runtime.wait({ runID })
628
- expect(first.status).toBe("completed")
629
-
630
- // Fire two resume(sameRunID) concurrently. Without the lock both pass the
631
- // live-guard (status is "completed") and both re-launch. With the lock the
632
- // second serializes behind the first and sees status "running" → resumed:false.
633
- const results = yield* Effect.all([runtime.resume({ runID }), runtime.resume({ runID })], {
634
- concurrency: "unbounded",
635
- })
636
-
637
- // PRIMARY (and discriminating): exactly one re-launch happened — locked: 1
638
- // true + 1 false; unlocked: 2 true (double-launch).
639
- expect(results.filter((r) => r.resumed).length).toBe(1)
640
- expect(results.filter((r) => !r.resumed).length).toBe(1)
641
-
642
- // The single relaunched pass replays cleanly to completion.
643
- const out = yield* runtime.wait({ runID })
644
- expect(out.status).toBe("completed")
645
- expect((out as { result: unknown }).result).toBe("done") // replayed cached value
646
-
647
- // SANITY: the surviving entry is a pure cache replay (no spawn) — a double-
648
- // launch that re-spawned would show agentCount > 0.
649
- const st = yield* runtime.status({ runID })
650
- expect(st.agentCount).toBe(0)
651
-
652
- // Settle the relaunched fiber's terminal tail (bus.publish + inbox.send run
653
- // AFTER Deferred.succeed, so wait() returns before the fiber is fully done)
654
- // before the tmpdir fixture's Instance.disposeAll() tears the layer scope
655
- // down. Without this drain, disposeAll can interrupt the fiber mid-tail and
656
- // hang teardown — a PRE-EXISTING resume teardown flake (the upstream single-
657
- // resume test exhibits it in isolation too), independent of the P2-1 lock.
658
- yield* Effect.sleep("300 millis")
659
- }),
660
- { git: true, config: providerCfg },
661
- ),
662
- 15000,
663
- )
664
- })
665
-
666
- describe("WorkflowRuntime agent() label + phase opts", () => {
667
- // label + phase are pure observability metadata. They land in the spawn
668
- // `description` ONLY (no schema / currentPhase / counter change). The actor
669
- // registry stores `description` (notNull, falls back to agentType otherwise),
670
- // so the most direct observable is the child actor's registry row after the
671
- // run: an agent() with {label,phase} must carry "[Implement] impl:foo".
672
- it.live("label + phase thread into the spawned agent description", () =>
673
- provideTmpdirServer(
674
- Effect.fnUntraced(function* ({ llm }) {
675
- const runtime = yield* WorkflowRuntime.Service
676
- const session = yield* Session.Service
677
- const registry = yield* ActorRegistry.Service
678
- const parent = yield* session.create({
679
- title: "wf label",
680
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
681
- })
682
- yield* llm.text("done")
683
- const script = [
684
- `export const meta = { name: "t", description: "d" }`,
685
- `return await agent("port it", { label: "impl:foo", phase: "Implement" })`,
686
- ].join("\n")
687
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
688
- yield* runtime.wait({ runID })
689
- // The spawned subagent's registry row carries the [phase] label description.
690
- // agent() defaults agentType to "general" and shares the parent session, so
691
- // the child is the lone non-"main" actor in that session.
692
- const actors = yield* registry.listBySession(parent.id)
693
- const child = actors.find((a) => a.actorID !== "main")
694
- expect(child?.description).toBe("[Implement] impl:foo")
695
- }),
696
- { git: true, config: providerCfg },
697
- ),
698
- )
699
- })
700
-
701
- describe("WorkflowRuntime replay journal", () => {
702
- it.live("re-running the SAME runID replays cached results with zero new spawns", () =>
703
- provideTmpdirServer(
704
- Effect.fnUntraced(function* ({ llm }) {
705
- const runtime = yield* WorkflowRuntime.Service
706
- const session = yield* Session.Service
707
- const parent = yield* session.create({
708
- title: "wf replay",
709
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
710
- })
711
- const script = [
712
- `export const meta = { name: "t", description: "d" }`,
713
- `const r = await parallel([() => agent("a"), () => agent("b"), () => agent("c")])`,
714
- `return r`,
715
- ].join("\n")
716
- // First run: 3 real spawns.
717
- yield* llm.text("done")
718
- yield* llm.text("done")
719
- yield* llm.text("done")
720
- const first = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
721
- const out1 = yield* runtime.wait({ runID: first.runID })
722
- expect(out1.status).toBe("completed")
723
- const st1 = yield* runtime.status({ runID: first.runID })
724
- expect(st1.agentCount).toBe(3)
725
-
726
- // Resume the SAME runID. The journal must replay all 3 — assert via
727
- // agentCount (the spawn counter), NOT via queue starvation (the test
728
- // server auto-"ok"s an unqueued request, so a stray spawn would silently
729
- // succeed). We queue nothing to keep intent clear.
730
- const r = yield* runtime.resume({ runID: first.runID })
731
- expect(r.resumed).toBe(true)
732
- const out2 = yield* runtime.wait({ runID: first.runID })
733
- expect(out2.status).toBe("completed")
734
- expect((out2 as { result: string[] }).result.filter((x) => x === "done").length).toBe(3)
735
- const st2 = yield* runtime.status({ runID: first.runID })
736
- expect(st2.agentCount).toBe(0) // ZERO new spawns on the resumed pass
737
- }),
738
- { git: true, config: providerCfg },
739
- ),
740
- )
741
-
742
- it.live("resume re-spawns ONLY the uncached unit (O(remaining), not O(all))", () =>
743
- provideTmpdirServer(
744
- Effect.fnUntraced(function* ({ llm }) {
745
- const runtime = yield* WorkflowRuntime.Service
746
- const session = yield* Session.Service
747
- const parent = yield* session.create({
748
- title: "wf partial",
749
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
750
- })
751
- const script = [
752
- `export const meta = { name: "t", description: "d" }`,
753
- `const r = await parallel([() => agent("u0"), () => agent("u1"), () => agent("u2")])`,
754
- `return r`,
755
- ].join("\n")
756
- yield* llm.text("done")
757
- yield* llm.text("done")
758
- yield* llm.text("done")
759
- const first = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
760
- yield* runtime.wait({ runID: first.runID })
761
-
762
- // Simulate a partial: drop ONE agent line from the journal so one unit is
763
- // "unfinished". Distinct prompts => distinct hashes => occ 0 each, so we
764
- // drop by line content (the last agent line).
765
- const fs = yield* Effect.promise(() => import("fs/promises"))
766
- const { Global } = yield* Effect.promise(() => import("../../src/global"))
767
- const p = `${Global.Path.data}/workflow/${first.runID}.jsonl`
768
- const lines = (yield* Effect.promise(() => Bun.file(p).text())).split("\n").filter(Boolean)
769
- const agentLines = lines.filter((l) => l.includes('"t":"agent"'))
770
- const dropKey = JSON.parse(agentLines[agentLines.length - 1]).key
771
- const kept = lines.filter((l) => !l.includes(`"${dropKey}"`))
772
- yield* Effect.promise(() => fs.writeFile(p, kept.join("\n") + "\n"))
773
-
774
- // Resume: queue exactly ONE response (for the one dropped unit). The other
775
- // two replay from cache. agentCount===1 is the proof.
776
- yield* llm.text("done")
777
- yield* runtime.resume({ runID: first.runID })
778
- const out = yield* runtime.wait({ runID: first.runID })
779
- expect(out.status).toBe("completed")
780
- expect((out as { result: string[] }).result.filter((x) => x === "done").length).toBe(3)
781
- const st = yield* runtime.status({ runID: first.runID })
782
- expect(st.agentCount).toBe(1) // exactly the one uncached unit re-spawned
783
- }),
784
- { git: true, config: providerCfg },
785
- ),
786
- )
787
-
788
- // MR104 P1-2 — script-change invalidation. The journal keys results by
789
- // {prompt,agentType,model,schema,phase}+occ but NOT by the script body. If the
790
- // user edits the workflow script between resume cycles, replaying the OLD journal
791
- // onto NEW code is silent divergence. Fix: recordStart stamps sha256(script body)
792
- // on the run row; resume compares the stored sha to the current script's sha. On
793
- // MISMATCH the stale journal is cleared and the run re-spawns fresh (re-stamping
794
- // the new sha so a SUBSEQUENT resume of the now-current script replays correctly).
795
- //
796
- // DISCRIMINATOR vs the same-script resume test above: same body → sha matches →
797
- // replay → agentCount 0. Changed body → sha differs → fresh → agentCount > 0, and
798
- // the old journal lines are gone (cleared, not interleaved with the new pass).
799
- it.live("resume with an EDITED script discards the stale journal and re-spawns fresh", () =>
800
- provideTmpdirServer(
801
- Effect.fnUntraced(function* ({ llm }) {
802
- const runtime = yield* WorkflowRuntime.Service
803
- const session = yield* Session.Service
804
- const parent = yield* session.create({
805
- title: "wf script change",
806
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
807
- })
808
- const scriptA = [
809
- `export const meta = { name: "t", description: "d" }`,
810
- `const r = await parallel([() => agent("a"), () => agent("b")])`,
811
- `return r`,
812
- ].join("\n")
813
- // First run under script A: 2 real spawns, both journaled.
814
- yield* llm.text("done")
815
- yield* llm.text("done")
816
- const first = yield* runtime.start({ script: scriptA, sessionID: parent.id, parentActorID: "main", model: ref })
817
- const out1 = yield* runtime.wait({ runID: first.runID })
818
- expect(out1.status).toBe("completed")
819
- const st1 = yield* runtime.status({ runID: first.runID })
820
- expect(st1.agentCount).toBe(2)
821
-
822
- // Edit the persisted script: overwrite <runID>.js with a DIFFERENT body
823
- // (resume reads its script from this file). Same prompts but a changed body
824
- // → a different sha → the stored journal must be discarded.
825
- const scriptB = [
826
- `export const meta = { name: "t", description: "d" }`,
827
- `// edited between resume cycles — a different body changes the sha`,
828
- `const r = await parallel([() => agent("a"), () => agent("b")])`,
829
- `return r`,
830
- ].join("\n")
831
- yield* WorkflowPersistence.writeScript(first.runID, scriptB)
832
-
833
- // Resume: the sha mismatch must force a fresh run. Queue 2 fresh replies; if
834
- // the journal were (wrongly) replayed these would go unused and agentCount
835
- // would be 0. agentCount === 2 is the proof of a fresh re-spawn.
836
- yield* llm.text("done")
837
- yield* llm.text("done")
838
- const r = yield* runtime.resume({ runID: first.runID })
839
- expect(r.resumed).toBe(true)
840
- const out2 = yield* runtime.wait({ runID: first.runID })
841
- expect(out2.status).toBe("completed")
842
- expect((out2 as { result: string[] }).result.filter((x) => x === "done").length).toBe(2)
843
- const st2 = yield* runtime.status({ runID: first.runID })
844
- expect(st2.agentCount).toBe(2) // fresh re-spawn, NOT a 0-spawn replay
845
-
846
- // The new sha was re-stamped: a SECOND resume of the now-current script B
847
- // replays from the freshly-written journal (zero new spawns).
848
- const r2 = yield* runtime.resume({ runID: first.runID })
849
- expect(r2.resumed).toBe(true)
850
- const out3 = yield* runtime.wait({ runID: first.runID })
851
- expect(out3.status).toBe("completed")
852
- const st3 = yield* runtime.status({ runID: first.runID })
853
- expect(st3.agentCount).toBe(0) // sha now matches → pure replay
854
- }),
855
- { git: true, config: providerCfg },
856
- ),
857
- 20000,
858
- )
859
- })
860
-
861
- // agent() collapses every failure path to bare null, but operators need to know
862
- // the REASON to triage (mimo TTFT timeout vs spawn-reject vs over-cap). The
863
- // WorkflowAgentFailed bus event carries the reason without changing agent()'s
864
- // null contract — these tests pin both invariants: the script still sees null,
865
- // AND the bus carries one event per failed agent with the right reason.
866
- describe("WorkflowRuntime agent failure event (Gap 3)", () => {
867
- it.live("a 400 client error → reason='no-deliverable'; success sibling → no event", () =>
868
- // The actor outcome is status:"success" (agent finished its turn cleanly),
869
- // but the failed-LLM call produced no assistant text → no finalText/structured
870
- // to extract → deliverable is null → reason="no-deliverable". This matches the
871
- // existing "a failing child yields null" test's mechanism (line 79).
872
- provideTmpdirServer(
873
- Effect.fnUntraced(function* ({ llm }) {
874
- const runtime = yield* WorkflowRuntime.Service
875
- const session = yield* Session.Service
876
- const bus = yield* Bus.Service
877
- const events: Array<{ reason: string; label?: string; phase?: string }> = []
878
- yield* bus.subscribeCallback(WorkflowAgentFailed, (e) => {
879
- events.push({ reason: e.properties.reason, label: e.properties.label, phase: e.properties.phase })
880
- })
881
- const parent = yield* session.create({
882
- title: "wf failreason",
883
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
884
- })
885
- yield* llm.error(400, { error: { message: "bad request" } })
886
- yield* llm.text("ok")
887
- const script = [
888
- `export const meta = { name: "t", description: "d" }`,
889
- `await parallel([`,
890
- ` () => agent("a", { label: "fail-one", phase: "Test" }),`,
891
- ` () => agent("b", { label: "ok-one" })`,
892
- `])`,
893
- ].join("\n")
894
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
895
- const outcome = yield* runtime.wait({ runID })
896
- expect(outcome.status).toBe("completed")
897
- // Bus is async; let the publish settle before asserting.
898
- yield* Effect.sleep("100 millis")
899
- expect(events.length).toBe(1)
900
- expect(events[0].reason).toBe("no-deliverable")
901
- expect(events[0].label).toBe("fail-one")
902
- expect(events[0].phase).toBe("Test")
903
- }),
904
- { git: true, config: providerCfg },
905
- ),
906
- )
907
-
908
- it.live("a hung agent under timeoutMs → reason='timeout'", () =>
909
- provideTmpdirServer(
910
- Effect.fnUntraced(function* ({ llm }) {
911
- const runtime = yield* WorkflowRuntime.Service
912
- const session = yield* Session.Service
913
- const bus = yield* Bus.Service
914
- const events: string[] = []
915
- yield* bus.subscribeCallback(WorkflowAgentFailed, (e) => {
916
- events.push(e.properties.reason)
917
- })
918
- const parent = yield* session.create({
919
- title: "wf timeout",
920
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
921
- })
922
- yield* llm.hang
923
- const script = [
924
- `export const meta = { name: "t", description: "d" }`,
925
- `return await agent("hangs", { timeoutMs: 50 })`,
926
- ].join("\n")
927
- const { runID } = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
928
- const outcome = yield* runtime.wait({ runID })
929
- expect(outcome.status).toBe("completed")
930
- // The script returned the null deliverable directly: it must be null
931
- // (sandbox marshals host null → guest undefined; equate the two).
932
- const v = (outcome as { result: unknown }).result
933
- expect(v === null || v === undefined).toBe(true)
934
- yield* Effect.sleep("100 millis")
935
- expect(events.length).toBe(1)
936
- expect(events[0]).toBe("timeout")
937
- }),
938
- { git: true, config: providerCfg },
939
- ),
940
- )
941
-
942
- it.live("over-cap rejections emit reason='over-cap' and don't increment agentCount", () =>
943
- provideTmpdirServer(
944
- Effect.fnUntraced(function* ({ llm }) {
945
- const runtime = yield* WorkflowRuntime.Service
946
- const session = yield* Session.Service
947
- const bus = yield* Bus.Service
948
- const events: string[] = []
949
- yield* bus.subscribeCallback(WorkflowAgentFailed, (e) => {
950
- events.push(e.properties.reason)
951
- })
952
- const parent = yield* session.create({
953
- title: "wf overcap",
954
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
955
- })
956
- // 4 agents try to spawn, cap is 2 → 2 succeed, 2 hit over-cap → null.
957
- for (let i = 0; i < 2; i++) yield* llm.text("done")
958
- const script = [
959
- `export const meta = { name: "t", description: "d" }`,
960
- `const ts = []`,
961
- `for (let i = 0; i < 4; i++) ts.push(() => agent("x" + i))`,
962
- `return await parallel(ts)`,
963
- ].join("\n")
964
- const { runID } = yield* runtime.start({
965
- script,
966
- sessionID: parent.id,
967
- parentActorID: "main",
968
- model: ref,
969
- maxLifecycleAgents: 2,
970
- })
971
- const outcome = yield* runtime.wait({ runID })
972
- expect(outcome.status).toBe("completed")
973
- yield* Effect.sleep("100 millis")
974
- // Exactly 2 over-cap events (the cap-exceeding spawn attempts); zero
975
- // other-reason events since the 2 in-cap agents both succeeded.
976
- const overCap = events.filter((r) => r === "over-cap")
977
- expect(overCap.length).toBe(2)
978
- expect(events.length).toBe(2) // no other reasons leaked in
979
- }),
980
- { git: true, config: providerCfg },
981
- ),
982
- )
983
- })
984
-
985
- // Math.random is seeded per-run from a hash of runID, so two unrelated runs of
986
- // the same script get DIFFERENT sequences (sampling-style scripts get fresh
987
- // coverage); a resume of the same run gets the SAME sequence (replay invariant
988
- // covered by other tests). This pins the cross-run divergence.
989
- describe("WorkflowRuntime PRNG seeding (cross-run divergence)", () => {
990
- it.live("two unrelated runs of the same Math.random script get different sequences", () =>
991
- provideTmpdirServer(
992
- Effect.fnUntraced(function* () {
993
- const runtime = yield* WorkflowRuntime.Service
994
- const session = yield* Session.Service
995
- const parent = yield* session.create({
996
- title: "wf prng",
997
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
998
- })
999
- const script = [
1000
- `export const meta = { name: "t", description: "d" }`,
1001
- `return [Math.random(), Math.random(), Math.random()]`,
1002
- ].join("\n")
1003
- const a = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
1004
- const ao = yield* runtime.wait({ runID: a.runID })
1005
- const b = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
1006
- const bo = yield* runtime.wait({ runID: b.runID })
1007
- expect(ao.status).toBe("completed")
1008
- expect(bo.status).toBe("completed")
1009
- const av = (ao as { result: number[] }).result
1010
- const bv = (bo as { result: number[] }).result
1011
- expect(av).not.toEqual(bv) // different runIDs → different seeds → different sequences
1012
- expect(av[0]).toBeGreaterThanOrEqual(0)
1013
- expect(av[0]).toBeLessThan(1)
1014
- }),
1015
- { git: true, config: providerCfg },
1016
- ),
1017
- )
1018
- })
1019
-
1020
- // agent_timeout_ms is persisted on the workflow_run row at start time so a
1021
- // resume that doesn't supply its own override (e.g. the TUI's /workflows resume
1022
- // command, which currently passes only runID) inherits the original timeout
1023
- // instead of silently dropping to unbounded — which used to let a wedged mimo
1024
- // TTFT stall the resumed run forever. This test pins the "implicit-resume
1025
- // inherits the persisted timeout" contract end-to-end via the persistence layer.
1026
- describe("WorkflowRuntime persists agentTimeoutMs across resume (TUI-style)", () => {
1027
- it.live("a row started with agentTimeoutMs is readable via persistence.load", () =>
1028
- provideTmpdirServer(
1029
- Effect.fnUntraced(function* () {
1030
- const runtime = yield* WorkflowRuntime.Service
1031
- const session = yield* Session.Service
1032
- const parent = yield* session.create({
1033
- title: "wf timeout-persist",
1034
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
1035
- })
1036
- const script = `export const meta = { name: "t", description: "d" }`
1037
- const r = yield* runtime.start({
1038
- script,
1039
- sessionID: parent.id,
1040
- parentActorID: "main",
1041
- model: ref,
1042
- agentTimeoutMs: 12345,
1043
- })
1044
- yield* runtime.wait({ runID: r.runID })
1045
- // Row is persisted with the timeout; a no-arg resume() would read this back
1046
- // (resume uses input.agentTimeoutMs ?? row.agentTimeoutMs as the effective
1047
- // value passed to launch()). Fresh-start with a value smaller than the
1048
- // smallest sleep would be a clean integration test, but it requires real
1049
- // mock timing; the persistence path is the load-bearing check so we pin
1050
- // that directly to keep the test cheap and deterministic.
1051
- const row = yield* WorkflowPersistence.load(r.runID)
1052
- expect(row).toBeDefined()
1053
- expect(row!.agentTimeoutMs).toBe(12345)
1054
- }),
1055
- { git: true, config: providerCfg },
1056
- ),
1057
- )
1058
-
1059
- it.live("a row started with NO timeout reads back undefined (no silent default)", () =>
1060
- provideTmpdirServer(
1061
- Effect.fnUntraced(function* () {
1062
- const runtime = yield* WorkflowRuntime.Service
1063
- const session = yield* Session.Service
1064
- const parent = yield* session.create({
1065
- title: "wf timeout-undef",
1066
- permission: [{ permission: "*", pattern: "*", action: "allow" }],
1067
- })
1068
- const script = `export const meta = { name: "t", description: "d" }`
1069
- const r = yield* runtime.start({ script, sessionID: parent.id, parentActorID: "main", model: ref })
1070
- yield* runtime.wait({ runID: r.runID })
1071
- const row = yield* WorkflowPersistence.load(r.runID)
1072
- expect(row).toBeDefined()
1073
- expect(row!.agentTimeoutMs).toBeUndefined()
1074
- }),
1075
- { git: true, config: providerCfg },
1076
- ),
1077
- )
1078
- })