jonsoc 1.1.49 → 1.1.50

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 (421) hide show
  1. package/bin/jonsoc +264 -256
  2. package/package.json +8 -142
  3. package/postinstall.mjs +15 -0
  4. package/AGENTS.md +0 -27
  5. package/Dockerfile +0 -18
  6. package/PUBLISHING_GUIDE.md +0 -151
  7. package/README.md +0 -58
  8. package/bunfig.toml +0 -7
  9. package/package.json.placeholder +0 -11
  10. package/parsers-config.ts +0 -253
  11. package/script/build.ts +0 -115
  12. package/script/publish-registries.ts +0 -197
  13. package/script/publish.ts +0 -110
  14. package/script/schema.ts +0 -47
  15. package/script/seed-e2e.ts +0 -50
  16. package/src/acp/README.md +0 -164
  17. package/src/acp/agent.ts +0 -1437
  18. package/src/acp/session.ts +0 -105
  19. package/src/acp/types.ts +0 -22
  20. package/src/agent/agent.ts +0 -347
  21. package/src/agent/generate.txt +0 -75
  22. package/src/agent/prompt/compaction.txt +0 -12
  23. package/src/agent/prompt/explore.txt +0 -18
  24. package/src/agent/prompt/summary.txt +0 -11
  25. package/src/agent/prompt/title.txt +0 -44
  26. package/src/auth/index.ts +0 -73
  27. package/src/brand/index.ts +0 -89
  28. package/src/bun/index.ts +0 -139
  29. package/src/bus/bus-event.ts +0 -43
  30. package/src/bus/global.ts +0 -10
  31. package/src/bus/index.ts +0 -105
  32. package/src/cli/bootstrap.ts +0 -17
  33. package/src/cli/cmd/acp.ts +0 -69
  34. package/src/cli/cmd/agent.ts +0 -257
  35. package/src/cli/cmd/auth.ts +0 -405
  36. package/src/cli/cmd/cmd.ts +0 -7
  37. package/src/cli/cmd/debug/agent.ts +0 -166
  38. package/src/cli/cmd/debug/config.ts +0 -16
  39. package/src/cli/cmd/debug/file.ts +0 -97
  40. package/src/cli/cmd/debug/index.ts +0 -48
  41. package/src/cli/cmd/debug/lsp.ts +0 -52
  42. package/src/cli/cmd/debug/ripgrep.ts +0 -87
  43. package/src/cli/cmd/debug/scrap.ts +0 -16
  44. package/src/cli/cmd/debug/skill.ts +0 -16
  45. package/src/cli/cmd/debug/snapshot.ts +0 -52
  46. package/src/cli/cmd/export.ts +0 -88
  47. package/src/cli/cmd/generate.ts +0 -38
  48. package/src/cli/cmd/github.ts +0 -1548
  49. package/src/cli/cmd/import.ts +0 -99
  50. package/src/cli/cmd/mcp.ts +0 -765
  51. package/src/cli/cmd/models.ts +0 -77
  52. package/src/cli/cmd/pr.ts +0 -112
  53. package/src/cli/cmd/run.ts +0 -395
  54. package/src/cli/cmd/serve.ts +0 -20
  55. package/src/cli/cmd/session.ts +0 -135
  56. package/src/cli/cmd/stats.ts +0 -402
  57. package/src/cli/cmd/tui/app.tsx +0 -923
  58. package/src/cli/cmd/tui/attach.ts +0 -39
  59. package/src/cli/cmd/tui/component/border.tsx +0 -21
  60. package/src/cli/cmd/tui/component/dialog-agent.tsx +0 -31
  61. package/src/cli/cmd/tui/component/dialog-command.tsx +0 -162
  62. package/src/cli/cmd/tui/component/dialog-error-log.tsx +0 -155
  63. package/src/cli/cmd/tui/component/dialog-mcp.tsx +0 -86
  64. package/src/cli/cmd/tui/component/dialog-model.tsx +0 -234
  65. package/src/cli/cmd/tui/component/dialog-provider.tsx +0 -256
  66. package/src/cli/cmd/tui/component/dialog-session-list.tsx +0 -114
  67. package/src/cli/cmd/tui/component/dialog-session-rename.tsx +0 -31
  68. package/src/cli/cmd/tui/component/dialog-stash.tsx +0 -87
  69. package/src/cli/cmd/tui/component/dialog-status.tsx +0 -164
  70. package/src/cli/cmd/tui/component/dialog-tag.tsx +0 -44
  71. package/src/cli/cmd/tui/component/dialog-theme-list.tsx +0 -50
  72. package/src/cli/cmd/tui/component/dynamic-layout.tsx +0 -86
  73. package/src/cli/cmd/tui/component/inspector-overlay.tsx +0 -247
  74. package/src/cli/cmd/tui/component/logo.tsx +0 -88
  75. package/src/cli/cmd/tui/component/prompt/autocomplete.tsx +0 -653
  76. package/src/cli/cmd/tui/component/prompt/frecency.tsx +0 -89
  77. package/src/cli/cmd/tui/component/prompt/history.tsx +0 -108
  78. package/src/cli/cmd/tui/component/prompt/index.tsx +0 -1347
  79. package/src/cli/cmd/tui/component/prompt/stash.tsx +0 -101
  80. package/src/cli/cmd/tui/component/textarea-keybindings.ts +0 -73
  81. package/src/cli/cmd/tui/component/tips.tsx +0 -153
  82. package/src/cli/cmd/tui/component/todo-item.tsx +0 -32
  83. package/src/cli/cmd/tui/context/args.tsx +0 -14
  84. package/src/cli/cmd/tui/context/directory.ts +0 -13
  85. package/src/cli/cmd/tui/context/error-log.tsx +0 -56
  86. package/src/cli/cmd/tui/context/exit.tsx +0 -26
  87. package/src/cli/cmd/tui/context/helper.tsx +0 -25
  88. package/src/cli/cmd/tui/context/inspector.tsx +0 -57
  89. package/src/cli/cmd/tui/context/keybind.tsx +0 -108
  90. package/src/cli/cmd/tui/context/kv.tsx +0 -53
  91. package/src/cli/cmd/tui/context/layout.tsx +0 -240
  92. package/src/cli/cmd/tui/context/local.tsx +0 -402
  93. package/src/cli/cmd/tui/context/prompt.tsx +0 -18
  94. package/src/cli/cmd/tui/context/route.tsx +0 -51
  95. package/src/cli/cmd/tui/context/sdk.tsx +0 -94
  96. package/src/cli/cmd/tui/context/sync.tsx +0 -449
  97. package/src/cli/cmd/tui/context/theme/aura.json +0 -69
  98. package/src/cli/cmd/tui/context/theme/ayu.json +0 -80
  99. package/src/cli/cmd/tui/context/theme/carbonfox.json +0 -248
  100. package/src/cli/cmd/tui/context/theme/catppuccin-frappe.json +0 -233
  101. package/src/cli/cmd/tui/context/theme/catppuccin-macchiato.json +0 -233
  102. package/src/cli/cmd/tui/context/theme/catppuccin.json +0 -112
  103. package/src/cli/cmd/tui/context/theme/cobalt2.json +0 -228
  104. package/src/cli/cmd/tui/context/theme/cursor.json +0 -249
  105. package/src/cli/cmd/tui/context/theme/dracula.json +0 -219
  106. package/src/cli/cmd/tui/context/theme/everforest.json +0 -241
  107. package/src/cli/cmd/tui/context/theme/flexoki.json +0 -237
  108. package/src/cli/cmd/tui/context/theme/github.json +0 -233
  109. package/src/cli/cmd/tui/context/theme/gruvbox.json +0 -242
  110. package/src/cli/cmd/tui/context/theme/jonsoc.json +0 -245
  111. package/src/cli/cmd/tui/context/theme/kanagawa.json +0 -77
  112. package/src/cli/cmd/tui/context/theme/lucent-orng.json +0 -237
  113. package/src/cli/cmd/tui/context/theme/material.json +0 -235
  114. package/src/cli/cmd/tui/context/theme/matrix.json +0 -77
  115. package/src/cli/cmd/tui/context/theme/mercury.json +0 -252
  116. package/src/cli/cmd/tui/context/theme/monokai.json +0 -221
  117. package/src/cli/cmd/tui/context/theme/nightowl.json +0 -221
  118. package/src/cli/cmd/tui/context/theme/nord.json +0 -223
  119. package/src/cli/cmd/tui/context/theme/one-dark.json +0 -84
  120. package/src/cli/cmd/tui/context/theme/orng.json +0 -249
  121. package/src/cli/cmd/tui/context/theme/osaka-jade.json +0 -93
  122. package/src/cli/cmd/tui/context/theme/palenight.json +0 -222
  123. package/src/cli/cmd/tui/context/theme/rosepine.json +0 -234
  124. package/src/cli/cmd/tui/context/theme/solarized.json +0 -223
  125. package/src/cli/cmd/tui/context/theme/synthwave84.json +0 -226
  126. package/src/cli/cmd/tui/context/theme/tokyonight.json +0 -243
  127. package/src/cli/cmd/tui/context/theme/vercel.json +0 -245
  128. package/src/cli/cmd/tui/context/theme/vesper.json +0 -218
  129. package/src/cli/cmd/tui/context/theme/zenburn.json +0 -223
  130. package/src/cli/cmd/tui/context/theme.tsx +0 -1153
  131. package/src/cli/cmd/tui/event.ts +0 -48
  132. package/src/cli/cmd/tui/hooks/use-command-registry.tsx +0 -184
  133. package/src/cli/cmd/tui/routes/home.tsx +0 -198
  134. package/src/cli/cmd/tui/routes/session/dialog-fork-from-timeline.tsx +0 -64
  135. package/src/cli/cmd/tui/routes/session/dialog-message.tsx +0 -109
  136. package/src/cli/cmd/tui/routes/session/dialog-subagent.tsx +0 -26
  137. package/src/cli/cmd/tui/routes/session/dialog-timeline.tsx +0 -47
  138. package/src/cli/cmd/tui/routes/session/footer.tsx +0 -91
  139. package/src/cli/cmd/tui/routes/session/git-commit.tsx +0 -59
  140. package/src/cli/cmd/tui/routes/session/git-history.tsx +0 -122
  141. package/src/cli/cmd/tui/routes/session/header.tsx +0 -185
  142. package/src/cli/cmd/tui/routes/session/index.tsx +0 -2363
  143. package/src/cli/cmd/tui/routes/session/navigator-ui.tsx +0 -214
  144. package/src/cli/cmd/tui/routes/session/navigator.tsx +0 -1124
  145. package/src/cli/cmd/tui/routes/session/panel-explorer.tsx +0 -553
  146. package/src/cli/cmd/tui/routes/session/panel-viewer.tsx +0 -386
  147. package/src/cli/cmd/tui/routes/session/permission.tsx +0 -501
  148. package/src/cli/cmd/tui/routes/session/question.tsx +0 -507
  149. package/src/cli/cmd/tui/routes/session/sidebar.tsx +0 -365
  150. package/src/cli/cmd/tui/routes/session/vcs-diff-viewer.tsx +0 -37
  151. package/src/cli/cmd/tui/routes/ui-settings.tsx +0 -449
  152. package/src/cli/cmd/tui/thread.ts +0 -172
  153. package/src/cli/cmd/tui/ui/dialog-alert.tsx +0 -90
  154. package/src/cli/cmd/tui/ui/dialog-confirm.tsx +0 -83
  155. package/src/cli/cmd/tui/ui/dialog-export-options.tsx +0 -204
  156. package/src/cli/cmd/tui/ui/dialog-help.tsx +0 -38
  157. package/src/cli/cmd/tui/ui/dialog-prompt.tsx +0 -77
  158. package/src/cli/cmd/tui/ui/dialog-select.tsx +0 -384
  159. package/src/cli/cmd/tui/ui/dialog.tsx +0 -170
  160. package/src/cli/cmd/tui/ui/link.tsx +0 -28
  161. package/src/cli/cmd/tui/ui/spinner.ts +0 -375
  162. package/src/cli/cmd/tui/ui/toast.tsx +0 -100
  163. package/src/cli/cmd/tui/util/clipboard.ts +0 -255
  164. package/src/cli/cmd/tui/util/editor.ts +0 -32
  165. package/src/cli/cmd/tui/util/signal.ts +0 -7
  166. package/src/cli/cmd/tui/util/terminal.ts +0 -114
  167. package/src/cli/cmd/tui/util/transcript.ts +0 -98
  168. package/src/cli/cmd/tui/worker.ts +0 -152
  169. package/src/cli/cmd/uninstall.ts +0 -362
  170. package/src/cli/cmd/upgrade.ts +0 -73
  171. package/src/cli/cmd/web.ts +0 -81
  172. package/src/cli/error.ts +0 -57
  173. package/src/cli/network.ts +0 -53
  174. package/src/cli/ui.ts +0 -119
  175. package/src/cli/upgrade.ts +0 -25
  176. package/src/command/index.ts +0 -131
  177. package/src/command/template/initialize.txt +0 -10
  178. package/src/command/template/review.txt +0 -99
  179. package/src/config/config.ts +0 -1404
  180. package/src/config/markdown.ts +0 -93
  181. package/src/env/index.ts +0 -26
  182. package/src/file/ignore.ts +0 -83
  183. package/src/file/index.ts +0 -432
  184. package/src/file/ripgrep.ts +0 -407
  185. package/src/file/time.ts +0 -69
  186. package/src/file/watcher.ts +0 -127
  187. package/src/flag/flag.ts +0 -80
  188. package/src/format/formatter.ts +0 -357
  189. package/src/format/index.ts +0 -137
  190. package/src/global/index.ts +0 -58
  191. package/src/id/id.ts +0 -83
  192. package/src/ide/index.ts +0 -76
  193. package/src/index.ts +0 -208
  194. package/src/installation/index.ts +0 -258
  195. package/src/lsp/client.ts +0 -252
  196. package/src/lsp/index.ts +0 -485
  197. package/src/lsp/language.ts +0 -119
  198. package/src/lsp/server.ts +0 -2046
  199. package/src/mcp/auth.ts +0 -135
  200. package/src/mcp/index.ts +0 -934
  201. package/src/mcp/oauth-callback.ts +0 -200
  202. package/src/mcp/oauth-provider.ts +0 -155
  203. package/src/patch/index.ts +0 -680
  204. package/src/permission/arity.ts +0 -163
  205. package/src/permission/index.ts +0 -210
  206. package/src/permission/next.ts +0 -280
  207. package/src/plugin/codex.ts +0 -500
  208. package/src/plugin/copilot.ts +0 -283
  209. package/src/plugin/index.ts +0 -135
  210. package/src/project/bootstrap.ts +0 -35
  211. package/src/project/instance.ts +0 -91
  212. package/src/project/project.ts +0 -371
  213. package/src/project/state.ts +0 -66
  214. package/src/project/vcs.ts +0 -151
  215. package/src/provider/auth.ts +0 -147
  216. package/src/provider/models-macro.ts +0 -14
  217. package/src/provider/models.ts +0 -114
  218. package/src/provider/provider.ts +0 -1220
  219. package/src/provider/sdk/openai-compatible/src/README.md +0 -5
  220. package/src/provider/sdk/openai-compatible/src/index.ts +0 -2
  221. package/src/provider/sdk/openai-compatible/src/openai-compatible-provider.ts +0 -100
  222. package/src/provider/sdk/openai-compatible/src/responses/convert-to-openai-responses-input.ts +0 -303
  223. package/src/provider/sdk/openai-compatible/src/responses/map-openai-responses-finish-reason.ts +0 -22
  224. package/src/provider/sdk/openai-compatible/src/responses/openai-config.ts +0 -18
  225. package/src/provider/sdk/openai-compatible/src/responses/openai-error.ts +0 -22
  226. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-api-types.ts +0 -207
  227. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-language-model.ts +0 -1732
  228. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-prepare-tools.ts +0 -177
  229. package/src/provider/sdk/openai-compatible/src/responses/openai-responses-settings.ts +0 -1
  230. package/src/provider/sdk/openai-compatible/src/responses/tool/code-interpreter.ts +0 -88
  231. package/src/provider/sdk/openai-compatible/src/responses/tool/file-search.ts +0 -128
  232. package/src/provider/sdk/openai-compatible/src/responses/tool/image-generation.ts +0 -115
  233. package/src/provider/sdk/openai-compatible/src/responses/tool/local-shell.ts +0 -65
  234. package/src/provider/sdk/openai-compatible/src/responses/tool/web-search-preview.ts +0 -104
  235. package/src/provider/sdk/openai-compatible/src/responses/tool/web-search.ts +0 -103
  236. package/src/provider/transform.ts +0 -742
  237. package/src/pty/index.ts +0 -241
  238. package/src/question/index.ts +0 -176
  239. package/src/scheduler/index.ts +0 -61
  240. package/src/server/error.ts +0 -36
  241. package/src/server/event.ts +0 -7
  242. package/src/server/mdns.ts +0 -59
  243. package/src/server/routes/config.ts +0 -92
  244. package/src/server/routes/experimental.ts +0 -208
  245. package/src/server/routes/file.ts +0 -227
  246. package/src/server/routes/global.ts +0 -135
  247. package/src/server/routes/mcp.ts +0 -225
  248. package/src/server/routes/permission.ts +0 -68
  249. package/src/server/routes/project.ts +0 -82
  250. package/src/server/routes/provider.ts +0 -165
  251. package/src/server/routes/pty.ts +0 -169
  252. package/src/server/routes/question.ts +0 -98
  253. package/src/server/routes/session.ts +0 -939
  254. package/src/server/routes/tui.ts +0 -379
  255. package/src/server/server.ts +0 -663
  256. package/src/session/compaction.ts +0 -225
  257. package/src/session/index.ts +0 -498
  258. package/src/session/llm.ts +0 -288
  259. package/src/session/message-v2.ts +0 -740
  260. package/src/session/message.ts +0 -189
  261. package/src/session/processor.ts +0 -406
  262. package/src/session/prompt/anthropic-20250930.txt +0 -168
  263. package/src/session/prompt/anthropic.txt +0 -172
  264. package/src/session/prompt/anthropic_spoof.txt +0 -1
  265. package/src/session/prompt/beast.txt +0 -149
  266. package/src/session/prompt/build-switch.txt +0 -5
  267. package/src/session/prompt/codex_header.txt +0 -81
  268. package/src/session/prompt/copilot-gpt-5.txt +0 -145
  269. package/src/session/prompt/gemini.txt +0 -157
  270. package/src/session/prompt/max-steps.txt +0 -16
  271. package/src/session/prompt/plan-reminder-anthropic.txt +0 -67
  272. package/src/session/prompt/plan.txt +0 -26
  273. package/src/session/prompt/qwen.txt +0 -111
  274. package/src/session/prompt.ts +0 -1815
  275. package/src/session/retry.ts +0 -90
  276. package/src/session/revert.ts +0 -121
  277. package/src/session/status.ts +0 -76
  278. package/src/session/summary.ts +0 -150
  279. package/src/session/system.ts +0 -156
  280. package/src/session/todo.ts +0 -37
  281. package/src/share/share-next.ts +0 -204
  282. package/src/share/share.ts +0 -95
  283. package/src/shell/shell.ts +0 -67
  284. package/src/skill/index.ts +0 -1
  285. package/src/skill/skill.ts +0 -135
  286. package/src/snapshot/index.ts +0 -236
  287. package/src/storage/storage.ts +0 -227
  288. package/src/tool/apply_patch.ts +0 -279
  289. package/src/tool/apply_patch.txt +0 -33
  290. package/src/tool/bash.ts +0 -258
  291. package/src/tool/bash.txt +0 -115
  292. package/src/tool/batch.ts +0 -175
  293. package/src/tool/batch.txt +0 -24
  294. package/src/tool/codesearch.ts +0 -132
  295. package/src/tool/codesearch.txt +0 -12
  296. package/src/tool/edit.ts +0 -645
  297. package/src/tool/edit.txt +0 -10
  298. package/src/tool/external-directory.ts +0 -32
  299. package/src/tool/glob.ts +0 -77
  300. package/src/tool/glob.txt +0 -6
  301. package/src/tool/grep.ts +0 -154
  302. package/src/tool/grep.txt +0 -8
  303. package/src/tool/invalid.ts +0 -17
  304. package/src/tool/ls.ts +0 -121
  305. package/src/tool/ls.txt +0 -1
  306. package/src/tool/lsp.ts +0 -96
  307. package/src/tool/lsp.txt +0 -19
  308. package/src/tool/multiedit.ts +0 -46
  309. package/src/tool/multiedit.txt +0 -41
  310. package/src/tool/plan-enter.txt +0 -14
  311. package/src/tool/plan-exit.txt +0 -13
  312. package/src/tool/plan.ts +0 -130
  313. package/src/tool/question.ts +0 -33
  314. package/src/tool/question.txt +0 -10
  315. package/src/tool/read.ts +0 -202
  316. package/src/tool/read.txt +0 -12
  317. package/src/tool/registry.ts +0 -162
  318. package/src/tool/skill.ts +0 -82
  319. package/src/tool/task.ts +0 -188
  320. package/src/tool/task.txt +0 -60
  321. package/src/tool/todo.ts +0 -53
  322. package/src/tool/todoread.txt +0 -14
  323. package/src/tool/todowrite.txt +0 -167
  324. package/src/tool/tool.ts +0 -88
  325. package/src/tool/truncation.ts +0 -106
  326. package/src/tool/webfetch.ts +0 -182
  327. package/src/tool/webfetch.txt +0 -13
  328. package/src/tool/websearch.ts +0 -150
  329. package/src/tool/websearch.txt +0 -14
  330. package/src/tool/write.ts +0 -80
  331. package/src/tool/write.txt +0 -8
  332. package/src/util/archive.ts +0 -16
  333. package/src/util/color.ts +0 -19
  334. package/src/util/context.ts +0 -25
  335. package/src/util/defer.ts +0 -12
  336. package/src/util/eventloop.ts +0 -20
  337. package/src/util/filesystem.ts +0 -93
  338. package/src/util/fn.ts +0 -11
  339. package/src/util/format.ts +0 -20
  340. package/src/util/iife.ts +0 -3
  341. package/src/util/keybind.ts +0 -103
  342. package/src/util/lazy.ts +0 -18
  343. package/src/util/locale.ts +0 -81
  344. package/src/util/lock.ts +0 -98
  345. package/src/util/log.ts +0 -180
  346. package/src/util/queue.ts +0 -32
  347. package/src/util/rpc.ts +0 -66
  348. package/src/util/scrap.ts +0 -10
  349. package/src/util/signal.ts +0 -12
  350. package/src/util/timeout.ts +0 -14
  351. package/src/util/token.ts +0 -7
  352. package/src/util/wildcard.ts +0 -56
  353. package/src/worktree/index.ts +0 -524
  354. package/sst-env.d.ts +0 -9
  355. package/test/acp/agent-interface.test.ts +0 -51
  356. package/test/acp/event-subscription.test.ts +0 -436
  357. package/test/agent/agent.test.ts +0 -638
  358. package/test/bun.test.ts +0 -53
  359. package/test/cli/cmd/tui/fileref.test.ts +0 -30
  360. package/test/cli/github-action.test.ts +0 -129
  361. package/test/cli/github-remote.test.ts +0 -80
  362. package/test/cli/tui/navigator_logic.test.ts +0 -99
  363. package/test/cli/tui/transcript.test.ts +0 -297
  364. package/test/cli/ui.test.ts +0 -80
  365. package/test/config/agent-color.test.ts +0 -66
  366. package/test/config/config.test.ts +0 -1613
  367. package/test/config/fixtures/empty-frontmatter.md +0 -4
  368. package/test/config/fixtures/frontmatter.md +0 -28
  369. package/test/config/fixtures/no-frontmatter.md +0 -1
  370. package/test/config/markdown.test.ts +0 -192
  371. package/test/file/ignore.test.ts +0 -10
  372. package/test/file/path-traversal.test.ts +0 -198
  373. package/test/fixture/fixture.ts +0 -45
  374. package/test/fixture/lsp/fake-lsp-server.js +0 -77
  375. package/test/ide/ide.test.ts +0 -82
  376. package/test/keybind.test.ts +0 -421
  377. package/test/lsp/client.test.ts +0 -95
  378. package/test/mcp/headers.test.ts +0 -153
  379. package/test/mcp/oauth-browser.test.ts +0 -261
  380. package/test/patch/patch.test.ts +0 -348
  381. package/test/permission/arity.test.ts +0 -33
  382. package/test/permission/next.test.ts +0 -690
  383. package/test/permission-task.test.ts +0 -319
  384. package/test/plugin/codex.test.ts +0 -123
  385. package/test/preload.ts +0 -67
  386. package/test/project/project.test.ts +0 -120
  387. package/test/provider/amazon-bedrock.test.ts +0 -268
  388. package/test/provider/gitlab-duo.test.ts +0 -286
  389. package/test/provider/provider.test.ts +0 -2149
  390. package/test/provider/transform.test.ts +0 -1631
  391. package/test/question/question.test.ts +0 -300
  392. package/test/scheduler.test.ts +0 -73
  393. package/test/server/session-list.test.ts +0 -39
  394. package/test/server/session-select.test.ts +0 -78
  395. package/test/session/compaction.test.ts +0 -293
  396. package/test/session/llm.test.ts +0 -90
  397. package/test/session/message-v2.test.ts +0 -786
  398. package/test/session/retry.test.ts +0 -131
  399. package/test/session/revert-compact.test.ts +0 -285
  400. package/test/session/session.test.ts +0 -71
  401. package/test/skill/skill.test.ts +0 -185
  402. package/test/snapshot/snapshot.test.ts +0 -939
  403. package/test/tool/__snapshots__/tool.test.ts.snap +0 -9
  404. package/test/tool/apply_patch.test.ts +0 -499
  405. package/test/tool/bash.test.ts +0 -320
  406. package/test/tool/external-directory.test.ts +0 -126
  407. package/test/tool/fixtures/large-image.png +0 -0
  408. package/test/tool/fixtures/models-api.json +0 -33453
  409. package/test/tool/grep.test.ts +0 -109
  410. package/test/tool/question.test.ts +0 -105
  411. package/test/tool/read.test.ts +0 -332
  412. package/test/tool/registry.test.ts +0 -76
  413. package/test/tool/truncation.test.ts +0 -159
  414. package/test/util/filesystem.test.ts +0 -39
  415. package/test/util/format.test.ts +0 -59
  416. package/test/util/iife.test.ts +0 -36
  417. package/test/util/lazy.test.ts +0 -50
  418. package/test/util/lock.test.ts +0 -72
  419. package/test/util/timeout.test.ts +0 -21
  420. package/test/util/wildcard.test.ts +0 -75
  421. package/tsconfig.json +0 -16
