@opendash-ai/cli 0.1.0-beta.1 → 0.1.0-beta.3

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