@@ -1,638 +0,0 @@
1
- import { test, expect } from "bun:test"
2
- import { tmpdir } from "../fixture/fixture"
3
- import { Instance } from "../../src/project/instance"
4
- import { Agent } from "../../src/agent/agent"
5
- import { PermissionNext } from "../../src/permission/next"
6
-
7
- // Helper to evaluate permission for a tool with wildcard pattern
8
- function evalPerm(agent: Agent.Info | undefined, permission: string): PermissionNext.Action | undefined {
9
- if (!agent) return undefined
10
- return PermissionNext.evaluate(permission, "*", agent.permission).action
11
- }
12
-
13
- test("returns default native agents when no config", async () => {
14
- await using tmp = await tmpdir()
15
- await Instance.provide({
16
- directory: tmp.path,
17
- fn: async () => {
18
- const agents = await Agent.list()
19
- const names = agents.map((a) => a.name)
20
- expect(names).toContain("build")
21
- expect(names).toContain("plan")
22
- expect(names).toContain("general")
23
- expect(names).toContain("explore")
24
- expect(names).toContain("compaction")
25
- expect(names).toContain("title")
26
- expect(names).toContain("summary")
27
- },
28
- })
29
- })
30
-
31
- test("build agent has correct default properties", async () => {
32
- await using tmp = await tmpdir()
33
- await Instance.provide({
34
- directory: tmp.path,
35
- fn: async () => {
36
- const build = await Agent.get("build")
37
- expect(build).toBeDefined()
38
- expect(build?.mode).toBe("primary")
39
- expect(build?.native).toBe(true)
40
- expect(evalPerm(build, "edit")).toBe("allow")
41
- expect(evalPerm(build, "bash")).toBe("allow")
42
- },
43
- })
44
- })
45
-
46
- test("plan agent denies edits except .jonsoc/plans/*", async () => {
47
- await using tmp = await tmpdir()
48
- await Instance.provide({
49
- directory: tmp.path,
50
- fn: async () => {
51
- const plan = await Agent.get("plan")
52
- expect(plan).toBeDefined()
53
- // Wildcard is denied
54
- expect(evalPerm(plan, "edit")).toBe("deny")
55
- // But specific path is allowed
56
- expect(PermissionNext.evaluate("edit", ".jonsoc/plans/foo.md", plan!.permission).action).toBe("allow")
57
- },
58
- })
59
- })
60
-
61
- test("explore agent denies edit and write", async () => {
62
- await using tmp = await tmpdir()
63
- await Instance.provide({
64
- directory: tmp.path,
65
- fn: async () => {
66
- const explore = await Agent.get("explore")
67
- expect(explore).toBeDefined()
68
- expect(explore?.mode).toBe("subagent")
69
- expect(evalPerm(explore, "edit")).toBe("deny")
70
- expect(evalPerm(explore, "write")).toBe("deny")
71
- expect(evalPerm(explore, "todoread")).toBe("deny")
72
- expect(evalPerm(explore, "todowrite")).toBe("deny")
73
- },
74
- })
75
- })
76
-
77
- test("general agent denies todo tools", async () => {
78
- await using tmp = await tmpdir()
79
- await Instance.provide({
80
- directory: tmp.path,
81
- fn: async () => {
82
- const general = await Agent.get("general")
83
- expect(general).toBeDefined()
84
- expect(general?.mode).toBe("subagent")
85
- expect(general?.hidden).toBeUndefined()
86
- expect(evalPerm(general, "todoread")).toBe("deny")
87
- expect(evalPerm(general, "todowrite")).toBe("deny")
88
- },
89
- })
90
- })
91
-
92
- test("compaction agent denies all permissions", async () => {
93
- await using tmp = await tmpdir()
94
- await Instance.provide({
95
- directory: tmp.path,
96
- fn: async () => {
97
- const compaction = await Agent.get("compaction")
98
- expect(compaction).toBeDefined()
99
- expect(compaction?.hidden).toBe(true)
100
- expect(evalPerm(compaction, "bash")).toBe("deny")
101
- expect(evalPerm(compaction, "edit")).toBe("deny")
102
- expect(evalPerm(compaction, "read")).toBe("deny")
103
- },
104
- })
105
- })
106
-
107
- test("custom agent from config creates new agent", async () => {
108
- await using tmp = await tmpdir({
109
- config: {
110
- agent: {
111
- my_custom_agent: {
112
- model: "openai/gpt-4",
113
- description: "My custom agent",
114
- temperature: 0.5,
115
- top_p: 0.9,
116
- },
117
- },
118
- },
119
- })
120
- await Instance.provide({
121
- directory: tmp.path,
122
- fn: async () => {
123
- const custom = await Agent.get("my_custom_agent")
124
- expect(custom).toBeDefined()
125
- expect(custom?.model?.providerID).toBe("openai")
126
- expect(custom?.model?.modelID).toBe("gpt-4")
127
- expect(custom?.description).toBe("My custom agent")
128
- expect(custom?.temperature).toBe(0.5)
129
- expect(custom?.topP).toBe(0.9)
130
- expect(custom?.native).toBe(false)
131
- expect(custom?.mode).toBe("all")
132
- },
133
- })
134
- })
135
-
136
- test("custom agent config overrides native agent properties", async () => {
137
- await using tmp = await tmpdir({
138
- config: {
139
- agent: {
140
- build: {
141
- model: "anthropic/claude-3",
142
- description: "Custom build agent",
143
- temperature: 0.7,
144
- color: "#FF0000",
145
- },
146
- },
147
- },
148
- })
149
- await Instance.provide({
150
- directory: tmp.path,
151
- fn: async () => {
152
- const build = await Agent.get("build")
153
- expect(build).toBeDefined()
154
- expect(build?.model?.providerID).toBe("anthropic")
155
- expect(build?.model?.modelID).toBe("claude-3")
156
- expect(build?.description).toBe("Custom build agent")
157
- expect(build?.temperature).toBe(0.7)
158
- expect(build?.color).toBe("#FF0000")
159
- expect(build?.native).toBe(true)
160
- },
161
- })
162
- })
163
-
164
- test("agent disable removes agent from list", async () => {
165
- await using tmp = await tmpdir({
166
- config: {
167
- agent: {
168
- explore: { disable: true },
169
- },
170
- },
171
- })
172
- await Instance.provide({
173
- directory: tmp.path,
174
- fn: async () => {
175
- const explore = await Agent.get("explore")
176
- expect(explore).toBeUndefined()
177
- const agents = await Agent.list()
178
- const names = agents.map((a) => a.name)
179
- expect(names).not.toContain("explore")
180
- },
181
- })
182
- })
183
-
184
- test("agent permission config merges with defaults", async () => {
185
- await using tmp = await tmpdir({
186
- config: {
187
- agent: {
188
- build: {
189
- permission: {
190
- bash: {
191
- "rm -rf *": "deny",
192
- },
193
- },
194
- },
195
- },
196
- },
197
- })
198
- await Instance.provide({
199
- directory: tmp.path,
200
- fn: async () => {
201
- const build = await Agent.get("build")
202
- expect(build).toBeDefined()
203
- // Specific pattern is denied
204
- expect(PermissionNext.evaluate("bash", "rm -rf *", build!.permission).action).toBe("deny")
205
- // Edit still allowed
206
- expect(evalPerm(build, "edit")).toBe("allow")
207
- },
208
- })
209
- })
210
-
211
- test("global permission config applies to all agents", async () => {
212
- await using tmp = await tmpdir({
213
- config: {
214
- permission: {
215
- bash: "deny",
216
- },
217
- },
218
- })
219
- await Instance.provide({
220
- directory: tmp.path,
221
- fn: async () => {
222
- const build = await Agent.get("build")
223
- expect(build).toBeDefined()
224
- expect(evalPerm(build, "bash")).toBe("deny")
225
- },
226
- })
227
- })
228
-
229
- test("agent steps/maxSteps config sets steps property", async () => {
230
- await using tmp = await tmpdir({
231
- config: {
232
- agent: {
233
- build: { steps: 50 },
234
- plan: { maxSteps: 100 },
235
- },
236
- },
237
- })
238
- await Instance.provide({
239
- directory: tmp.path,
240
- fn: async () => {
241
- const build = await Agent.get("build")
242
- const plan = await Agent.get("plan")
243
- expect(build?.steps).toBe(50)
244
- expect(plan?.steps).toBe(100)
245
- },
246
- })
247
- })
248
-
249
- test("agent mode can be overridden", async () => {
250
- await using tmp = await tmpdir({
251
- config: {
252
- agent: {
253
- explore: { mode: "primary" },
254
- },
255
- },
256
- })
257
- await Instance.provide({
258
- directory: tmp.path,
259
- fn: async () => {
260
- const explore = await Agent.get("explore")
261
- expect(explore?.mode).toBe("primary")
262
- },
263
- })
264
- })
265
-
266
- test("agent name can be overridden", async () => {
267
- await using tmp = await tmpdir({
268
- config: {
269
- agent: {
270
- build: { name: "Builder" },
271
- },
272
- },
273
- })
274
- await Instance.provide({
275
- directory: tmp.path,
276
- fn: async () => {
277
- const build = await Agent.get("build")
278
- expect(build?.name).toBe("Builder")
279
- },
280
- })
281
- })
282
-
283
- test("agent prompt can be set from config", async () => {
284
- await using tmp = await tmpdir({
285
- config: {
286
- agent: {
287
- build: { prompt: "Custom system prompt" },
288
- },
289
- },
290
- })
291
- await Instance.provide({
292
- directory: tmp.path,
293
- fn: async () => {
294
- const build = await Agent.get("build")
295
- expect(build?.prompt).toBe("Custom system prompt")
296
- },
297
- })
298
- })
299
-
300
- test("unknown agent properties are placed into options", async () => {
301
- await using tmp = await tmpdir({
302
- config: {
303
- agent: {
304
- build: {
305
- random_property: "hello",
306
- another_random: 123,
307
- },
308
- },
309
- },
310
- })
311
- await Instance.provide({
312
- directory: tmp.path,
313
- fn: async () => {
314
- const build = await Agent.get("build")
315
- expect(build?.options.random_property).toBe("hello")
316
- expect(build?.options.another_random).toBe(123)
317
- },
318
- })
319
- })
320
-
321
- test("agent options merge correctly", async () => {
322
- await using tmp = await tmpdir({
323
- config: {
324
- agent: {
325
- build: {
326
- options: {
327
- custom_option: true,
328
- another_option: "value",
329
- },
330
- },
331
- },
332
- },
333
- })
334
- await Instance.provide({
335
- directory: tmp.path,
336
- fn: async () => {
337
- const build = await Agent.get("build")
338
- expect(build?.options.custom_option).toBe(true)
339
- expect(build?.options.another_option).toBe("value")
340
- },
341
- })
342
- })
343
-
344
- test("multiple custom agents can be defined", async () => {
345
- await using tmp = await tmpdir({
346
- config: {
347
- agent: {
348
- agent_a: {
349
- description: "Agent A",
350
- mode: "subagent",
351
- },
352
- agent_b: {
353
- description: "Agent B",
354
- mode: "primary",
355
- },
356
- },
357
- },
358
- })
359
- await Instance.provide({
360
- directory: tmp.path,
361
- fn: async () => {
362
- const agentA = await Agent.get("agent_a")
363
- const agentB = await Agent.get("agent_b")
364
- expect(agentA?.description).toBe("Agent A")
365
- expect(agentA?.mode).toBe("subagent")
366
- expect(agentB?.description).toBe("Agent B")
367
- expect(agentB?.mode).toBe("primary")
368
- },
369
- })
370
- })
371
-
372
- test("Agent.get returns undefined for non-existent agent", async () => {
373
- await using tmp = await tmpdir()
374
- await Instance.provide({
375
- directory: tmp.path,
376
- fn: async () => {
377
- const nonExistent = await Agent.get("does_not_exist")
378
- expect(nonExistent).toBeUndefined()
379
- },
380
- })
381
- })
382
-
383
- test("default permission includes doom_loop and external_directory as ask", async () => {
384
- await using tmp = await tmpdir()
385
- await Instance.provide({
386
- directory: tmp.path,
387
- fn: async () => {
388
- const build = await Agent.get("build")
389
- expect(evalPerm(build, "doom_loop")).toBe("ask")
390
- expect(evalPerm(build, "external_directory")).toBe("ask")
391
- },
392
- })
393
- })
394
-
395
- test("webfetch is allowed by default", async () => {
396
- await using tmp = await tmpdir()
397
- await Instance.provide({
398
- directory: tmp.path,
399
- fn: async () => {
400
- const build = await Agent.get("build")
401
- expect(evalPerm(build, "webfetch")).toBe("allow")
402
- },
403
- })
404
- })
405
-
406
- test("legacy tools config converts to permissions", async () => {
407
- await using tmp = await tmpdir({
408
- config: {
409
- agent: {
410
- build: {
411
- tools: {
412
- bash: false,
413
- read: false,
414
- },
415
- },
416
- },
417
- },
418
- })
419
- await Instance.provide({
420
- directory: tmp.path,
421
- fn: async () => {
422
- const build = await Agent.get("build")
423
- expect(evalPerm(build, "bash")).toBe("deny")
424
- expect(evalPerm(build, "read")).toBe("deny")
425
- },
426
- })
427
- })
428
-
429
- test("legacy tools config maps write/edit/patch/multiedit to edit permission", async () => {
430
- await using tmp = await tmpdir({
431
- config: {
432
- agent: {
433
- build: {
434
- tools: {
435
- write: false,
436
- },
437
- },
438
- },
439
- },
440
- })
441
- await Instance.provide({
442
- directory: tmp.path,
443
- fn: async () => {
444
- const build = await Agent.get("build")
445
- expect(evalPerm(build, "edit")).toBe("deny")
446
- },
447
- })
448
- })
449
-
450
- test("Truncate.DIR is allowed even when user denies external_directory globally", async () => {
451
- const { Truncate } = await import("../../src/tool/truncation")
452
- await using tmp = await tmpdir({
453
- config: {
454
- permission: {
455
- external_directory: "deny",
456
- },
457
- },
458
- })
459
- await Instance.provide({
460
- directory: tmp.path,
461
- fn: async () => {
462
- const build = await Agent.get("build")
463
- expect(PermissionNext.evaluate("external_directory", Truncate.DIR, build!.permission).action).toBe("allow")
464
- expect(PermissionNext.evaluate("external_directory", Truncate.GLOB, build!.permission).action).toBe("allow")
465
- expect(PermissionNext.evaluate("external_directory", "/some/other/path", build!.permission).action).toBe("deny")
466
- },
467
- })
468
- })
469
-
470
- test("Truncate.DIR is allowed even when user denies external_directory per-agent", async () => {
471
- const { Truncate } = await import("../../src/tool/truncation")
472
- await using tmp = await tmpdir({
473
- config: {
474
- agent: {
475
- build: {
476
- permission: {
477
- external_directory: "deny",
478
- },
479
- },
480
- },
481
- },
482
- })
483
- await Instance.provide({
484
- directory: tmp.path,
485
- fn: async () => {
486
- const build = await Agent.get("build")
487
- expect(PermissionNext.evaluate("external_directory", Truncate.DIR, build!.permission).action).toBe("allow")
488
- expect(PermissionNext.evaluate("external_directory", Truncate.GLOB, build!.permission).action).toBe("allow")
489
- expect(PermissionNext.evaluate("external_directory", "/some/other/path", build!.permission).action).toBe("deny")
490
- },
491
- })
492
- })
493
-
494
- test("explicit Truncate.DIR deny is respected", async () => {
495
- const { Truncate } = await import("../../src/tool/truncation")
496
- await using tmp = await tmpdir({
497
- config: {
498
- permission: {
499
- external_directory: {
500
- "*": "deny",
501
- [Truncate.DIR]: "deny",
502
- },
503
- },
504
- },
505
- })
506
- await Instance.provide({
507
- directory: tmp.path,
508
- fn: async () => {
509
- const build = await Agent.get("build")
510
- expect(PermissionNext.evaluate("external_directory", Truncate.DIR, build!.permission).action).toBe("deny")
511
- expect(PermissionNext.evaluate("external_directory", Truncate.GLOB, build!.permission).action).toBe("deny")
512
- },
513
- })
514
- })
515
-
516
- test("defaultAgent returns build when no default_agent config", async () => {
517
- await using tmp = await tmpdir()
518
- await Instance.provide({
519
- directory: tmp.path,
520
- fn: async () => {
521
- const agent = await Agent.defaultAgent()
522
- expect(agent).toBe("build")
523
- },
524
- })
525
- })
526
-
527
- test("defaultAgent respects default_agent config set to plan", async () => {
528
- await using tmp = await tmpdir({
529
- config: {
530
- default_agent: "plan",
531
- },
532
- })
533
- await Instance.provide({
534
- directory: tmp.path,
535
- fn: async () => {
536
- const agent = await Agent.defaultAgent()
537
- expect(agent).toBe("plan")
538
- },
539
- })
540
- })
541
-
542
- test("defaultAgent respects default_agent config set to custom agent with mode all", async () => {
543
- await using tmp = await tmpdir({
544
- config: {
545
- default_agent: "my_custom",
546
- agent: {
547
- my_custom: {
548
- description: "My custom agent",
549
- },
550
- },
551
- },
552
- })
553
- await Instance.provide({
554
- directory: tmp.path,
555
- fn: async () => {
556
- const agent = await Agent.defaultAgent()
557
- expect(agent).toBe("my_custom")
558
- },
559
- })
560
- })
561
-
562
- test("defaultAgent throws when default_agent points to subagent", async () => {
563
- await using tmp = await tmpdir({
564
- config: {
565
- default_agent: "explore",
566
- },
567
- })
568
- await Instance.provide({
569
- directory: tmp.path,
570
- fn: async () => {
571
- await expect(Agent.defaultAgent()).rejects.toThrow('default agent "explore" is a subagent')
572
- },
573
- })
574
- })
575
-
576
- test("defaultAgent throws when default_agent points to hidden agent", async () => {
577
- await using tmp = await tmpdir({
578
- config: {
579
- default_agent: "compaction",
580
- },
581
- })
582
- await Instance.provide({
583
- directory: tmp.path,
584
- fn: async () => {
585
- await expect(Agent.defaultAgent()).rejects.toThrow('default agent "compaction" is hidden')
586
- },
587
- })
588
- })
589
-
590
- test("defaultAgent throws when default_agent points to non-existent agent", async () => {
591
- await using tmp = await tmpdir({
592
- config: {
593
- default_agent: "does_not_exist",
594
- },
595
- })
596
- await Instance.provide({
597
- directory: tmp.path,
598
- fn: async () => {
599
- await expect(Agent.defaultAgent()).rejects.toThrow('default agent "does_not_exist" not found')
600
- },
601
- })
602
- })
603
-
604
- test("defaultAgent returns plan when build is disabled and default_agent not set", async () => {
605
- await using tmp = await tmpdir({
606
- config: {
607
- agent: {
608
- build: { disable: true },
609
- },
610
- },
611
- })
612
- await Instance.provide({
613
- directory: tmp.path,
614
- fn: async () => {
615
- const agent = await Agent.defaultAgent()
616
- // build is disabled, so it should return plan (next primary agent)
617
- expect(agent).toBe("plan")
618
- },
619
- })
620
- })
621
-
622
- test("defaultAgent throws when all primary agents are disabled", async () => {
623
- await using tmp = await tmpdir({
624
- config: {
625
- agent: {
626
- build: { disable: true },
627
- plan: { disable: true },
628
- },
629
- },
630
- })
631
- await Instance.provide({
632
- directory: tmp.path,
633
- fn: async () => {
634
- // build and plan are disabled, no primary-capable agents remain
635
- await expect(Agent.defaultAgent()).rejects.toThrow("no primary visible agent found")
636
- },
637
- })
638
- })
package/test/bun.test.ts DELETED
@@ -1,53 +0,0 @@
1
- import { describe, expect, test } from "bun:test"
2
- import fs from "fs/promises"
3
- import path from "path"
4
-
5
- describe("BunProc registry configuration", () => {
6
- test("should not contain hardcoded registry parameters", async () => {
7
- // Read the bun/index.ts file
8
- const bunIndexPath = path.join(__dirname, "../src/bun/index.ts")
9
- const content = await fs.readFile(bunIndexPath, "utf-8")
10
-
11
- // Verify that no hardcoded registry is present
12
- expect(content).not.toContain("--registry=")
13
- expect(content).not.toContain("hasNpmRcConfig")
14
- expect(content).not.toContain("NpmRc")
15
- })
16
-
17
- test("should use Bun's default registry resolution", async () => {
18
- // Read the bun/index.ts file
19
- const bunIndexPath = path.join(__dirname, "../src/bun/index.ts")
20
- const content = await fs.readFile(bunIndexPath, "utf-8")
21
-
22
- // Verify that it uses Bun's default resolution
23
- expect(content).toContain("Bun's default registry resolution")
24
- expect(content).toContain("Bun will use them automatically")
25
- expect(content).toContain("No need to pass --registry flag")
26
- })
27
-
28
- test("should have correct command structure without registry", async () => {
29
- // Read the bun/index.ts file
30
- const bunIndexPath = path.join(__dirname, "../src/bun/index.ts")
31
- const content = await fs.readFile(bunIndexPath, "utf-8")
32
-
33
- // Extract the install function
34
- const installFunctionMatch = content.match(/export async function install[\s\S]*?^ }/m)
35
- expect(installFunctionMatch).toBeTruthy()
36
-
37
- if (installFunctionMatch) {
38
- const installFunction = installFunctionMatch[0]
39
-
40
- // Verify expected arguments are present
41
- expect(installFunction).toContain('"add"')
42
- expect(installFunction).toContain('"--force"')
43
- expect(installFunction).toContain('"--exact"')
44
- expect(installFunction).toContain('"--cwd"')
45
- expect(installFunction).toContain("Global.Path.cache")
46
- expect(installFunction).toContain('pkg + "@" + version')
47
-
48
- // Verify no registry argument is added
49
- expect(installFunction).not.toContain('"--registry"')
50
- expect(installFunction).not.toContain('args.push("--registry')
51
- }
52
- })
53
- })