@anh3d0nic/qwen-code-termux-ice 14.0.0 → 16.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1968) hide show
  1. package/bin/api-setup-launcher.js +14 -0
  2. package/bin/qwen-ice +350 -0
  3. package/bin/qwen-ice-api-setup +340 -0
  4. package/bin/qwen-ice-launcher.js +14 -0
  5. package/core/ice-v16.js +1202 -0
  6. package/core/install.js +179 -0
  7. package/core/uninstall.js +66 -0
  8. package/package.json +49 -10
  9. package/.allstar/branch_protection.yaml +0 -1
  10. package/.aoneci/workflows/ci.yml +0 -69
  11. package/.dockerignore +0 -10
  12. package/.editorconfig +0 -13
  13. package/.gcp/Dockerfile.gemini-code-builder +0 -89
  14. package/.gcp/release-docker.yml +0 -71
  15. package/.gitattributes +0 -24
  16. package/.github/CODEOWNERS +0 -3
  17. package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -58
  18. package/.github/ISSUE_TEMPLATE/feature_request.yml +0 -35
  19. package/.github/actions/post-coverage-comment/action.yml +0 -114
  20. package/.github/dependabot.yml +0 -35
  21. package/.github/pull_request_template.md +0 -41
  22. package/.github/scripts/pr-triage.sh +0 -144
  23. package/.github/workflows/build-and-publish-image.yml +0 -109
  24. package/.github/workflows/check-issue-completeness.yml +0 -201
  25. package/.github/workflows/ci.yml +0 -239
  26. package/.github/workflows/community-report.yml +0 -197
  27. package/.github/workflows/docs-page-action.yml +0 -50
  28. package/.github/workflows/e2e.yml +0 -111
  29. package/.github/workflows/eval.yml +0 -29
  30. package/.github/workflows/gemini-automated-issue-dedup.yml +0 -262
  31. package/.github/workflows/gemini-scheduled-issue-dedup.yml +0 -116
  32. package/.github/workflows/gemini-scheduled-pr-triage.yml +0 -30
  33. package/.github/workflows/gemini-self-assign-issue.yml +0 -99
  34. package/.github/workflows/no-response.yml +0 -33
  35. package/.github/workflows/qwen-automated-issue-triage.yml +0 -203
  36. package/.github/workflows/qwen-code-pr-review.yml +0 -190
  37. package/.github/workflows/qwen-scheduled-issue-triage.yml +0 -213
  38. package/.github/workflows/release-sdk.yml +0 -420
  39. package/.github/workflows/release-vscode-companion.yml +0 -359
  40. package/.github/workflows/release.yml +0 -236
  41. package/.github/workflows/stale.yml +0 -39
  42. package/.github/workflows/terminal-bench.yml +0 -96
  43. package/.husky/pre-commit +0 -9
  44. package/.nvmrc +0 -1
  45. package/.prettierignore +0 -22
  46. package/.prettierrc.json +0 -7
  47. package/.qwen/commands/qc/code-review.md +0 -25
  48. package/.qwen/commands/qc/commit.md +0 -70
  49. package/.qwen/commands/qc/create-issue.md +0 -42
  50. package/.qwen/commands/qc/create-pr.md +0 -34
  51. package/.qwen/ice-auto-load.sh +0 -39
  52. package/.qwen/ice.py +0 -822
  53. package/.qwen/qwen.md +0 -70
  54. package/.qwen/skills/pr-review/SKILL.md +0 -104
  55. package/.qwen/skills/terminal-capture/SKILL.md +0 -241
  56. package/.termux-backup/esbuild.config.js +0 -77
  57. package/.termux-backup/package.json.backup +0 -135
  58. package/.termux-backup/patches-README.md +0 -231
  59. package/.termux-backup/postinstall.cjs +0 -14
  60. package/.termux-backup/prepare-termux.cjs +0 -33
  61. package/.termux-backup/termux-runtime.ts +0 -50
  62. package/.vscode/extensions.json +0 -7
  63. package/.vscode/launch.json +0 -165
  64. package/.vscode/settings.json +0 -17
  65. package/.vscode/tasks.json +0 -41
  66. package/.yamllint.yml +0 -90
  67. package/CHANGELOG.md +0 -77
  68. package/CONTRIBUTING.md +0 -303
  69. package/Dockerfile +0 -73
  70. package/Makefile +0 -59
  71. package/SECURITY.md +0 -9
  72. package/docs/_meta.ts +0 -14
  73. package/docs/developers/BUILDING.md +0 -145
  74. package/docs/developers/_meta.ts +0 -25
  75. package/docs/developers/architecture.md +0 -95
  76. package/docs/developers/contributing.md +0 -303
  77. package/docs/developers/development/_meta.ts +0 -9
  78. package/docs/developers/development/deployment.md +0 -117
  79. package/docs/developers/development/integration-tests.md +0 -137
  80. package/docs/developers/development/issue-and-pr-automation.md +0 -84
  81. package/docs/developers/development/npm.md +0 -258
  82. package/docs/developers/development/telemetry.md +0 -297
  83. package/docs/developers/examples/proxy-script.md +0 -81
  84. package/docs/developers/roadmap.md +0 -82
  85. package/docs/developers/sdk-java.md +0 -311
  86. package/docs/developers/sdk-typescript.md +0 -375
  87. package/docs/developers/tools/_meta.ts +0 -14
  88. package/docs/developers/tools/exit-plan-mode.md +0 -149
  89. package/docs/developers/tools/file-system.md +0 -167
  90. package/docs/developers/tools/introduction.md +0 -62
  91. package/docs/developers/tools/mcp-server.md +0 -873
  92. package/docs/developers/tools/memory.md +0 -44
  93. package/docs/developers/tools/multi-file.md +0 -69
  94. package/docs/developers/tools/sandbox.md +0 -91
  95. package/docs/developers/tools/shell.md +0 -259
  96. package/docs/developers/tools/task.md +0 -145
  97. package/docs/developers/tools/todo-write.md +0 -63
  98. package/docs/developers/tools/web-fetch.md +0 -54
  99. package/docs/developers/tools/web-search.md +0 -186
  100. package/docs/index.md +0 -25
  101. package/docs/users/_meta.ts +0 -30
  102. package/docs/users/common-workflow.md +0 -571
  103. package/docs/users/configuration/_meta.ts +0 -10
  104. package/docs/users/configuration/auth.md +0 -297
  105. package/docs/users/configuration/memory.md +0 -0
  106. package/docs/users/configuration/model-providers.md +0 -506
  107. package/docs/users/configuration/qwen-ignore.md +0 -55
  108. package/docs/users/configuration/settings.md +0 -563
  109. package/docs/users/configuration/themes.md +0 -160
  110. package/docs/users/configuration/trusted-folders.md +0 -61
  111. package/docs/users/configuration.md +0 -73
  112. package/docs/users/extension/_meta.ts +0 -9
  113. package/docs/users/extension/extension-releasing.md +0 -121
  114. package/docs/users/extension/getting-started-extensions.md +0 -299
  115. package/docs/users/extension/introduction.md +0 -303
  116. package/docs/users/features/_meta.ts +0 -15
  117. package/docs/users/features/approval-mode.md +0 -263
  118. package/docs/users/features/checkpointing.md +0 -77
  119. package/docs/users/features/commands.md +0 -295
  120. package/docs/users/features/headless.md +0 -282
  121. package/docs/users/features/language.md +0 -139
  122. package/docs/users/features/lsp.md +0 -374
  123. package/docs/users/features/mcp.md +0 -281
  124. package/docs/users/features/sandbox.md +0 -218
  125. package/docs/users/features/skills.md +0 -289
  126. package/docs/users/features/sub-agents.md +0 -504
  127. package/docs/users/features/token-caching.md +0 -29
  128. package/docs/users/ide-integration/_meta.ts +0 -4
  129. package/docs/users/ide-integration/ide-companion-spec.md +0 -182
  130. package/docs/users/ide-integration/ide-integration.md +0 -144
  131. package/docs/users/integration-github-action.md +0 -241
  132. package/docs/users/integration-jetbrains.md +0 -57
  133. package/docs/users/integration-vscode.md +0 -39
  134. package/docs/users/integration-zed.md +0 -54
  135. package/docs/users/overview.md +0 -64
  136. package/docs/users/quickstart.md +0 -271
  137. package/docs/users/reference/_meta.ts +0 -3
  138. package/docs/users/reference/keyboard-shortcuts.md +0 -72
  139. package/docs/users/support/Uninstall.md +0 -42
  140. package/docs/users/support/_meta.ts +0 -6
  141. package/docs/users/support/tos-privacy.md +0 -112
  142. package/docs/users/support/troubleshooting.md +0 -123
  143. package/docs-site/README.md +0 -54
  144. package/docs-site/mdx-components.js +0 -12
  145. package/docs-site/next-env.d.ts +0 -6
  146. package/docs-site/next.config.mjs +0 -5
  147. package/docs-site/package.json +0 -22
  148. package/docs-site/src/app/[[...mdxPath]]/page.jsx +0 -27
  149. package/docs-site/src/app/layout.jsx +0 -55
  150. package/esbuild.config.js +0 -80
  151. package/eslint-rules/no-relative-cross-package-imports.js +0 -159
  152. package/eslint.config.js +0 -327
  153. package/hello/QWEN.md +0 -8
  154. package/hello/qwen-extension.json +0 -5
  155. package/integration-tests/acp-integration.test.ts +0 -1003
  156. package/integration-tests/concurrent-runner/README.md +0 -139
  157. package/integration-tests/concurrent-runner/config.example.json +0 -39
  158. package/integration-tests/concurrent-runner/examples/toy-config.json +0 -27
  159. package/integration-tests/concurrent-runner/examples/toy-project/package.json +0 -11
  160. package/integration-tests/concurrent-runner/export-html-from-chatrecord-jsonl.js +0 -973
  161. package/integration-tests/concurrent-runner/render-chat-temp.html +0 -291
  162. package/integration-tests/concurrent-runner/requirements.txt +0 -2
  163. package/integration-tests/concurrent-runner/runner.py +0 -1083
  164. package/integration-tests/context-compress-interactive.test.ts +0 -108
  165. package/integration-tests/ctrl-c-exit.test.ts +0 -76
  166. package/integration-tests/edit.test.ts +0 -185
  167. package/integration-tests/extensions-install.test.ts +0 -52
  168. package/integration-tests/file-system-interactive.test.ts +0 -83
  169. package/integration-tests/file-system.test.ts +0 -247
  170. package/integration-tests/fixtures/settings-migration/workspaces.json +0 -189
  171. package/integration-tests/globalSetup.ts +0 -136
  172. package/integration-tests/hook-integration/hooks.test.ts +0 -1995
  173. package/integration-tests/json-output.test.ts +0 -310
  174. package/integration-tests/list_directory.test.ts +0 -66
  175. package/integration-tests/mcp_server_cyclic_schema.test.ts +0 -207
  176. package/integration-tests/mixed-input-crash.test.ts +0 -62
  177. package/integration-tests/read_many_files.test.ts +0 -47
  178. package/integration-tests/run_shell_command.test.ts +0 -130
  179. package/integration-tests/save_memory.test.ts +0 -47
  180. package/integration-tests/sdk-typescript/abort-and-lifecycle.test.ts +0 -657
  181. package/integration-tests/sdk-typescript/configuration-options.test.ts +0 -636
  182. package/integration-tests/sdk-typescript/mcp-server.test.ts +0 -581
  183. package/integration-tests/sdk-typescript/multi-turn.test.ts +0 -610
  184. package/integration-tests/sdk-typescript/permission-control.test.ts +0 -1272
  185. package/integration-tests/sdk-typescript/sdk-mcp-server.test.ts +0 -467
  186. package/integration-tests/sdk-typescript/session-id.test.ts +0 -582
  187. package/integration-tests/sdk-typescript/single-turn.test.ts +0 -528
  188. package/integration-tests/sdk-typescript/subagents.test.ts +0 -570
  189. package/integration-tests/sdk-typescript/system-control.test.ts +0 -426
  190. package/integration-tests/sdk-typescript/test-helper.ts +0 -1012
  191. package/integration-tests/sdk-typescript/tool-control.test.ts +0 -984
  192. package/integration-tests/settings-migration.test.ts +0 -627
  193. package/integration-tests/simple-mcp-server.test.ts +0 -231
  194. package/integration-tests/stdin-context.test.ts +0 -97
  195. package/integration-tests/telemetry.test.ts +0 -26
  196. package/integration-tests/terminal-bench/ci-tasks/hello-world/Dockerfile +0 -2
  197. package/integration-tests/terminal-bench/ci-tasks/hello-world/docker-compose.yaml +0 -12
  198. package/integration-tests/terminal-bench/ci-tasks/hello-world/run-tests.sh +0 -4
  199. package/integration-tests/terminal-bench/ci-tasks/hello-world/solution.sh +0 -4
  200. package/integration-tests/terminal-bench/ci-tasks/hello-world/task.yaml +0 -15
  201. package/integration-tests/terminal-bench/ci-tasks/hello-world/tests/run-uv-pytest.sh +0 -3
  202. package/integration-tests/terminal-bench/ci-tasks/hello-world/tests/setup-uv-pytest.sh +0 -19
  203. package/integration-tests/terminal-bench/ci-tasks/hello-world/tests/test_outputs.py +0 -19
  204. package/integration-tests/terminal-bench/ci-tasks/swe-bench-astropy-1/Dockerfile +0 -34
  205. package/integration-tests/terminal-bench/ci-tasks/swe-bench-astropy-1/docker-compose.yaml +0 -12
  206. package/integration-tests/terminal-bench/ci-tasks/swe-bench-astropy-1/run-tests.sh +0 -52
  207. package/integration-tests/terminal-bench/ci-tasks/swe-bench-astropy-1/solution.sh +0 -26
  208. package/integration-tests/terminal-bench/ci-tasks/swe-bench-astropy-1/task.yaml +0 -55
  209. package/integration-tests/terminal-bench/qwen-code-setup.sh.j2 +0 -15
  210. package/integration-tests/terminal-bench/qwen_code.py +0 -70
  211. package/integration-tests/terminal-bench/terminal-bench.test.ts +0 -328
  212. package/integration-tests/terminal-capture/motivation.md +0 -127
  213. package/integration-tests/terminal-capture/package.json +0 -18
  214. package/integration-tests/terminal-capture/run.ts +0 -105
  215. package/integration-tests/terminal-capture/scenario-runner.ts +0 -429
  216. package/integration-tests/terminal-capture/scenarios/about.ts +0 -8
  217. package/integration-tests/terminal-capture/scenarios/all.ts +0 -46
  218. package/integration-tests/terminal-capture/scenarios/message-components.ts +0 -32
  219. package/integration-tests/terminal-capture/scenarios/progress.sh +0 -16
  220. package/integration-tests/terminal-capture/scenarios/qc-code-review.ts +0 -17
  221. package/integration-tests/terminal-capture/scenarios/streaming-insight.ts +0 -23
  222. package/integration-tests/terminal-capture/scenarios/streaming-shell.ts +0 -24
  223. package/integration-tests/terminal-capture/terminal-capture.ts +0 -856
  224. package/integration-tests/test-helper.ts +0 -863
  225. package/integration-tests/test-mcp-server.ts +0 -64
  226. package/integration-tests/todo_write.test.ts +0 -69
  227. package/integration-tests/tsconfig.json +0 -13
  228. package/integration-tests/utf-bom-encoding.test.ts +0 -218
  229. package/integration-tests/vitest.config.ts +0 -40
  230. package/integration-tests/vitest.terminal-bench.config.ts +0 -21
  231. package/integration-tests/web_search.test.ts +0 -122
  232. package/integration-tests/write_file.test.ts +0 -69
  233. package/packages/cli/index.ts +0 -30
  234. package/packages/cli/package.json +0 -112
  235. package/packages/cli/src/acp-integration/acpAgent.ts +0 -600
  236. package/packages/cli/src/acp-integration/authMethods.ts +0 -51
  237. package/packages/cli/src/acp-integration/errorCodes.ts +0 -25
  238. package/packages/cli/src/acp-integration/service/filesystem.test.ts +0 -182
  239. package/packages/cli/src/acp-integration/service/filesystem.ts +0 -108
  240. package/packages/cli/src/acp-integration/session/HistoryReplayer.test.ts +0 -477
  241. package/packages/cli/src/acp-integration/session/HistoryReplayer.ts +0 -234
  242. package/packages/cli/src/acp-integration/session/Session.test.ts +0 -245
  243. package/packages/cli/src/acp-integration/session/Session.ts +0 -1068
  244. package/packages/cli/src/acp-integration/session/SubAgentTracker.test.ts +0 -725
  245. package/packages/cli/src/acp-integration/session/SubAgentTracker.ts +0 -390
  246. package/packages/cli/src/acp-integration/session/emitters/BaseEmitter.ts +0 -52
  247. package/packages/cli/src/acp-integration/session/emitters/MessageEmitter.test.ts +0 -206
  248. package/packages/cli/src/acp-integration/session/emitters/MessageEmitter.ts +0 -124
  249. package/packages/cli/src/acp-integration/session/emitters/PlanEmitter.test.ts +0 -228
  250. package/packages/cli/src/acp-integration/session/emitters/PlanEmitter.ts +0 -96
  251. package/packages/cli/src/acp-integration/session/emitters/ToolCallEmitter.test.ts +0 -677
  252. package/packages/cli/src/acp-integration/session/emitters/ToolCallEmitter.ts +0 -328
  253. package/packages/cli/src/acp-integration/session/emitters/index.ts +0 -10
  254. package/packages/cli/src/acp-integration/session/index.ts +0 -40
  255. package/packages/cli/src/acp-integration/session/types.ts +0 -102
  256. package/packages/cli/src/commands/extensions/consent.test.ts +0 -327
  257. package/packages/cli/src/commands/extensions/consent.ts +0 -269
  258. package/packages/cli/src/commands/extensions/disable.test.ts +0 -145
  259. package/packages/cli/src/commands/extensions/disable.ts +0 -77
  260. package/packages/cli/src/commands/extensions/enable.test.ts +0 -133
  261. package/packages/cli/src/commands/extensions/enable.ts +0 -89
  262. package/packages/cli/src/commands/extensions/examples/agent/agents/diary.md +0 -87
  263. package/packages/cli/src/commands/extensions/examples/agent/qwen-extension.json +0 -4
  264. package/packages/cli/src/commands/extensions/examples/commands/commands/fs/grep-code.md +0 -3
  265. package/packages/cli/src/commands/extensions/examples/commands/qwen-extension.json +0 -4
  266. package/packages/cli/src/commands/extensions/examples/context/QWEN.md +0 -8
  267. package/packages/cli/src/commands/extensions/examples/context/qwen-extension.json +0 -4
  268. package/packages/cli/src/commands/extensions/examples/mcp-server/example.ts +0 -60
  269. package/packages/cli/src/commands/extensions/examples/mcp-server/package.json +0 -18
  270. package/packages/cli/src/commands/extensions/examples/mcp-server/qwen-extension.json +0 -11
  271. package/packages/cli/src/commands/extensions/examples/mcp-server/tsconfig.json +0 -13
  272. package/packages/cli/src/commands/extensions/examples/skills/qwen-extension.json +0 -4
  273. package/packages/cli/src/commands/extensions/examples/skills/skills/synonyms/SKILL.md +0 -48
  274. package/packages/cli/src/commands/extensions/install.test.ts +0 -228
  275. package/packages/cli/src/commands/extensions/install.ts +0 -131
  276. package/packages/cli/src/commands/extensions/link.test.ts +0 -99
  277. package/packages/cli/src/commands/extensions/link.ts +0 -66
  278. package/packages/cli/src/commands/extensions/list.test.ts +0 -103
  279. package/packages/cli/src/commands/extensions/list.ts +0 -42
  280. package/packages/cli/src/commands/extensions/new.test.ts +0 -91
  281. package/packages/cli/src/commands/extensions/new.ts +0 -110
  282. package/packages/cli/src/commands/extensions/settings.test.ts +0 -345
  283. package/packages/cli/src/commands/extensions/settings.ts +0 -152
  284. package/packages/cli/src/commands/extensions/uninstall.test.ts +0 -21
  285. package/packages/cli/src/commands/extensions/uninstall.ts +0 -71
  286. package/packages/cli/src/commands/extensions/update.test.ts +0 -260
  287. package/packages/cli/src/commands/extensions/update.ts +0 -155
  288. package/packages/cli/src/commands/extensions/utils.test.ts +0 -138
  289. package/packages/cli/src/commands/extensions/utils.ts +0 -98
  290. package/packages/cli/src/commands/extensions.test.tsx +0 -106
  291. package/packages/cli/src/commands/extensions.tsx +0 -38
  292. package/packages/cli/src/commands/hooks/disable.ts +0 -78
  293. package/packages/cli/src/commands/hooks/enable.ts +0 -78
  294. package/packages/cli/src/commands/hooks.tsx +0 -25
  295. package/packages/cli/src/commands/mcp/add.test.ts +0 -371
  296. package/packages/cli/src/commands/mcp/add.ts +0 -247
  297. package/packages/cli/src/commands/mcp/list.test.ts +0 -189
  298. package/packages/cli/src/commands/mcp/list.ts +0 -148
  299. package/packages/cli/src/commands/mcp/remove.test.ts +0 -115
  300. package/packages/cli/src/commands/mcp/remove.ts +0 -70
  301. package/packages/cli/src/commands/mcp.test.ts +0 -55
  302. package/packages/cli/src/commands/mcp.ts +0 -27
  303. package/packages/cli/src/config/auth.test.ts +0 -230
  304. package/packages/cli/src/config/auth.ts +0 -223
  305. package/packages/cli/src/config/config.integration.test.ts +0 -417
  306. package/packages/cli/src/config/config.test.ts +0 -2402
  307. package/packages/cli/src/config/config.ts +0 -1089
  308. package/packages/cli/src/config/keyBindings.test.ts +0 -59
  309. package/packages/cli/src/config/keyBindings.ts +0 -186
  310. package/packages/cli/src/config/migration/index.test.ts +0 -383
  311. package/packages/cli/src/config/migration/index.ts +0 -106
  312. package/packages/cli/src/config/migration/scheduler.test.ts +0 -164
  313. package/packages/cli/src/config/migration/scheduler.ts +0 -115
  314. package/packages/cli/src/config/migration/types.ts +0 -58
  315. package/packages/cli/src/config/migration/versions/v1-to-v2-shared.ts +0 -180
  316. package/packages/cli/src/config/migration/versions/v1-to-v2.test.ts +0 -277
  317. package/packages/cli/src/config/migration/versions/v1-to-v2.ts +0 -267
  318. package/packages/cli/src/config/migration/versions/v2-to-v3.test.ts +0 -598
  319. package/packages/cli/src/config/migration/versions/v2-to-v3.ts +0 -222
  320. package/packages/cli/src/config/modelProvidersScope.test.ts +0 -87
  321. package/packages/cli/src/config/modelProvidersScope.ts +0 -48
  322. package/packages/cli/src/config/sandboxConfig.ts +0 -105
  323. package/packages/cli/src/config/settings.test.ts +0 -2786
  324. package/packages/cli/src/config/settings.ts +0 -740
  325. package/packages/cli/src/config/settingsSchema.test.ts +0 -312
  326. package/packages/cli/src/config/settingsSchema.ts +0 -1277
  327. package/packages/cli/src/config/trustedFolders.test.ts +0 -429
  328. package/packages/cli/src/config/trustedFolders.ts +0 -239
  329. package/packages/cli/src/config/webSearch.ts +0 -121
  330. package/packages/cli/src/constants/codingPlan.ts +0 -321
  331. package/packages/cli/src/core/auth.ts +0 -48
  332. package/packages/cli/src/core/initializer.ts +0 -74
  333. package/packages/cli/src/core/theme.ts +0 -24
  334. package/packages/cli/src/gemini.test.tsx +0 -691
  335. package/packages/cli/src/gemini.tsx +0 -512
  336. package/packages/cli/src/i18n/index.ts +0 -257
  337. package/packages/cli/src/i18n/languages.ts +0 -98
  338. package/packages/cli/src/i18n/locales/de.js +0 -1613
  339. package/packages/cli/src/i18n/locales/en.js +0 -1665
  340. package/packages/cli/src/i18n/locales/ja.js +0 -1117
  341. package/packages/cli/src/i18n/locales/pt.js +0 -1608
  342. package/packages/cli/src/i18n/locales/ru.js +0 -1620
  343. package/packages/cli/src/i18n/locales/zh.js +0 -1485
  344. package/packages/cli/src/nonInteractive/control/ControlContext.ts +0 -79
  345. package/packages/cli/src/nonInteractive/control/ControlDispatcher.test.ts +0 -1010
  346. package/packages/cli/src/nonInteractive/control/ControlDispatcher.ts +0 -432
  347. package/packages/cli/src/nonInteractive/control/ControlService.ts +0 -179
  348. package/packages/cli/src/nonInteractive/control/controllers/baseController.ts +0 -226
  349. package/packages/cli/src/nonInteractive/control/controllers/hookController.ts +0 -56
  350. package/packages/cli/src/nonInteractive/control/controllers/permissionController.ts +0 -495
  351. package/packages/cli/src/nonInteractive/control/controllers/sdkMcpController.ts +0 -134
  352. package/packages/cli/src/nonInteractive/control/controllers/systemController.ts +0 -419
  353. package/packages/cli/src/nonInteractive/control/types/serviceAPIs.ts +0 -117
  354. package/packages/cli/src/nonInteractive/io/BaseJsonOutputAdapter.test.ts +0 -1652
  355. package/packages/cli/src/nonInteractive/io/BaseJsonOutputAdapter.ts +0 -1339
  356. package/packages/cli/src/nonInteractive/io/JsonOutputAdapter.test.ts +0 -865
  357. package/packages/cli/src/nonInteractive/io/JsonOutputAdapter.ts +0 -89
  358. package/packages/cli/src/nonInteractive/io/StreamJsonInputReader.test.ts +0 -215
  359. package/packages/cli/src/nonInteractive/io/StreamJsonInputReader.ts +0 -73
  360. package/packages/cli/src/nonInteractive/io/StreamJsonOutputAdapter.test.ts +0 -1168
  361. package/packages/cli/src/nonInteractive/io/StreamJsonOutputAdapter.ts +0 -330
  362. package/packages/cli/src/nonInteractive/session.test.ts +0 -577
  363. package/packages/cli/src/nonInteractive/session.ts +0 -626
  364. package/packages/cli/src/nonInteractive/types.ts +0 -578
  365. package/packages/cli/src/nonInteractiveCli.test.ts +0 -1814
  366. package/packages/cli/src/nonInteractiveCli.ts +0 -420
  367. package/packages/cli/src/nonInteractiveCliCommands.test.ts +0 -242
  368. package/packages/cli/src/nonInteractiveCliCommands.ts +0 -386
  369. package/packages/cli/src/patches/is-in-ci.ts +0 -17
  370. package/packages/cli/src/patches/termux-runtime.ts +0 -50
  371. package/packages/cli/src/services/BuiltinCommandLoader.test.ts +0 -187
  372. package/packages/cli/src/services/BuiltinCommandLoader.ts +0 -101
  373. package/packages/cli/src/services/CommandService.test.ts +0 -348
  374. package/packages/cli/src/services/CommandService.ts +0 -106
  375. package/packages/cli/src/services/FileCommandLoader-extension.test.ts +0 -343
  376. package/packages/cli/src/services/FileCommandLoader-markdown.test.ts +0 -141
  377. package/packages/cli/src/services/FileCommandLoader.test.ts +0 -1254
  378. package/packages/cli/src/services/FileCommandLoader.ts +0 -363
  379. package/packages/cli/src/services/McpPromptLoader.test.ts +0 -399
  380. package/packages/cli/src/services/McpPromptLoader.ts +0 -305
  381. package/packages/cli/src/services/command-factory.ts +0 -157
  382. package/packages/cli/src/services/command-migration-tool.test.ts +0 -254
  383. package/packages/cli/src/services/command-migration-tool.ts +0 -173
  384. package/packages/cli/src/services/insight/generators/DataProcessor.test.ts +0 -1217
  385. package/packages/cli/src/services/insight/generators/DataProcessor.ts +0 -1131
  386. package/packages/cli/src/services/insight/generators/StaticInsightGenerator.ts +0 -93
  387. package/packages/cli/src/services/insight/generators/TemplateRenderer.ts +0 -52
  388. package/packages/cli/src/services/insight/types/QualitativeInsightTypes.ts +0 -82
  389. package/packages/cli/src/services/insight/types/StaticInsightTypes.ts +0 -90
  390. package/packages/cli/src/services/markdown-command-parser.test.ts +0 -189
  391. package/packages/cli/src/services/markdown-command-parser.ts +0 -69
  392. package/packages/cli/src/services/prompt-processors/argumentProcessor.test.ts +0 -43
  393. package/packages/cli/src/services/prompt-processors/argumentProcessor.ts +0 -27
  394. package/packages/cli/src/services/prompt-processors/atFileProcessor.test.ts +0 -221
  395. package/packages/cli/src/services/prompt-processors/atFileProcessor.ts +0 -99
  396. package/packages/cli/src/services/prompt-processors/injectionParser.test.ts +0 -223
  397. package/packages/cli/src/services/prompt-processors/injectionParser.ts +0 -89
  398. package/packages/cli/src/services/prompt-processors/shellProcessor.test.ts +0 -741
  399. package/packages/cli/src/services/prompt-processors/shellProcessor.ts +0 -233
  400. package/packages/cli/src/services/prompt-processors/types.ts +0 -54
  401. package/packages/cli/src/services/test-commands/example.md +0 -5
  402. package/packages/cli/src/services/types.ts +0 -24
  403. package/packages/cli/src/test-utils/customMatchers.ts +0 -66
  404. package/packages/cli/src/test-utils/mockCommandContext.test.ts +0 -62
  405. package/packages/cli/src/test-utils/mockCommandContext.ts +0 -119
  406. package/packages/cli/src/test-utils/render.tsx +0 -47
  407. package/packages/cli/src/types/qrcode-terminal.d.ts +0 -9
  408. package/packages/cli/src/types/web-templates.d.ts +0 -8
  409. package/packages/cli/src/ui/App.test.tsx +0 -160
  410. package/packages/cli/src/ui/App.tsx +0 -27
  411. package/packages/cli/src/ui/AppContainer.test.tsx +0 -1124
  412. package/packages/cli/src/ui/AppContainer.tsx +0 -1647
  413. package/packages/cli/src/ui/CommandFormatMigrationNudge.tsx +0 -94
  414. package/packages/cli/src/ui/FeedbackDialog.tsx +0 -75
  415. package/packages/cli/src/ui/IdeIntegrationNudge.tsx +0 -103
  416. package/packages/cli/src/ui/auth/AuthDialog.test.tsx +0 -558
  417. package/packages/cli/src/ui/auth/AuthDialog.tsx +0 -396
  418. package/packages/cli/src/ui/auth/AuthInProgress.tsx +0 -64
  419. package/packages/cli/src/ui/auth/useAuth.ts +0 -478
  420. package/packages/cli/src/ui/colors.ts +0 -62
  421. package/packages/cli/src/ui/commands/aboutCommand.test.ts +0 -283
  422. package/packages/cli/src/ui/commands/aboutCommand.ts +0 -30
  423. package/packages/cli/src/ui/commands/agentsCommand.ts +0 -44
  424. package/packages/cli/src/ui/commands/approvalModeCommand.test.ts +0 -175
  425. package/packages/cli/src/ui/commands/approvalModeCommand.ts +0 -83
  426. package/packages/cli/src/ui/commands/authCommand.test.ts +0 -38
  427. package/packages/cli/src/ui/commands/authCommand.ts +0 -22
  428. package/packages/cli/src/ui/commands/bugCommand.test.ts +0 -166
  429. package/packages/cli/src/ui/commands/bugCommand.ts +0 -68
  430. package/packages/cli/src/ui/commands/clearCommand.test.ts +0 -100
  431. package/packages/cli/src/ui/commands/clearCommand.ts +0 -49
  432. package/packages/cli/src/ui/commands/compressCommand.test.ts +0 -134
  433. package/packages/cli/src/ui/commands/compressCommand.ts +0 -175
  434. package/packages/cli/src/ui/commands/copyCommand.test.ts +0 -304
  435. package/packages/cli/src/ui/commands/copyCommand.ts +0 -67
  436. package/packages/cli/src/ui/commands/directoryCommand.test.tsx +0 -183
  437. package/packages/cli/src/ui/commands/directoryCommand.tsx +0 -207
  438. package/packages/cli/src/ui/commands/docsCommand.test.ts +0 -99
  439. package/packages/cli/src/ui/commands/docsCommand.ts +0 -53
  440. package/packages/cli/src/ui/commands/editorCommand.test.ts +0 -30
  441. package/packages/cli/src/ui/commands/editorCommand.ts +0 -24
  442. package/packages/cli/src/ui/commands/exportCommand.test.ts +0 -383
  443. package/packages/cli/src/ui/commands/exportCommand.ts +0 -347
  444. package/packages/cli/src/ui/commands/extensionsCommand.test.ts +0 -213
  445. package/packages/cli/src/ui/commands/extensionsCommand.ts +0 -255
  446. package/packages/cli/src/ui/commands/helpCommand.test.ts +0 -52
  447. package/packages/cli/src/ui/commands/helpCommand.ts +0 -27
  448. package/packages/cli/src/ui/commands/hooksCommand.ts +0 -322
  449. package/packages/cli/src/ui/commands/ideCommand.test.ts +0 -264
  450. package/packages/cli/src/ui/commands/ideCommand.ts +0 -335
  451. package/packages/cli/src/ui/commands/initCommand.test.ts +0 -169
  452. package/packages/cli/src/ui/commands/initCommand.ts +0 -134
  453. package/packages/cli/src/ui/commands/insightCommand.ts +0 -132
  454. package/packages/cli/src/ui/commands/languageCommand.test.ts +0 -848
  455. package/packages/cli/src/ui/commands/languageCommand.ts +0 -374
  456. package/packages/cli/src/ui/commands/mcpCommand.test.ts +0 -153
  457. package/packages/cli/src/ui/commands/mcpCommand.ts +0 -21
  458. package/packages/cli/src/ui/commands/memoryCommand.test.ts +0 -411
  459. package/packages/cli/src/ui/commands/memoryCommand.ts +0 -347
  460. package/packages/cli/src/ui/commands/modelCommand.test.ts +0 -140
  461. package/packages/cli/src/ui/commands/modelCommand.ts +0 -59
  462. package/packages/cli/src/ui/commands/permissionsCommand.test.ts +0 -35
  463. package/packages/cli/src/ui/commands/permissionsCommand.ts +0 -21
  464. package/packages/cli/src/ui/commands/quitCommand.test.ts +0 -55
  465. package/packages/cli/src/ui/commands/quitCommand.ts +0 -39
  466. package/packages/cli/src/ui/commands/restoreCommand.test.ts +0 -255
  467. package/packages/cli/src/ui/commands/restoreCommand.ts +0 -153
  468. package/packages/cli/src/ui/commands/resumeCommand.test.ts +0 -38
  469. package/packages/cli/src/ui/commands/resumeCommand.ts +0 -21
  470. package/packages/cli/src/ui/commands/settingsCommand.test.ts +0 -36
  471. package/packages/cli/src/ui/commands/settingsCommand.ts +0 -21
  472. package/packages/cli/src/ui/commands/setupGithubCommand.test.ts +0 -231
  473. package/packages/cli/src/ui/commands/setupGithubCommand.ts +0 -225
  474. package/packages/cli/src/ui/commands/skillsCommand.ts +0 -135
  475. package/packages/cli/src/ui/commands/statsCommand.test.ts +0 -78
  476. package/packages/cli/src/ui/commands/statsCommand.ts +0 -78
  477. package/packages/cli/src/ui/commands/summaryCommand.ts +0 -323
  478. package/packages/cli/src/ui/commands/terminalSetupCommand.test.ts +0 -85
  479. package/packages/cli/src/ui/commands/terminalSetupCommand.ts +0 -53
  480. package/packages/cli/src/ui/commands/themeCommand.test.ts +0 -38
  481. package/packages/cli/src/ui/commands/themeCommand.ts +0 -21
  482. package/packages/cli/src/ui/commands/toolsCommand.test.ts +0 -114
  483. package/packages/cli/src/ui/commands/toolsCommand.ts +0 -58
  484. package/packages/cli/src/ui/commands/types.ts +0 -254
  485. package/packages/cli/src/ui/commands/vimCommand.ts +0 -29
  486. package/packages/cli/src/ui/components/AboutBox.tsx +0 -52
  487. package/packages/cli/src/ui/components/AnsiOutput.test.tsx +0 -106
  488. package/packages/cli/src/ui/components/AnsiOutput.tsx +0 -50
  489. package/packages/cli/src/ui/components/ApiKeyInput.tsx +0 -95
  490. package/packages/cli/src/ui/components/AppHeader.test.tsx +0 -94
  491. package/packages/cli/src/ui/components/AppHeader.tsx +0 -76
  492. package/packages/cli/src/ui/components/ApprovalModeDialog.tsx +0 -182
  493. package/packages/cli/src/ui/components/AsciiArt.ts +0 -14
  494. package/packages/cli/src/ui/components/AutoAcceptIndicator.tsx +0 -58
  495. package/packages/cli/src/ui/components/Composer.test.tsx +0 -347
  496. package/packages/cli/src/ui/components/Composer.tsx +0 -116
  497. package/packages/cli/src/ui/components/ConfigInitDisplay.tsx +0 -56
  498. package/packages/cli/src/ui/components/ConsentPrompt.test.tsx +0 -119
  499. package/packages/cli/src/ui/components/ConsentPrompt.tsx +0 -51
  500. package/packages/cli/src/ui/components/ContextSummaryDisplay.test.tsx +0 -85
  501. package/packages/cli/src/ui/components/ContextSummaryDisplay.tsx +0 -143
  502. package/packages/cli/src/ui/components/ContextUsageDisplay.tsx +0 -34
  503. package/packages/cli/src/ui/components/DebugModeNotification.tsx +0 -39
  504. package/packages/cli/src/ui/components/DebugProfiler.tsx +0 -36
  505. package/packages/cli/src/ui/components/DialogManager.tsx +0 -321
  506. package/packages/cli/src/ui/components/EditorSettingsDialog.tsx +0 -195
  507. package/packages/cli/src/ui/components/ExitWarning.tsx +0 -29
  508. package/packages/cli/src/ui/components/FolderTrustDialog.test.tsx +0 -129
  509. package/packages/cli/src/ui/components/FolderTrustDialog.tsx +0 -110
  510. package/packages/cli/src/ui/components/Footer.test.tsx +0 -98
  511. package/packages/cli/src/ui/components/Footer.tsx +0 -124
  512. package/packages/cli/src/ui/components/GeminiRespondingSpinner.tsx +0 -67
  513. package/packages/cli/src/ui/components/Header.test.tsx +0 -84
  514. package/packages/cli/src/ui/components/Header.tsx +0 -158
  515. package/packages/cli/src/ui/components/Help.test.tsx +0 -83
  516. package/packages/cli/src/ui/components/Help.tsx +0 -188
  517. package/packages/cli/src/ui/components/HistoryItemDisplay.test.tsx +0 -287
  518. package/packages/cli/src/ui/components/HistoryItemDisplay.tsx +0 -202
  519. package/packages/cli/src/ui/components/IdeTrustChangeDialog.test.tsx +0 -85
  520. package/packages/cli/src/ui/components/IdeTrustChangeDialog.tsx +0 -50
  521. package/packages/cli/src/ui/components/InputPrompt.test.tsx +0 -2579
  522. package/packages/cli/src/ui/components/InputPrompt.tsx +0 -1203
  523. package/packages/cli/src/ui/components/KeyboardShortcuts.tsx +0 -124
  524. package/packages/cli/src/ui/components/LoadingIndicator.test.tsx +0 -311
  525. package/packages/cli/src/ui/components/LoadingIndicator.tsx +0 -90
  526. package/packages/cli/src/ui/components/LoopDetectionConfirmation.test.tsx +0 -39
  527. package/packages/cli/src/ui/components/LoopDetectionConfirmation.tsx +0 -97
  528. package/packages/cli/src/ui/components/MainContent.tsx +0 -80
  529. package/packages/cli/src/ui/components/MemoryUsageDisplay.tsx +0 -41
  530. package/packages/cli/src/ui/components/ModelDialog.test.tsx +0 -399
  531. package/packages/cli/src/ui/components/ModelDialog.tsx +0 -460
  532. package/packages/cli/src/ui/components/ModelStatsDisplay.test.tsx +0 -252
  533. package/packages/cli/src/ui/components/ModelStatsDisplay.tsx +0 -217
  534. package/packages/cli/src/ui/components/Notifications.tsx +0 -58
  535. package/packages/cli/src/ui/components/PermissionsModifyTrustDialog.test.tsx +0 -199
  536. package/packages/cli/src/ui/components/PermissionsModifyTrustDialog.tsx +0 -125
  537. package/packages/cli/src/ui/components/PlanSummaryDisplay.tsx +0 -41
  538. package/packages/cli/src/ui/components/PluginChoicePrompt.test.tsx +0 -243
  539. package/packages/cli/src/ui/components/PluginChoicePrompt.tsx +0 -195
  540. package/packages/cli/src/ui/components/PrepareLabel.test.tsx +0 -123
  541. package/packages/cli/src/ui/components/PrepareLabel.tsx +0 -116
  542. package/packages/cli/src/ui/components/QueuedMessageDisplay.test.tsx +0 -76
  543. package/packages/cli/src/ui/components/QueuedMessageDisplay.tsx +0 -47
  544. package/packages/cli/src/ui/components/QuittingDisplay.tsx +0 -39
  545. package/packages/cli/src/ui/components/QwenOAuthProgress.test.tsx +0 -611
  546. package/packages/cli/src/ui/components/QwenOAuthProgress.tsx +0 -316
  547. package/packages/cli/src/ui/components/SessionPicker.tsx +0 -251
  548. package/packages/cli/src/ui/components/SessionSummaryDisplay.test.tsx +0 -154
  549. package/packages/cli/src/ui/components/SessionSummaryDisplay.tsx +0 -51
  550. package/packages/cli/src/ui/components/SettingInputPrompt.test.tsx +0 -133
  551. package/packages/cli/src/ui/components/SettingInputPrompt.tsx +0 -157
  552. package/packages/cli/src/ui/components/SettingsDialog.test.tsx +0 -1638
  553. package/packages/cli/src/ui/components/SettingsDialog.tsx +0 -900
  554. package/packages/cli/src/ui/components/ShellConfirmationDialog.test.tsx +0 -53
  555. package/packages/cli/src/ui/components/ShellConfirmationDialog.tsx +0 -109
  556. package/packages/cli/src/ui/components/ShellInputPrompt.tsx +0 -57
  557. package/packages/cli/src/ui/components/ShellModeIndicator.tsx +0 -18
  558. package/packages/cli/src/ui/components/ShowMoreLines.tsx +0 -40
  559. package/packages/cli/src/ui/components/StandaloneSessionPicker.test.tsx +0 -624
  560. package/packages/cli/src/ui/components/StandaloneSessionPicker.tsx +0 -129
  561. package/packages/cli/src/ui/components/StatsDisplay.test.tsx +0 -401
  562. package/packages/cli/src/ui/components/StatsDisplay.tsx +0 -298
  563. package/packages/cli/src/ui/components/SuggestionsDisplay.tsx +0 -131
  564. package/packages/cli/src/ui/components/ThemeDialog.test.tsx +0 -108
  565. package/packages/cli/src/ui/components/ThemeDialog.tsx +0 -287
  566. package/packages/cli/src/ui/components/Tips.test.ts +0 -62
  567. package/packages/cli/src/ui/components/Tips.tsx +0 -62
  568. package/packages/cli/src/ui/components/TodoDisplay.test.tsx +0 -98
  569. package/packages/cli/src/ui/components/TodoDisplay.tsx +0 -72
  570. package/packages/cli/src/ui/components/ToolStatsDisplay.test.tsx +0 -180
  571. package/packages/cli/src/ui/components/ToolStatsDisplay.tsx +0 -234
  572. package/packages/cli/src/ui/components/UpdateNotification.tsx +0 -23
  573. package/packages/cli/src/ui/components/WelcomeBackDialog.tsx +0 -134
  574. package/packages/cli/src/ui/components/__snapshots__/Footer.test.tsx.snap +0 -5
  575. package/packages/cli/src/ui/components/__snapshots__/HistoryItemDisplay.test.tsx.snap +0 -139
  576. package/packages/cli/src/ui/components/__snapshots__/IDEContextDetailDisplay.test.tsx.snap +0 -24
  577. package/packages/cli/src/ui/components/__snapshots__/InputPrompt.test.tsx.snap +0 -57
  578. package/packages/cli/src/ui/components/__snapshots__/LoadingIndicator.test.tsx.snap +0 -6
  579. package/packages/cli/src/ui/components/__snapshots__/LoopDetectionConfirmation.test.tsx.snap +0 -16
  580. package/packages/cli/src/ui/components/__snapshots__/ModelStatsDisplay.test.tsx.snap +0 -121
  581. package/packages/cli/src/ui/components/__snapshots__/PrepareLabel.test.tsx.snap +0 -25
  582. package/packages/cli/src/ui/components/__snapshots__/SessionSummaryDisplay.test.tsx.snap +0 -32
  583. package/packages/cli/src/ui/components/__snapshots__/SettingsDialog.test.tsx.snap +0 -211
  584. package/packages/cli/src/ui/components/__snapshots__/ShellConfirmationDialog.test.tsx.snap +0 -21
  585. package/packages/cli/src/ui/components/__snapshots__/StatsDisplay.test.tsx.snap +0 -264
  586. package/packages/cli/src/ui/components/__snapshots__/ThemeDialog.test.tsx.snap +0 -38
  587. package/packages/cli/src/ui/components/__snapshots__/ToolStatsDisplay.test.tsx.snap +0 -91
  588. package/packages/cli/src/ui/components/extensions/ExtensionsManagerDialog.test.tsx +0 -153
  589. package/packages/cli/src/ui/components/extensions/ExtensionsManagerDialog.tsx +0 -530
  590. package/packages/cli/src/ui/components/extensions/__snapshots__/ExtensionsManagerDialog.test.tsx.snap +0 -45
  591. package/packages/cli/src/ui/components/extensions/index.ts +0 -9
  592. package/packages/cli/src/ui/components/extensions/steps/ActionSelectionStep.test.tsx +0 -109
  593. package/packages/cli/src/ui/components/extensions/steps/ActionSelectionStep.tsx +0 -102
  594. package/packages/cli/src/ui/components/extensions/steps/ExtensionDetailStep.tsx +0 -128
  595. package/packages/cli/src/ui/components/extensions/steps/ExtensionListStep.test.tsx +0 -134
  596. package/packages/cli/src/ui/components/extensions/steps/ExtensionListStep.tsx +0 -177
  597. package/packages/cli/src/ui/components/extensions/steps/ScopeSelectStep.tsx +0 -70
  598. package/packages/cli/src/ui/components/extensions/steps/UninstallConfirmStep.tsx +0 -65
  599. package/packages/cli/src/ui/components/extensions/steps/__snapshots__/ActionSelectionStep.test.tsx.snap +0 -33
  600. package/packages/cli/src/ui/components/extensions/steps/__snapshots__/ExtensionListStep.test.tsx.snap +0 -32
  601. package/packages/cli/src/ui/components/extensions/steps/index.ts +0 -11
  602. package/packages/cli/src/ui/components/extensions/types.ts +0 -89
  603. package/packages/cli/src/ui/components/mcp/MCPManagementDialog.tsx +0 -680
  604. package/packages/cli/src/ui/components/mcp/constants.ts +0 -47
  605. package/packages/cli/src/ui/components/mcp/index.ts +0 -30
  606. package/packages/cli/src/ui/components/mcp/steps/AuthenticateStep.tsx +0 -164
  607. package/packages/cli/src/ui/components/mcp/steps/DisableScopeSelectStep.tsx +0 -88
  608. package/packages/cli/src/ui/components/mcp/steps/ServerDetailStep.tsx +0 -233
  609. package/packages/cli/src/ui/components/mcp/steps/ServerListStep.tsx +0 -176
  610. package/packages/cli/src/ui/components/mcp/steps/ToolDetailStep.tsx +0 -139
  611. package/packages/cli/src/ui/components/mcp/steps/ToolListStep.tsx +0 -146
  612. package/packages/cli/src/ui/components/mcp/types.ts +0 -195
  613. package/packages/cli/src/ui/components/mcp/utils.test.ts +0 -159
  614. package/packages/cli/src/ui/components/mcp/utils.ts +0 -129
  615. package/packages/cli/src/ui/components/messages/AskUserQuestionDialog.test.tsx +0 -883
  616. package/packages/cli/src/ui/components/messages/AskUserQuestionDialog.tsx +0 -572
  617. package/packages/cli/src/ui/components/messages/CompressionMessage.test.tsx +0 -198
  618. package/packages/cli/src/ui/components/messages/CompressionMessage.tsx +0 -90
  619. package/packages/cli/src/ui/components/messages/ConversationMessages.tsx +0 -261
  620. package/packages/cli/src/ui/components/messages/DiffRenderer.test.tsx +0 -479
  621. package/packages/cli/src/ui/components/messages/DiffRenderer.tsx +0 -380
  622. package/packages/cli/src/ui/components/messages/InsightProgressMessage.tsx +0 -59
  623. package/packages/cli/src/ui/components/messages/StatusMessages.tsx +0 -105
  624. package/packages/cli/src/ui/components/messages/SummaryMessage.tsx +0 -59
  625. package/packages/cli/src/ui/components/messages/ToolConfirmationMessage.test.tsx +0 -250
  626. package/packages/cli/src/ui/components/messages/ToolConfirmationMessage.tsx +0 -437
  627. package/packages/cli/src/ui/components/messages/ToolGroupMessage.test.tsx +0 -360
  628. package/packages/cli/src/ui/components/messages/ToolGroupMessage.tsx +0 -151
  629. package/packages/cli/src/ui/components/messages/ToolMessage.test.tsx +0 -303
  630. package/packages/cli/src/ui/components/messages/ToolMessage.tsx +0 -498
  631. package/packages/cli/src/ui/components/messages/__snapshots__/ToolGroupMessage.test.tsx.snap +0 -108
  632. package/packages/cli/src/ui/components/shared/BaseSelectionList.test.tsx +0 -534
  633. package/packages/cli/src/ui/components/shared/BaseSelectionList.tsx +0 -182
  634. package/packages/cli/src/ui/components/shared/DescriptiveRadioButtonSelect.test.tsx +0 -97
  635. package/packages/cli/src/ui/components/shared/DescriptiveRadioButtonSelect.tsx +0 -74
  636. package/packages/cli/src/ui/components/shared/EnumSelector.test.tsx +0 -152
  637. package/packages/cli/src/ui/components/shared/EnumSelector.tsx +0 -87
  638. package/packages/cli/src/ui/components/shared/MaxSizedBox.test.tsx +0 -425
  639. package/packages/cli/src/ui/components/shared/MaxSizedBox.tsx +0 -628
  640. package/packages/cli/src/ui/components/shared/RadioButtonSelect.test.tsx +0 -198
  641. package/packages/cli/src/ui/components/shared/RadioButtonSelect.tsx +0 -91
  642. package/packages/cli/src/ui/components/shared/ScopeSelector.tsx +0 -59
  643. package/packages/cli/src/ui/components/shared/TextInput.tsx +0 -197
  644. package/packages/cli/src/ui/components/shared/__snapshots__/DescriptiveRadioButtonSelect.test.tsx.snap +0 -21
  645. package/packages/cli/src/ui/components/shared/__snapshots__/EnumSelector.test.tsx.snap +0 -9
  646. package/packages/cli/src/ui/components/shared/text-buffer.test.ts +0 -1951
  647. package/packages/cli/src/ui/components/shared/text-buffer.ts +0 -2371
  648. package/packages/cli/src/ui/components/shared/vim-buffer-actions.test.ts +0 -1119
  649. package/packages/cli/src/ui/components/shared/vim-buffer-actions.ts +0 -813
  650. package/packages/cli/src/ui/components/subagents/constants.ts +0 -71
  651. package/packages/cli/src/ui/components/subagents/create/AgentCreationWizard.tsx +0 -299
  652. package/packages/cli/src/ui/components/subagents/create/ColorSelector.tsx +0 -85
  653. package/packages/cli/src/ui/components/subagents/create/CreationSummary.tsx +0 -331
  654. package/packages/cli/src/ui/components/subagents/create/DescriptionInput.tsx +0 -177
  655. package/packages/cli/src/ui/components/subagents/create/GenerationMethodSelector.tsx +0 -63
  656. package/packages/cli/src/ui/components/subagents/create/LocationSelector.tsx +0 -58
  657. package/packages/cli/src/ui/components/subagents/create/TextEntryStep.tsx +0 -78
  658. package/packages/cli/src/ui/components/subagents/create/ToolSelector.tsx +0 -253
  659. package/packages/cli/src/ui/components/subagents/index.ts +0 -14
  660. package/packages/cli/src/ui/components/subagents/manage/ActionSelectionStep.tsx +0 -103
  661. package/packages/cli/src/ui/components/subagents/manage/AgentDeleteStep.tsx +0 -62
  662. package/packages/cli/src/ui/components/subagents/manage/AgentEditStep.tsx +0 -124
  663. package/packages/cli/src/ui/components/subagents/manage/AgentSelectionStep.tsx +0 -449
  664. package/packages/cli/src/ui/components/subagents/manage/AgentViewerStep.tsx +0 -66
  665. package/packages/cli/src/ui/components/subagents/manage/AgentsManagerDialog.tsx +0 -341
  666. package/packages/cli/src/ui/components/subagents/reducers.tsx +0 -190
  667. package/packages/cli/src/ui/components/subagents/runtime/AgentExecutionDisplay.tsx +0 -550
  668. package/packages/cli/src/ui/components/subagents/types.ts +0 -133
  669. package/packages/cli/src/ui/components/subagents/utils.ts +0 -102
  670. package/packages/cli/src/ui/components/views/ExtensionsList.test.tsx +0 -100
  671. package/packages/cli/src/ui/components/views/ExtensionsList.tsx +0 -80
  672. package/packages/cli/src/ui/components/views/McpStatus.test.tsx +0 -163
  673. package/packages/cli/src/ui/components/views/McpStatus.tsx +0 -298
  674. package/packages/cli/src/ui/components/views/SkillsList.tsx +0 -36
  675. package/packages/cli/src/ui/components/views/ToolsList.test.tsx +0 -58
  676. package/packages/cli/src/ui/components/views/ToolsList.tsx +0 -53
  677. package/packages/cli/src/ui/components/views/__snapshots__/McpStatus.test.tsx.snap +0 -166
  678. package/packages/cli/src/ui/components/views/__snapshots__/ToolsList.test.tsx.snap +0 -29
  679. package/packages/cli/src/ui/constants.ts +0 -29
  680. package/packages/cli/src/ui/contexts/AppContext.tsx +0 -22
  681. package/packages/cli/src/ui/contexts/ConfigContext.tsx +0 -18
  682. package/packages/cli/src/ui/contexts/KeypressContext.test.tsx +0 -1756
  683. package/packages/cli/src/ui/contexts/KeypressContext.tsx +0 -932
  684. package/packages/cli/src/ui/contexts/OverflowContext.tsx +0 -88
  685. package/packages/cli/src/ui/contexts/SessionContext.test.tsx +0 -221
  686. package/packages/cli/src/ui/contexts/SessionContext.tsx +0 -281
  687. package/packages/cli/src/ui/contexts/SettingsContext.tsx +0 -20
  688. package/packages/cli/src/ui/contexts/ShellFocusContext.tsx +0 -11
  689. package/packages/cli/src/ui/contexts/StreamingContext.tsx +0 -22
  690. package/packages/cli/src/ui/contexts/UIActionsContext.tsx +0 -100
  691. package/packages/cli/src/ui/contexts/UIStateContext.tsx +0 -144
  692. package/packages/cli/src/ui/contexts/VimModeContext.tsx +0 -80
  693. package/packages/cli/src/ui/editors/editorSettingsManager.ts +0 -67
  694. package/packages/cli/src/ui/hooks/atCommandProcessor.test.ts +0 -1136
  695. package/packages/cli/src/ui/hooks/atCommandProcessor.ts +0 -434
  696. package/packages/cli/src/ui/hooks/keyToAnsi.ts +0 -77
  697. package/packages/cli/src/ui/hooks/shellCommandProcessor.test.ts +0 -723
  698. package/packages/cli/src/ui/hooks/shellCommandProcessor.ts +0 -382
  699. package/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts +0 -1083
  700. package/packages/cli/src/ui/hooks/slashCommandProcessor.ts +0 -714
  701. package/packages/cli/src/ui/hooks/useAgentsManagerDialog.ts +0 -32
  702. package/packages/cli/src/ui/hooks/useApprovalModeCommand.ts +0 -57
  703. package/packages/cli/src/ui/hooks/useAtCompletion.test.ts +0 -508
  704. package/packages/cli/src/ui/hooks/useAtCompletion.ts +0 -239
  705. package/packages/cli/src/ui/hooks/useAttentionNotifications.test.ts +0 -199
  706. package/packages/cli/src/ui/hooks/useAttentionNotifications.ts +0 -71
  707. package/packages/cli/src/ui/hooks/useAutoAcceptIndicator.test.ts +0 -561
  708. package/packages/cli/src/ui/hooks/useAutoAcceptIndicator.ts +0 -85
  709. package/packages/cli/src/ui/hooks/useBracketedPaste.ts +0 -37
  710. package/packages/cli/src/ui/hooks/useCodingPlanUpdates.test.ts +0 -658
  711. package/packages/cli/src/ui/hooks/useCodingPlanUpdates.ts +0 -233
  712. package/packages/cli/src/ui/hooks/useCommandCompletion.test.ts +0 -517
  713. package/packages/cli/src/ui/hooks/useCommandCompletion.tsx +0 -243
  714. package/packages/cli/src/ui/hooks/useCommandMigration.ts +0 -51
  715. package/packages/cli/src/ui/hooks/useCompletion.ts +0 -126
  716. package/packages/cli/src/ui/hooks/useDialogClose.ts +0 -103
  717. package/packages/cli/src/ui/hooks/useEditorSettings.test.ts +0 -284
  718. package/packages/cli/src/ui/hooks/useEditorSettings.ts +0 -75
  719. package/packages/cli/src/ui/hooks/useExtensionUpdates.test.ts +0 -608
  720. package/packages/cli/src/ui/hooks/useExtensionUpdates.ts +0 -340
  721. package/packages/cli/src/ui/hooks/useExtensionsManagerDialog.ts +0 -33
  722. package/packages/cli/src/ui/hooks/useFeedbackDialog.ts +0 -206
  723. package/packages/cli/src/ui/hooks/useFocus.test.ts +0 -145
  724. package/packages/cli/src/ui/hooks/useFocus.ts +0 -62
  725. package/packages/cli/src/ui/hooks/useFolderTrust.test.ts +0 -211
  726. package/packages/cli/src/ui/hooks/useFolderTrust.ts +0 -80
  727. package/packages/cli/src/ui/hooks/useGeminiStream.test.tsx +0 -2946
  728. package/packages/cli/src/ui/hooks/useGeminiStream.ts +0 -1625
  729. package/packages/cli/src/ui/hooks/useGitBranchName.test.ts +0 -238
  730. package/packages/cli/src/ui/hooks/useGitBranchName.ts +0 -78
  731. package/packages/cli/src/ui/hooks/useHistoryManager.test.ts +0 -202
  732. package/packages/cli/src/ui/hooks/useHistoryManager.ts +0 -111
  733. package/packages/cli/src/ui/hooks/useIdeTrustListener.test.ts +0 -226
  734. package/packages/cli/src/ui/hooks/useIdeTrustListener.ts +0 -90
  735. package/packages/cli/src/ui/hooks/useInitializationAuthError.ts +0 -47
  736. package/packages/cli/src/ui/hooks/useInputHistory.test.ts +0 -261
  737. package/packages/cli/src/ui/hooks/useInputHistory.ts +0 -111
  738. package/packages/cli/src/ui/hooks/useInputHistoryStore.test.ts +0 -293
  739. package/packages/cli/src/ui/hooks/useInputHistoryStore.ts +0 -118
  740. package/packages/cli/src/ui/hooks/useKeypress.test.ts +0 -314
  741. package/packages/cli/src/ui/hooks/useKeypress.ts +0 -36
  742. package/packages/cli/src/ui/hooks/useKittyKeyboardProtocol.ts +0 -31
  743. package/packages/cli/src/ui/hooks/useLaunchEditor.ts +0 -125
  744. package/packages/cli/src/ui/hooks/useLoadingIndicator.test.ts +0 -136
  745. package/packages/cli/src/ui/hooks/useLoadingIndicator.ts +0 -61
  746. package/packages/cli/src/ui/hooks/useLogger.ts +0 -37
  747. package/packages/cli/src/ui/hooks/useMcpDialog.ts +0 -31
  748. package/packages/cli/src/ui/hooks/useMemoryMonitor.test.ts +0 -71
  749. package/packages/cli/src/ui/hooks/useMemoryMonitor.ts +0 -41
  750. package/packages/cli/src/ui/hooks/useMessageQueue.test.ts +0 -235
  751. package/packages/cli/src/ui/hooks/useMessageQueue.ts +0 -75
  752. package/packages/cli/src/ui/hooks/useModelCommand.test.ts +0 -42
  753. package/packages/cli/src/ui/hooks/useModelCommand.ts +0 -31
  754. package/packages/cli/src/ui/hooks/usePermissionsModifyTrust.test.ts +0 -263
  755. package/packages/cli/src/ui/hooks/usePermissionsModifyTrust.ts +0 -128
  756. package/packages/cli/src/ui/hooks/usePhraseCycler.test.ts +0 -192
  757. package/packages/cli/src/ui/hooks/usePhraseCycler.ts +0 -82
  758. package/packages/cli/src/ui/hooks/useQwenAuth.test.ts +0 -425
  759. package/packages/cli/src/ui/hooks/useQwenAuth.ts +0 -108
  760. package/packages/cli/src/ui/hooks/useReactToolScheduler.ts +0 -315
  761. package/packages/cli/src/ui/hooks/useRefreshMemoryCommand.ts +0 -7
  762. package/packages/cli/src/ui/hooks/useResumeCommand.test.ts +0 -190
  763. package/packages/cli/src/ui/hooks/useResumeCommand.ts +0 -82
  764. package/packages/cli/src/ui/hooks/useReverseSearchCompletion.test.tsx +0 -260
  765. package/packages/cli/src/ui/hooks/useReverseSearchCompletion.tsx +0 -155
  766. package/packages/cli/src/ui/hooks/useSelectionList.test.ts +0 -980
  767. package/packages/cli/src/ui/hooks/useSelectionList.ts +0 -376
  768. package/packages/cli/src/ui/hooks/useSessionPicker.ts +0 -279
  769. package/packages/cli/src/ui/hooks/useSettingsCommand.ts +0 -25
  770. package/packages/cli/src/ui/hooks/useShellHistory.test.ts +0 -257
  771. package/packages/cli/src/ui/hooks/useShellHistory.ts +0 -143
  772. package/packages/cli/src/ui/hooks/useShowMemoryCommand.ts +0 -73
  773. package/packages/cli/src/ui/hooks/useSlashCompletion.test.ts +0 -897
  774. package/packages/cli/src/ui/hooks/useSlashCompletion.ts +0 -555
  775. package/packages/cli/src/ui/hooks/useStateAndRef.ts +0 -36
  776. package/packages/cli/src/ui/hooks/useSubagentCreateDialog.ts +0 -26
  777. package/packages/cli/src/ui/hooks/useTerminalSize.ts +0 -34
  778. package/packages/cli/src/ui/hooks/useThemeCommand.ts +0 -112
  779. package/packages/cli/src/ui/hooks/useTimer.test.ts +0 -120
  780. package/packages/cli/src/ui/hooks/useTimer.ts +0 -65
  781. package/packages/cli/src/ui/hooks/useTomlMigration.ts +0 -0
  782. package/packages/cli/src/ui/hooks/useToolScheduler.test.ts +0 -781
  783. package/packages/cli/src/ui/hooks/useWelcomeBack.ts +0 -119
  784. package/packages/cli/src/ui/hooks/vim.test.ts +0 -1691
  785. package/packages/cli/src/ui/hooks/vim.ts +0 -790
  786. package/packages/cli/src/ui/keyMatchers.test.ts +0 -375
  787. package/packages/cli/src/ui/keyMatchers.ts +0 -105
  788. package/packages/cli/src/ui/layouts/DefaultAppLayout.tsx +0 -40
  789. package/packages/cli/src/ui/layouts/ScreenReaderAppLayout.tsx +0 -41
  790. package/packages/cli/src/ui/models/availableModels.test.ts +0 -186
  791. package/packages/cli/src/ui/models/availableModels.ts +0 -129
  792. package/packages/cli/src/ui/noninteractive/nonInteractiveUi.ts +0 -30
  793. package/packages/cli/src/ui/semantic-colors.ts +0 -26
  794. package/packages/cli/src/ui/state/extensions.ts +0 -90
  795. package/packages/cli/src/ui/textConstants.ts +0 -13
  796. package/packages/cli/src/ui/themes/ansi-light.ts +0 -152
  797. package/packages/cli/src/ui/themes/ansi.ts +0 -161
  798. package/packages/cli/src/ui/themes/atom-one-dark.ts +0 -147
  799. package/packages/cli/src/ui/themes/ayu-light.ts +0 -139
  800. package/packages/cli/src/ui/themes/ayu.ts +0 -113
  801. package/packages/cli/src/ui/themes/color-utils.test.ts +0 -221
  802. package/packages/cli/src/ui/themes/color-utils.ts +0 -235
  803. package/packages/cli/src/ui/themes/default-light.ts +0 -106
  804. package/packages/cli/src/ui/themes/default.ts +0 -149
  805. package/packages/cli/src/ui/themes/dracula.ts +0 -124
  806. package/packages/cli/src/ui/themes/github-dark.ts +0 -147
  807. package/packages/cli/src/ui/themes/github-light.ts +0 -149
  808. package/packages/cli/src/ui/themes/googlecode.ts +0 -146
  809. package/packages/cli/src/ui/themes/no-color.ts +0 -131
  810. package/packages/cli/src/ui/themes/qwen-dark.ts +0 -115
  811. package/packages/cli/src/ui/themes/qwen-light.ts +0 -141
  812. package/packages/cli/src/ui/themes/semantic-tokens.ts +0 -140
  813. package/packages/cli/src/ui/themes/shades-of-purple.ts +0 -352
  814. package/packages/cli/src/ui/themes/theme-manager.test.ts +0 -173
  815. package/packages/cli/src/ui/themes/theme-manager.ts +0 -344
  816. package/packages/cli/src/ui/themes/theme.test.ts +0 -97
  817. package/packages/cli/src/ui/themes/theme.ts +0 -505
  818. package/packages/cli/src/ui/themes/xcode.ts +0 -154
  819. package/packages/cli/src/ui/types.ts +0 -463
  820. package/packages/cli/src/ui/utils/CodeColorizer.tsx +0 -224
  821. package/packages/cli/src/ui/utils/InlineMarkdownRenderer.tsx +0 -180
  822. package/packages/cli/src/ui/utils/MarkdownDisplay.test.tsx +0 -236
  823. package/packages/cli/src/ui/utils/MarkdownDisplay.tsx +0 -423
  824. package/packages/cli/src/ui/utils/TableRenderer.tsx +0 -158
  825. package/packages/cli/src/ui/utils/__snapshots__/MarkdownDisplay.test.tsx.snap +0 -187
  826. package/packages/cli/src/ui/utils/clipboardUtils.test.ts +0 -136
  827. package/packages/cli/src/ui/utils/clipboardUtils.ts +0 -153
  828. package/packages/cli/src/ui/utils/commandUtils.test.ts +0 -489
  829. package/packages/cli/src/ui/utils/commandUtils.ts +0 -174
  830. package/packages/cli/src/ui/utils/computeStats.test.ts +0 -295
  831. package/packages/cli/src/ui/utils/computeStats.ts +0 -86
  832. package/packages/cli/src/ui/utils/displayUtils.test.ts +0 -83
  833. package/packages/cli/src/ui/utils/displayUtils.ts +0 -35
  834. package/packages/cli/src/ui/utils/export/collect.ts +0 -266
  835. package/packages/cli/src/ui/utils/export/formatters/html.ts +0 -83
  836. package/packages/cli/src/ui/utils/export/formatters/json.ts +0 -15
  837. package/packages/cli/src/ui/utils/export/formatters/jsonl.ts +0 -31
  838. package/packages/cli/src/ui/utils/export/formatters/markdown.ts +0 -225
  839. package/packages/cli/src/ui/utils/export/index.ts +0 -18
  840. package/packages/cli/src/ui/utils/export/normalize.ts +0 -324
  841. package/packages/cli/src/ui/utils/export/types.ts +0 -54
  842. package/packages/cli/src/ui/utils/export/utils.ts +0 -13
  843. package/packages/cli/src/ui/utils/formatters.test.ts +0 -157
  844. package/packages/cli/src/ui/utils/formatters.ts +0 -97
  845. package/packages/cli/src/ui/utils/highlight.test.ts +0 -136
  846. package/packages/cli/src/ui/utils/highlight.ts +0 -103
  847. package/packages/cli/src/ui/utils/isNarrowWidth.ts +0 -9
  848. package/packages/cli/src/ui/utils/kittyProtocolDetector.ts +0 -116
  849. package/packages/cli/src/ui/utils/markdownUtilities.test.ts +0 -50
  850. package/packages/cli/src/ui/utils/markdownUtilities.ts +0 -125
  851. package/packages/cli/src/ui/utils/platformConstants.ts +0 -87
  852. package/packages/cli/src/ui/utils/resumeHistoryUtils.test.ts +0 -289
  853. package/packages/cli/src/ui/utils/resumeHistoryUtils.ts +0 -455
  854. package/packages/cli/src/ui/utils/sessionPickerUtils.test.ts +0 -45
  855. package/packages/cli/src/ui/utils/sessionPickerUtils.ts +0 -59
  856. package/packages/cli/src/ui/utils/terminalSetup.ts +0 -393
  857. package/packages/cli/src/ui/utils/textUtils.test.ts +0 -170
  858. package/packages/cli/src/ui/utils/textUtils.ts +0 -216
  859. package/packages/cli/src/ui/utils/updateCheck.test.ts +0 -163
  860. package/packages/cli/src/ui/utils/updateCheck.ts +0 -104
  861. package/packages/cli/src/utils/acpModelUtils.test.ts +0 -42
  862. package/packages/cli/src/utils/acpModelUtils.ts +0 -61
  863. package/packages/cli/src/utils/attentionNotification.test.ts +0 -72
  864. package/packages/cli/src/utils/attentionNotification.ts +0 -51
  865. package/packages/cli/src/utils/checks.ts +0 -28
  866. package/packages/cli/src/utils/cleanup.test.ts +0 -68
  867. package/packages/cli/src/utils/cleanup.ts +0 -37
  868. package/packages/cli/src/utils/commands.test.ts +0 -140
  869. package/packages/cli/src/utils/commands.ts +0 -71
  870. package/packages/cli/src/utils/commentJson.test.ts +0 -186
  871. package/packages/cli/src/utils/commentJson.ts +0 -70
  872. package/packages/cli/src/utils/deepMerge.test.ts +0 -163
  873. package/packages/cli/src/utils/deepMerge.ts +0 -90
  874. package/packages/cli/src/utils/dialogScopeUtils.ts +0 -69
  875. package/packages/cli/src/utils/envVarResolver.test.ts +0 -297
  876. package/packages/cli/src/utils/envVarResolver.ts +0 -126
  877. package/packages/cli/src/utils/errors.test.ts +0 -681
  878. package/packages/cli/src/utils/errors.ts +0 -197
  879. package/packages/cli/src/utils/events.ts +0 -15
  880. package/packages/cli/src/utils/gitUtils.test.ts +0 -248
  881. package/packages/cli/src/utils/gitUtils.ts +0 -143
  882. package/packages/cli/src/utils/handleAutoUpdate.test.ts +0 -274
  883. package/packages/cli/src/utils/handleAutoUpdate.ts +0 -152
  884. package/packages/cli/src/utils/installationInfo.test.ts +0 -325
  885. package/packages/cli/src/utils/installationInfo.ts +0 -181
  886. package/packages/cli/src/utils/languageUtils.test.ts +0 -478
  887. package/packages/cli/src/utils/languageUtils.ts +0 -191
  888. package/packages/cli/src/utils/math.ts +0 -15
  889. package/packages/cli/src/utils/modelConfigUtils.test.ts +0 -727
  890. package/packages/cli/src/utils/modelConfigUtils.ts +0 -159
  891. package/packages/cli/src/utils/nonInteractiveHelpers.test.ts +0 -1297
  892. package/packages/cli/src/utils/nonInteractiveHelpers.ts +0 -666
  893. package/packages/cli/src/utils/package.ts +0 -38
  894. package/packages/cli/src/utils/processUtils.test.ts +0 -22
  895. package/packages/cli/src/utils/processUtils.ts +0 -20
  896. package/packages/cli/src/utils/readStdin.test.ts +0 -112
  897. package/packages/cli/src/utils/readStdin.ts +0 -70
  898. package/packages/cli/src/utils/relaunch.test.ts +0 -335
  899. package/packages/cli/src/utils/relaunch.ts +0 -70
  900. package/packages/cli/src/utils/resolvePath.ts +0 -21
  901. package/packages/cli/src/utils/sandbox-macos-permissive-closed.sb +0 -32
  902. package/packages/cli/src/utils/sandbox-macos-permissive-open.sb +0 -25
  903. package/packages/cli/src/utils/sandbox-macos-permissive-proxied.sb +0 -37
  904. package/packages/cli/src/utils/sandbox-macos-restrictive-closed.sb +0 -93
  905. package/packages/cli/src/utils/sandbox-macos-restrictive-open.sb +0 -96
  906. package/packages/cli/src/utils/sandbox-macos-restrictive-proxied.sb +0 -98
  907. package/packages/cli/src/utils/sandbox.ts +0 -984
  908. package/packages/cli/src/utils/settingsUtils.test.ts +0 -1154
  909. package/packages/cli/src/utils/settingsUtils.ts +0 -646
  910. package/packages/cli/src/utils/spawnWrapper.ts +0 -9
  911. package/packages/cli/src/utils/startupWarnings.test.ts +0 -76
  912. package/packages/cli/src/utils/startupWarnings.ts +0 -40
  913. package/packages/cli/src/utils/stdioHelpers.ts +0 -41
  914. package/packages/cli/src/utils/systemInfo.test.ts +0 -337
  915. package/packages/cli/src/utils/systemInfo.ts +0 -181
  916. package/packages/cli/src/utils/systemInfoFields.test.ts +0 -79
  917. package/packages/cli/src/utils/systemInfoFields.ts +0 -143
  918. package/packages/cli/src/utils/updateEventEmitter.ts +0 -13
  919. package/packages/cli/src/utils/userStartupWarnings.test.ts +0 -112
  920. package/packages/cli/src/utils/userStartupWarnings.ts +0 -96
  921. package/packages/cli/src/utils/version.ts +0 -12
  922. package/packages/cli/src/utils/windowTitle.test.ts +0 -59
  923. package/packages/cli/src/utils/windowTitle.ts +0 -22
  924. package/packages/cli/src/utils/writeWithBackup.test.ts +0 -232
  925. package/packages/cli/src/utils/writeWithBackup.ts +0 -169
  926. package/packages/cli/src/validateNonInterActiveAuth.test.ts +0 -557
  927. package/packages/cli/src/validateNonInterActiveAuth.ts +0 -83
  928. package/packages/cli/test-setup.ts +0 -12
  929. package/packages/cli/tsconfig.json +0 -30
  930. package/packages/cli/vitest.config.ts +0 -57
  931. package/packages/core/index.ts +0 -7
  932. package/packages/core/package.json +0 -96
  933. package/packages/core/scripts/postinstall.js +0 -179
  934. package/packages/core/scripts/postinstall.js.backup +0 -1
  935. package/packages/core/src/__mocks__/fs/promises.ts +0 -48
  936. package/packages/core/src/config/config.test.ts +0 -1501
  937. package/packages/core/src/config/config.ts +0 -1916
  938. package/packages/core/src/config/constants.ts +0 -22
  939. package/packages/core/src/config/models.ts +0 -10
  940. package/packages/core/src/config/storage.test.ts +0 -42
  941. package/packages/core/src/config/storage.ts +0 -143
  942. package/packages/core/src/confirmation-bus/message-bus.ts +0 -125
  943. package/packages/core/src/confirmation-bus/types.ts +0 -128
  944. package/packages/core/src/core/__snapshots__/prompts.test.ts.snap +0 -3490
  945. package/packages/core/src/core/__tests__/openaiTimeoutHandling.test.ts +0 -386
  946. package/packages/core/src/core/__tests__/orphanedToolCallsTest.ts +0 -125
  947. package/packages/core/src/core/anthropicContentGenerator/anthropicContentGenerator.test.ts +0 -524
  948. package/packages/core/src/core/anthropicContentGenerator/anthropicContentGenerator.ts +0 -514
  949. package/packages/core/src/core/anthropicContentGenerator/converter.test.ts +0 -946
  950. package/packages/core/src/core/anthropicContentGenerator/converter.ts +0 -581
  951. package/packages/core/src/core/anthropicContentGenerator/index.ts +0 -21
  952. package/packages/core/src/core/baseLlmClient.test.ts +0 -447
  953. package/packages/core/src/core/baseLlmClient.ts +0 -191
  954. package/packages/core/src/core/client.test.ts +0 -2368
  955. package/packages/core/src/core/client.ts +0 -785
  956. package/packages/core/src/core/contentGenerator.test.ts +0 -113
  957. package/packages/core/src/core/contentGenerator.ts +0 -357
  958. package/packages/core/src/core/coreToolScheduler.test.ts +0 -2814
  959. package/packages/core/src/core/coreToolScheduler.ts +0 -1406
  960. package/packages/core/src/core/geminiChat.test.ts +0 -1721
  961. package/packages/core/src/core/geminiChat.ts +0 -746
  962. package/packages/core/src/core/geminiContentGenerator/geminiContentGenerator.test.ts +0 -371
  963. package/packages/core/src/core/geminiContentGenerator/geminiContentGenerator.ts +0 -303
  964. package/packages/core/src/core/geminiContentGenerator/index.test.ts +0 -41
  965. package/packages/core/src/core/geminiContentGenerator/index.ts +0 -53
  966. package/packages/core/src/core/geminiRequest.test.ts +0 -85
  967. package/packages/core/src/core/geminiRequest.ts +0 -19
  968. package/packages/core/src/core/logger.test.ts +0 -704
  969. package/packages/core/src/core/logger.ts +0 -462
  970. package/packages/core/src/core/loggingContentGenerator/index.ts +0 -7
  971. package/packages/core/src/core/loggingContentGenerator/loggingContentGenerator.test.ts +0 -397
  972. package/packages/core/src/core/loggingContentGenerator/loggingContentGenerator.ts +0 -510
  973. package/packages/core/src/core/modalityDefaults.test.ts +0 -213
  974. package/packages/core/src/core/modalityDefaults.ts +0 -94
  975. package/packages/core/src/core/nonInteractiveToolExecutor.test.ts +0 -373
  976. package/packages/core/src/core/nonInteractiveToolExecutor.ts +0 -52
  977. package/packages/core/src/core/openaiContentGenerator/constants.ts +0 -8
  978. package/packages/core/src/core/openaiContentGenerator/converter.test.ts +0 -2361
  979. package/packages/core/src/core/openaiContentGenerator/converter.ts +0 -1359
  980. package/packages/core/src/core/openaiContentGenerator/errorHandler.test.ts +0 -355
  981. package/packages/core/src/core/openaiContentGenerator/errorHandler.ts +0 -140
  982. package/packages/core/src/core/openaiContentGenerator/index.ts +0 -94
  983. package/packages/core/src/core/openaiContentGenerator/openaiContentGenerator.test.ts +0 -405
  984. package/packages/core/src/core/openaiContentGenerator/openaiContentGenerator.ts +0 -168
  985. package/packages/core/src/core/openaiContentGenerator/pipeline.test.ts +0 -1475
  986. package/packages/core/src/core/openaiContentGenerator/pipeline.ts +0 -490
  987. package/packages/core/src/core/openaiContentGenerator/provider/README.md +0 -61
  988. package/packages/core/src/core/openaiContentGenerator/provider/dashscope.test.ts +0 -1014
  989. package/packages/core/src/core/openaiContentGenerator/provider/dashscope.ts +0 -365
  990. package/packages/core/src/core/openaiContentGenerator/provider/deepseek.test.ts +0 -68
  991. package/packages/core/src/core/openaiContentGenerator/provider/deepseek.ts +0 -33
  992. package/packages/core/src/core/openaiContentGenerator/provider/default.test.ts +0 -308
  993. package/packages/core/src/core/openaiContentGenerator/provider/default.ts +0 -78
  994. package/packages/core/src/core/openaiContentGenerator/provider/index.ts +0 -11
  995. package/packages/core/src/core/openaiContentGenerator/provider/modelscope.test.ts +0 -96
  996. package/packages/core/src/core/openaiContentGenerator/provider/modelscope.ts +0 -32
  997. package/packages/core/src/core/openaiContentGenerator/provider/openrouter.test.ts +0 -221
  998. package/packages/core/src/core/openaiContentGenerator/provider/openrouter.ts +0 -31
  999. package/packages/core/src/core/openaiContentGenerator/provider/types.ts +0 -35
  1000. package/packages/core/src/core/openaiContentGenerator/streamingToolCallParser.test.ts +0 -864
  1001. package/packages/core/src/core/openaiContentGenerator/streamingToolCallParser.ts +0 -442
  1002. package/packages/core/src/core/prompts.test.ts +0 -617
  1003. package/packages/core/src/core/prompts.ts +0 -1064
  1004. package/packages/core/src/core/tokenLimits.test.ts +0 -331
  1005. package/packages/core/src/core/tokenLimits.ts +0 -216
  1006. package/packages/core/src/core/turn.test.ts +0 -1013
  1007. package/packages/core/src/core/turn.ts +0 -418
  1008. package/packages/core/src/extension/claude-converter.test.ts +0 -436
  1009. package/packages/core/src/extension/claude-converter.ts +0 -776
  1010. package/packages/core/src/extension/extensionManager.test.ts +0 -760
  1011. package/packages/core/src/extension/extensionManager.ts +0 -1290
  1012. package/packages/core/src/extension/extensionSettings.test.ts +0 -730
  1013. package/packages/core/src/extension/extensionSettings.ts +0 -319
  1014. package/packages/core/src/extension/gemini-converter.test.ts +0 -177
  1015. package/packages/core/src/extension/gemini-converter.ts +0 -234
  1016. package/packages/core/src/extension/github.test.ts +0 -485
  1017. package/packages/core/src/extension/github.ts +0 -457
  1018. package/packages/core/src/extension/index.ts +0 -6
  1019. package/packages/core/src/extension/marketplace.test.ts +0 -282
  1020. package/packages/core/src/extension/marketplace.ts +0 -279
  1021. package/packages/core/src/extension/override.test.ts +0 -110
  1022. package/packages/core/src/extension/override.ts +0 -102
  1023. package/packages/core/src/extension/settings.test.ts +0 -138
  1024. package/packages/core/src/extension/settings.ts +0 -149
  1025. package/packages/core/src/extension/storage.test.ts +0 -100
  1026. package/packages/core/src/extension/storage.ts +0 -50
  1027. package/packages/core/src/extension/variableSchema.ts +0 -43
  1028. package/packages/core/src/extension/variables.test.ts +0 -18
  1029. package/packages/core/src/extension/variables.ts +0 -72
  1030. package/packages/core/src/hooks/hookAggregator.test.ts +0 -618
  1031. package/packages/core/src/hooks/hookAggregator.ts +0 -369
  1032. package/packages/core/src/hooks/hookEventHandler.test.ts +0 -278
  1033. package/packages/core/src/hooks/hookEventHandler.ts +0 -192
  1034. package/packages/core/src/hooks/hookPlanner.test.ts +0 -366
  1035. package/packages/core/src/hooks/hookPlanner.ts +0 -146
  1036. package/packages/core/src/hooks/hookRegistry.test.ts +0 -636
  1037. package/packages/core/src/hooks/hookRegistry.ts +0 -353
  1038. package/packages/core/src/hooks/hookRunner.test.ts +0 -684
  1039. package/packages/core/src/hooks/hookRunner.ts +0 -427
  1040. package/packages/core/src/hooks/hookSystem.test.ts +0 -328
  1041. package/packages/core/src/hooks/hookSystem.ts +0 -103
  1042. package/packages/core/src/hooks/index.ts +0 -22
  1043. package/packages/core/src/hooks/trustedHooks.ts +0 -118
  1044. package/packages/core/src/hooks/types.ts +0 -678
  1045. package/packages/core/src/ide/constants.ts +0 -10
  1046. package/packages/core/src/ide/detect-ide.test.ts +0 -137
  1047. package/packages/core/src/ide/detect-ide.ts +0 -93
  1048. package/packages/core/src/ide/ide-client.test.ts +0 -764
  1049. package/packages/core/src/ide/ide-client.ts +0 -983
  1050. package/packages/core/src/ide/ide-installer.test.ts +0 -178
  1051. package/packages/core/src/ide/ide-installer.ts +0 -162
  1052. package/packages/core/src/ide/ideContext.test.ts +0 -453
  1053. package/packages/core/src/ide/ideContext.ts +0 -124
  1054. package/packages/core/src/ide/process-utils.test.ts +0 -158
  1055. package/packages/core/src/ide/process-utils.ts +0 -219
  1056. package/packages/core/src/ide/types.ts +0 -148
  1057. package/packages/core/src/index.test.ts +0 -13
  1058. package/packages/core/src/index.ts +0 -309
  1059. package/packages/core/src/lsp/LspConfigLoader.test.ts +0 -90
  1060. package/packages/core/src/lsp/LspConfigLoader.ts +0 -500
  1061. package/packages/core/src/lsp/LspConnectionFactory.ts +0 -395
  1062. package/packages/core/src/lsp/LspLanguageDetector.ts +0 -226
  1063. package/packages/core/src/lsp/LspResponseNormalizer.ts +0 -917
  1064. package/packages/core/src/lsp/LspServerManager.ts +0 -720
  1065. package/packages/core/src/lsp/NativeLspClient.ts +0 -259
  1066. package/packages/core/src/lsp/NativeLspService.integration.test.ts +0 -769
  1067. package/packages/core/src/lsp/NativeLspService.test.ts +0 -132
  1068. package/packages/core/src/lsp/NativeLspService.ts +0 -894
  1069. package/packages/core/src/lsp/constants.ts +0 -101
  1070. package/packages/core/src/lsp/types.ts +0 -523
  1071. package/packages/core/src/mcp/constants.ts +0 -27
  1072. package/packages/core/src/mcp/google-auth-provider.test.ts +0 -112
  1073. package/packages/core/src/mcp/google-auth-provider.ts +0 -103
  1074. package/packages/core/src/mcp/oauth-provider.test.ts +0 -1275
  1075. package/packages/core/src/mcp/oauth-provider.ts +0 -910
  1076. package/packages/core/src/mcp/oauth-token-storage.test.ts +0 -459
  1077. package/packages/core/src/mcp/oauth-token-storage.ts +0 -228
  1078. package/packages/core/src/mcp/oauth-utils.test.ts +0 -345
  1079. package/packages/core/src/mcp/oauth-utils.ts +0 -379
  1080. package/packages/core/src/mcp/sa-impersonation-provider.test.ts +0 -153
  1081. package/packages/core/src/mcp/sa-impersonation-provider.ts +0 -177
  1082. package/packages/core/src/mcp/token-storage/base-token-storage.test.ts +0 -208
  1083. package/packages/core/src/mcp/token-storage/base-token-storage.ts +0 -49
  1084. package/packages/core/src/mcp/token-storage/file-token-storage.test.ts +0 -323
  1085. package/packages/core/src/mcp/token-storage/file-token-storage.ts +0 -184
  1086. package/packages/core/src/mcp/token-storage/hybrid-token-storage.test.ts +0 -274
  1087. package/packages/core/src/mcp/token-storage/hybrid-token-storage.ts +0 -97
  1088. package/packages/core/src/mcp/token-storage/index.ts +0 -14
  1089. package/packages/core/src/mcp/token-storage/keychain-token-storage.test.ts +0 -352
  1090. package/packages/core/src/mcp/token-storage/keychain-token-storage.ts +0 -315
  1091. package/packages/core/src/mcp/token-storage/types.ts +0 -42
  1092. package/packages/core/src/mocks/msw.ts +0 -9
  1093. package/packages/core/src/models/constants.ts +0 -117
  1094. package/packages/core/src/models/index.ts +0 -45
  1095. package/packages/core/src/models/modelConfigErrors.ts +0 -125
  1096. package/packages/core/src/models/modelConfigResolver.test.ts +0 -351
  1097. package/packages/core/src/models/modelConfigResolver.ts +0 -369
  1098. package/packages/core/src/models/modelRegistry.test.ts +0 -533
  1099. package/packages/core/src/models/modelRegistry.ts +0 -234
  1100. package/packages/core/src/models/modelsConfig.test.ts +0 -1509
  1101. package/packages/core/src/models/modelsConfig.ts +0 -1201
  1102. package/packages/core/src/models/types.ts +0 -150
  1103. package/packages/core/src/output/json-formatter.test.ts +0 -301
  1104. package/packages/core/src/output/json-formatter.ts +0 -39
  1105. package/packages/core/src/output/types.ts +0 -30
  1106. package/packages/core/src/prompts/mcp-prompts.ts +0 -19
  1107. package/packages/core/src/prompts/prompt-registry.ts +0 -77
  1108. package/packages/core/src/qwen/qwenContentGenerator.test.ts +0 -1698
  1109. package/packages/core/src/qwen/qwenContentGenerator.ts +0 -252
  1110. package/packages/core/src/qwen/qwenOAuth2.test.ts +0 -2187
  1111. package/packages/core/src/qwen/qwenOAuth2.ts +0 -1017
  1112. package/packages/core/src/qwen/sharedTokenManager.test.ts +0 -937
  1113. package/packages/core/src/qwen/sharedTokenManager.ts +0 -887
  1114. package/packages/core/src/services/chatCompressionService.test.ts +0 -484
  1115. package/packages/core/src/services/chatCompressionService.ts +0 -274
  1116. package/packages/core/src/services/chatRecordingService.test.ts +0 -356
  1117. package/packages/core/src/services/chatRecordingService.ts +0 -448
  1118. package/packages/core/src/services/fileDiscoveryService.test.ts +0 -211
  1119. package/packages/core/src/services/fileDiscoveryService.ts +0 -142
  1120. package/packages/core/src/services/fileSystemService.test.ts +0 -297
  1121. package/packages/core/src/services/fileSystemService.ts +0 -234
  1122. package/packages/core/src/services/gitService.test.ts +0 -231
  1123. package/packages/core/src/services/gitService.ts +0 -121
  1124. package/packages/core/src/services/loopDetectionService.test.ts +0 -622
  1125. package/packages/core/src/services/loopDetectionService.ts +0 -316
  1126. package/packages/core/src/services/sessionService.test.ts +0 -721
  1127. package/packages/core/src/services/sessionService.ts +0 -706
  1128. package/packages/core/src/services/shellExecutionService.test.ts +0 -999
  1129. package/packages/core/src/services/shellExecutionService.ts +0 -799
  1130. package/packages/core/src/skills/index.ts +0 -31
  1131. package/packages/core/src/skills/skill-load.test.ts +0 -303
  1132. package/packages/core/src/skills/skill-load.ts +0 -173
  1133. package/packages/core/src/skills/skill-manager.test.ts +0 -692
  1134. package/packages/core/src/skills/skill-manager.ts +0 -652
  1135. package/packages/core/src/skills/types.ts +0 -111
  1136. package/packages/core/src/subagents/builtin-agents.test.ts +0 -95
  1137. package/packages/core/src/subagents/builtin-agents.ts +0 -95
  1138. package/packages/core/src/subagents/index.ts +0 -75
  1139. package/packages/core/src/subagents/subagent-events.ts +0 -145
  1140. package/packages/core/src/subagents/subagent-hooks.ts +0 -33
  1141. package/packages/core/src/subagents/subagent-manager.test.ts +0 -1152
  1142. package/packages/core/src/subagents/subagent-manager.ts +0 -978
  1143. package/packages/core/src/subagents/subagent-statistics.test.ts +0 -318
  1144. package/packages/core/src/subagents/subagent-statistics.ts +0 -275
  1145. package/packages/core/src/subagents/subagent.test.ts +0 -1196
  1146. package/packages/core/src/subagents/subagent.ts +0 -1010
  1147. package/packages/core/src/subagents/types.test.ts +0 -40
  1148. package/packages/core/src/subagents/types.ts +0 -272
  1149. package/packages/core/src/subagents/validation.test.ts +0 -426
  1150. package/packages/core/src/subagents/validation.ts +0 -354
  1151. package/packages/core/src/telemetry/config.test.ts +0 -155
  1152. package/packages/core/src/telemetry/config.ts +0 -118
  1153. package/packages/core/src/telemetry/constants.ts +0 -45
  1154. package/packages/core/src/telemetry/file-exporters.ts +0 -93
  1155. package/packages/core/src/telemetry/index.ts +0 -108
  1156. package/packages/core/src/telemetry/integration.test.circular.ts +0 -111
  1157. package/packages/core/src/telemetry/loggers.test.circular.ts +0 -128
  1158. package/packages/core/src/telemetry/loggers.test.ts +0 -1284
  1159. package/packages/core/src/telemetry/loggers.ts +0 -948
  1160. package/packages/core/src/telemetry/metrics.test.ts +0 -899
  1161. package/packages/core/src/telemetry/metrics.ts +0 -749
  1162. package/packages/core/src/telemetry/qwen-logger/event-types.ts +0 -102
  1163. package/packages/core/src/telemetry/qwen-logger/qwen-logger.test.ts +0 -515
  1164. package/packages/core/src/telemetry/qwen-logger/qwen-logger.ts +0 -988
  1165. package/packages/core/src/telemetry/sdk.test.ts +0 -148
  1166. package/packages/core/src/telemetry/sdk.ts +0 -195
  1167. package/packages/core/src/telemetry/telemetry-utils.test.ts +0 -46
  1168. package/packages/core/src/telemetry/telemetry-utils.ts +0 -17
  1169. package/packages/core/src/telemetry/telemetry.test.ts +0 -63
  1170. package/packages/core/src/telemetry/tool-call-decision.ts +0 -32
  1171. package/packages/core/src/telemetry/types.ts +0 -874
  1172. package/packages/core/src/telemetry/uiTelemetry.test.ts +0 -766
  1173. package/packages/core/src/telemetry/uiTelemetry.ts +0 -253
  1174. package/packages/core/src/test-utils/config.ts +0 -36
  1175. package/packages/core/src/test-utils/index.ts +0 -7
  1176. package/packages/core/src/test-utils/mock-tool.ts +0 -218
  1177. package/packages/core/src/test-utils/mockWorkspaceContext.ts +0 -33
  1178. package/packages/core/src/tools/__snapshots__/shell.test.ts.snap +0 -98
  1179. package/packages/core/src/tools/askUserQuestion.test.ts +0 -260
  1180. package/packages/core/src/tools/askUserQuestion.ts +0 -352
  1181. package/packages/core/src/tools/diffOptions.test.ts +0 -165
  1182. package/packages/core/src/tools/diffOptions.ts +0 -73
  1183. package/packages/core/src/tools/edit.test.ts +0 -933
  1184. package/packages/core/src/tools/edit.ts +0 -622
  1185. package/packages/core/src/tools/exitPlanMode.test.ts +0 -241
  1186. package/packages/core/src/tools/exitPlanMode.ts +0 -200
  1187. package/packages/core/src/tools/glob.test.ts +0 -650
  1188. package/packages/core/src/tools/glob.ts +0 -296
  1189. package/packages/core/src/tools/grep.test.ts +0 -484
  1190. package/packages/core/src/tools/grep.ts +0 -570
  1191. package/packages/core/src/tools/ls.test.ts +0 -325
  1192. package/packages/core/src/tools/ls.ts +0 -339
  1193. package/packages/core/src/tools/lsp.test.ts +0 -1233
  1194. package/packages/core/src/tools/lsp.ts +0 -1218
  1195. package/packages/core/src/tools/mcp-client-manager.test.ts +0 -257
  1196. package/packages/core/src/tools/mcp-client-manager.ts +0 -532
  1197. package/packages/core/src/tools/mcp-client.test.ts +0 -424
  1198. package/packages/core/src/tools/mcp-client.ts +0 -1450
  1199. package/packages/core/src/tools/mcp-tool.test.ts +0 -1119
  1200. package/packages/core/src/tools/mcp-tool.ts +0 -580
  1201. package/packages/core/src/tools/memoryTool.test.ts +0 -603
  1202. package/packages/core/src/tools/memoryTool.ts +0 -542
  1203. package/packages/core/src/tools/modifiable-tool.test.ts +0 -347
  1204. package/packages/core/src/tools/modifiable-tool.ts +0 -178
  1205. package/packages/core/src/tools/read-file.test.ts +0 -468
  1206. package/packages/core/src/tools/read-file.ts +0 -226
  1207. package/packages/core/src/tools/ripGrep.test.ts +0 -727
  1208. package/packages/core/src/tools/ripGrep.ts +0 -334
  1209. package/packages/core/src/tools/sdk-control-client-transport.ts +0 -145
  1210. package/packages/core/src/tools/shell.test.ts +0 -1277
  1211. package/packages/core/src/tools/shell.ts +0 -651
  1212. package/packages/core/src/tools/skill.test.ts +0 -436
  1213. package/packages/core/src/tools/skill.ts +0 -275
  1214. package/packages/core/src/tools/task.test.ts +0 -538
  1215. package/packages/core/src/tools/task.ts +0 -570
  1216. package/packages/core/src/tools/todoWrite.test.ts +0 -304
  1217. package/packages/core/src/tools/todoWrite.ts +0 -482
  1218. package/packages/core/src/tools/tool-error.ts +0 -72
  1219. package/packages/core/src/tools/tool-names.ts +0 -69
  1220. package/packages/core/src/tools/tool-registry.test.ts +0 -432
  1221. package/packages/core/src/tools/tool-registry.ts +0 -525
  1222. package/packages/core/src/tools/tools.test.ts +0 -230
  1223. package/packages/core/src/tools/tools.ts +0 -662
  1224. package/packages/core/src/tools/web-fetch.test.ts +0 -169
  1225. package/packages/core/src/tools/web-fetch.ts +0 -256
  1226. package/packages/core/src/tools/web-search/base-provider.ts +0 -58
  1227. package/packages/core/src/tools/web-search/index.test.ts +0 -312
  1228. package/packages/core/src/tools/web-search/index.ts +0 -344
  1229. package/packages/core/src/tools/web-search/providers/dashscope-provider.ts +0 -199
  1230. package/packages/core/src/tools/web-search/providers/google-provider.ts +0 -91
  1231. package/packages/core/src/tools/web-search/providers/tavily-provider.ts +0 -84
  1232. package/packages/core/src/tools/web-search/types.ts +0 -156
  1233. package/packages/core/src/tools/web-search/utils.ts +0 -42
  1234. package/packages/core/src/tools/write-file.test.ts +0 -861
  1235. package/packages/core/src/tools/write-file.ts +0 -491
  1236. package/packages/core/src/types/memfs.d.ts +0 -9
  1237. package/packages/core/src/types/mock-fs.d.ts +0 -25
  1238. package/packages/core/src/types/qrcode-terminal.d.ts +0 -6
  1239. package/packages/core/src/types/uuid.d.ts +0 -12
  1240. package/packages/core/src/types/vitest.d.ts +0 -33
  1241. package/packages/core/src/utils/LruCache.ts +0 -41
  1242. package/packages/core/src/utils/browser.ts +0 -56
  1243. package/packages/core/src/utils/configResolver.test.ts +0 -141
  1244. package/packages/core/src/utils/configResolver.ts +0 -222
  1245. package/packages/core/src/utils/debugLogger.test.ts +0 -268
  1246. package/packages/core/src/utils/debugLogger.ts +0 -195
  1247. package/packages/core/src/utils/editHelper.test.ts +0 -210
  1248. package/packages/core/src/utils/editHelper.ts +0 -478
  1249. package/packages/core/src/utils/editor.test.ts +0 -546
  1250. package/packages/core/src/utils/editor.ts +0 -226
  1251. package/packages/core/src/utils/envVarResolver.test.ts +0 -297
  1252. package/packages/core/src/utils/envVarResolver.ts +0 -126
  1253. package/packages/core/src/utils/environmentContext.test.ts +0 -225
  1254. package/packages/core/src/utils/environmentContext.ts +0 -94
  1255. package/packages/core/src/utils/errorParsing.test.ts +0 -118
  1256. package/packages/core/src/utils/errorParsing.ts +0 -84
  1257. package/packages/core/src/utils/errorReporting.test.ts +0 -128
  1258. package/packages/core/src/utils/errorReporting.ts +0 -80
  1259. package/packages/core/src/utils/errors.test.ts +0 -91
  1260. package/packages/core/src/utils/errors.ts +0 -134
  1261. package/packages/core/src/utils/fetch.test.ts +0 -52
  1262. package/packages/core/src/utils/fetch.ts +0 -192
  1263. package/packages/core/src/utils/fileUtils.test.ts +0 -1126
  1264. package/packages/core/src/utils/fileUtils.ts +0 -692
  1265. package/packages/core/src/utils/filesearch/crawlCache.test.ts +0 -123
  1266. package/packages/core/src/utils/filesearch/crawlCache.ts +0 -69
  1267. package/packages/core/src/utils/filesearch/crawler.test.ts +0 -577
  1268. package/packages/core/src/utils/filesearch/crawler.ts +0 -85
  1269. package/packages/core/src/utils/filesearch/fileSearch.test.ts +0 -772
  1270. package/packages/core/src/utils/filesearch/fileSearch.ts +0 -250
  1271. package/packages/core/src/utils/filesearch/ignore.test.ts +0 -163
  1272. package/packages/core/src/utils/filesearch/ignore.ts +0 -131
  1273. package/packages/core/src/utils/filesearch/result-cache.test.ts +0 -55
  1274. package/packages/core/src/utils/filesearch/result-cache.ts +0 -67
  1275. package/packages/core/src/utils/formatters.ts +0 -16
  1276. package/packages/core/src/utils/generateContentResponseUtilities.test.ts +0 -283
  1277. package/packages/core/src/utils/generateContentResponseUtilities.ts +0 -127
  1278. package/packages/core/src/utils/getFolderStructure.test.ts +0 -340
  1279. package/packages/core/src/utils/getFolderStructure.ts +0 -336
  1280. package/packages/core/src/utils/getPty.ts +0 -9
  1281. package/packages/core/src/utils/gitIgnoreParser.test.ts +0 -237
  1282. package/packages/core/src/utils/gitIgnoreParser.ts +0 -189
  1283. package/packages/core/src/utils/gitUtils.ts +0 -90
  1284. package/packages/core/src/utils/iconvHelper.ts +0 -65
  1285. package/packages/core/src/utils/ignorePatterns.test.ts +0 -324
  1286. package/packages/core/src/utils/ignorePatterns.ts +0 -278
  1287. package/packages/core/src/utils/installationManager.test.ts +0 -99
  1288. package/packages/core/src/utils/installationManager.ts +0 -61
  1289. package/packages/core/src/utils/jsonl-utils.ts +0 -196
  1290. package/packages/core/src/utils/language-detection.ts +0 -103
  1291. package/packages/core/src/utils/memoryDiscovery.test.ts +0 -432
  1292. package/packages/core/src/utils/memoryDiscovery.ts +0 -357
  1293. package/packages/core/src/utils/memoryImportProcessor.test.ts +0 -933
  1294. package/packages/core/src/utils/memoryImportProcessor.ts +0 -417
  1295. package/packages/core/src/utils/messageInspectors.ts +0 -23
  1296. package/packages/core/src/utils/nextSpeakerChecker.test.ts +0 -273
  1297. package/packages/core/src/utils/nextSpeakerChecker.ts +0 -138
  1298. package/packages/core/src/utils/openaiLogger.test.ts +0 -390
  1299. package/packages/core/src/utils/openaiLogger.ts +0 -151
  1300. package/packages/core/src/utils/partUtils.test.ts +0 -301
  1301. package/packages/core/src/utils/partUtils.ts +0 -169
  1302. package/packages/core/src/utils/pathReader.test.ts +0 -411
  1303. package/packages/core/src/utils/pathReader.ts +0 -110
  1304. package/packages/core/src/utils/paths.test.ts +0 -850
  1305. package/packages/core/src/utils/paths.ts +0 -332
  1306. package/packages/core/src/utils/projectSummary.ts +0 -119
  1307. package/packages/core/src/utils/promptIdContext.ts +0 -9
  1308. package/packages/core/src/utils/quotaErrorDetection.test.ts +0 -134
  1309. package/packages/core/src/utils/quotaErrorDetection.ts +0 -126
  1310. package/packages/core/src/utils/qwenIgnoreParser.test.ts +0 -68
  1311. package/packages/core/src/utils/qwenIgnoreParser.ts +0 -81
  1312. package/packages/core/src/utils/rateLimit.test.ts +0 -102
  1313. package/packages/core/src/utils/rateLimit.ts +0 -84
  1314. package/packages/core/src/utils/readManyFiles.test.ts +0 -298
  1315. package/packages/core/src/utils/readManyFiles.ts +0 -210
  1316. package/packages/core/src/utils/request-tokenizer/imageTokenizer.test.ts +0 -157
  1317. package/packages/core/src/utils/request-tokenizer/imageTokenizer.ts +0 -508
  1318. package/packages/core/src/utils/request-tokenizer/index.ts +0 -11
  1319. package/packages/core/src/utils/request-tokenizer/requestTokenizer.test.ts +0 -271
  1320. package/packages/core/src/utils/request-tokenizer/requestTokenizer.ts +0 -330
  1321. package/packages/core/src/utils/request-tokenizer/supportedImageFormats.ts +0 -56
  1322. package/packages/core/src/utils/request-tokenizer/textTokenizer.test.ts +0 -279
  1323. package/packages/core/src/utils/request-tokenizer/textTokenizer.ts +0 -58
  1324. package/packages/core/src/utils/request-tokenizer/types.ts +0 -36
  1325. package/packages/core/src/utils/retry.test.ts +0 -534
  1326. package/packages/core/src/utils/retry.ts +0 -246
  1327. package/packages/core/src/utils/ripgrepUtils.test.ts +0 -135
  1328. package/packages/core/src/utils/ripgrepUtils.ts +0 -322
  1329. package/packages/core/src/utils/runtimeFetchOptions.test.ts +0 -95
  1330. package/packages/core/src/utils/runtimeFetchOptions.ts +0 -153
  1331. package/packages/core/src/utils/safeJsonParse.test.ts +0 -149
  1332. package/packages/core/src/utils/safeJsonParse.ts +0 -48
  1333. package/packages/core/src/utils/safeJsonStringify.test.ts +0 -73
  1334. package/packages/core/src/utils/safeJsonStringify.ts +0 -32
  1335. package/packages/core/src/utils/schemaConverter.test.ts +0 -118
  1336. package/packages/core/src/utils/schemaConverter.ts +0 -135
  1337. package/packages/core/src/utils/schemaValidator.test.ts +0 -297
  1338. package/packages/core/src/utils/schemaValidator.ts +0 -140
  1339. package/packages/core/src/utils/secure-browser-launcher.test.ts +0 -242
  1340. package/packages/core/src/utils/secure-browser-launcher.ts +0 -191
  1341. package/packages/core/src/utils/shell-utils.test.ts +0 -609
  1342. package/packages/core/src/utils/shell-utils.ts +0 -915
  1343. package/packages/core/src/utils/shellReadOnlyChecker.test.ts +0 -234
  1344. package/packages/core/src/utils/shellReadOnlyChecker.ts +0 -353
  1345. package/packages/core/src/utils/subagentGenerator.test.ts +0 -217
  1346. package/packages/core/src/utils/subagentGenerator.ts +0 -146
  1347. package/packages/core/src/utils/summarizer.test.ts +0 -202
  1348. package/packages/core/src/utils/summarizer.ts +0 -99
  1349. package/packages/core/src/utils/symlink.ts +0 -60
  1350. package/packages/core/src/utils/systemEncoding.test.ts +0 -478
  1351. package/packages/core/src/utils/systemEncoding.ts +0 -178
  1352. package/packages/core/src/utils/terminalSerializer.test.ts +0 -197
  1353. package/packages/core/src/utils/terminalSerializer.ts +0 -476
  1354. package/packages/core/src/utils/testUtils.ts +0 -87
  1355. package/packages/core/src/utils/textUtils.test.ts +0 -119
  1356. package/packages/core/src/utils/textUtils.ts +0 -75
  1357. package/packages/core/src/utils/thoughtUtils.test.ts +0 -80
  1358. package/packages/core/src/utils/thoughtUtils.ts +0 -76
  1359. package/packages/core/src/utils/toml-to-markdown-converter.test.ts +0 -103
  1360. package/packages/core/src/utils/toml-to-markdown-converter.ts +0 -74
  1361. package/packages/core/src/utils/tool-utils.test.ts +0 -159
  1362. package/packages/core/src/utils/tool-utils.ts +0 -181
  1363. package/packages/core/src/utils/workspaceContext.test.ts +0 -414
  1364. package/packages/core/src/utils/workspaceContext.ts +0 -202
  1365. package/packages/core/src/utils/yaml-parser.test.ts +0 -193
  1366. package/packages/core/src/utils/yaml-parser.ts +0 -192
  1367. package/packages/core/test-setup.ts +0 -27
  1368. package/packages/core/tsconfig.json +0 -26
  1369. package/packages/core/vendor/ripgrep/COPYING +0 -3
  1370. package/packages/core/vendor/ripgrep/arm64-darwin/rg +0 -0
  1371. package/packages/core/vendor/ripgrep/arm64-linux/rg +0 -0
  1372. package/packages/core/vendor/ripgrep/x64-darwin/rg +0 -0
  1373. package/packages/core/vendor/ripgrep/x64-linux/rg +0 -0
  1374. package/packages/core/vendor/ripgrep/x64-win32/rg.exe +0 -0
  1375. package/packages/core/vitest.config.ts +0 -38
  1376. package/packages/ice-v43/package.json +0 -35
  1377. package/packages/ice-v43/src/agent-crews.ts +0 -189
  1378. package/packages/ice-v43/src/cli.ts +0 -96
  1379. package/packages/ice-v43/src/d20-learner.ts +0 -161
  1380. package/packages/ice-v43/src/engine.ts +0 -219
  1381. package/packages/ice-v43/src/index.ts +0 -40
  1382. package/packages/ice-v43/src/intent-decoder.ts +0 -200
  1383. package/packages/ice-v43/src/multi-provider-client.ts +0 -200
  1384. package/packages/ice-v43/src/reasoning/chain-of-thought.ts +0 -166
  1385. package/packages/ice-v43/src/reasoning/index.ts +0 -16
  1386. package/packages/ice-v43/src/reasoning/self-reflection.ts +0 -160
  1387. package/packages/ice-v43/src/reasoning/socratic-reviewer.ts +0 -167
  1388. package/packages/ice-v43/src/reasoning/tree-of-thoughts.ts +0 -212
  1389. package/packages/ice-v43/src/reasoning/types.ts +0 -40
  1390. package/packages/ice-v43/src/status-cli.ts +0 -77
  1391. package/packages/ice-v43/src/types.ts +0 -81
  1392. package/packages/ice-v43/tsconfig.json +0 -25
  1393. package/packages/sdk-java/client/.editorconfig +0 -24
  1394. package/packages/sdk-java/client/QWEN.md +0 -106
  1395. package/packages/sdk-java/client/README.md +0 -178
  1396. package/packages/sdk-java/client/checkstyle.xml +0 -131
  1397. package/packages/sdk-java/client/pom.xml +0 -206
  1398. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/AcpClient.java +0 -174
  1399. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/notification/AgentNotification.java +0 -12
  1400. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/notification/SessionNotification.java +0 -42
  1401. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/AuthenticateRequest.java +0 -31
  1402. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/ReadTextFileRequest.java +0 -58
  1403. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/RequestPermissionRequest.java +0 -53
  1404. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/WriteTextFileRequest.java +0 -49
  1405. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/terminal/CreateTerminalRequest.java +0 -79
  1406. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/terminal/KillTerminalCommandRequest.java +0 -40
  1407. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/terminal/ReleaseTerminalRequest.java +0 -40
  1408. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/terminal/TerminalOutputRequest.java +0 -40
  1409. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/request/terminal/WaitForTerminalExitRequest.java +0 -40
  1410. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/response/AuthenticateResponse.java +0 -11
  1411. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/response/InitializeResponse.java +0 -101
  1412. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/response/LoadSessionResponse.java +0 -21
  1413. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/response/NewSessionResponse.java +0 -30
  1414. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/response/PromptResponse.java +0 -21
  1415. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/agent/response/SetSessionModeResponse.java +0 -11
  1416. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/notification/CancelNotification.java +0 -33
  1417. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/notification/ClientNotification.java +0 -13
  1418. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/request/InitializeRequest.java +0 -102
  1419. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/request/LoadSessionRequest.java +0 -54
  1420. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/request/NewSessionRequest.java +0 -46
  1421. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/request/PromptRequest.java +0 -50
  1422. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/request/SetSessionModeRequest.java +0 -40
  1423. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/response/ReadTextFileResponse.java +0 -33
  1424. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/response/RequestPermissionResponse.java +0 -40
  1425. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/response/WriteTextFileResponse.java +0 -11
  1426. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/response/terminal/CreateTerminalResponse.java +0 -20
  1427. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/response/terminal/KillTerminalCommandResponse.java +0 -11
  1428. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/response/terminal/ReleaseTerminalResponse.java +0 -11
  1429. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/response/terminal/TerminalOutputResponse.java +0 -60
  1430. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/client/response/terminal/WaitForTerminalExitResponse.java +0 -29
  1431. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/agent/AgentCapabilities.java +0 -189
  1432. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/agent/AgentInfo.java +0 -68
  1433. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/agent/AuthMethod.java +0 -68
  1434. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/client/ClientCapabilities.java +0 -120
  1435. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/client/ClientInfo.java +0 -68
  1436. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/Diff.java +0 -34
  1437. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/ToolCallContent.java +0 -44
  1438. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/block/Annotations.java +0 -53
  1439. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/block/AudioContent.java +0 -40
  1440. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/block/ContentBlock.java +0 -18
  1441. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/block/ImageContent.java +0 -49
  1442. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/block/ResourceLink.java +0 -76
  1443. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/block/TextContent.java +0 -36
  1444. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/embedded/BlobResourceContents.java +0 -13
  1445. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/embedded/EmbeddedResource.java +0 -32
  1446. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/embedded/ResourceContent.java +0 -26
  1447. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/embedded/ResourceContentDeserializer.java +0 -24
  1448. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/content/embedded/TextResourceContents.java +0 -13
  1449. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/mcp/HttpHeader.java +0 -25
  1450. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/mcp/McpServer.java +0 -75
  1451. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/permission/PermissionOption.java +0 -34
  1452. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/permission/PermissionOptionKind.java +0 -17
  1453. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/permission/PermissionOutcomeKind.java +0 -10
  1454. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/permission/RequestPermissionOutcome.java +0 -34
  1455. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/plan/Plan.java +0 -18
  1456. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/plan/PlanEntry.java +0 -34
  1457. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/plan/PlanEntryPriority.java +0 -14
  1458. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/plan/PlanEntryStatus.java +0 -14
  1459. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/SessionMode.java +0 -34
  1460. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/SessionModeState.java +0 -27
  1461. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/StopReason.java +0 -20
  1462. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/AgentMessageChunkSessionUpdate.java +0 -21
  1463. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/AvailableCommand.java +0 -34
  1464. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/AvailableCommandsUpdateSessionUpdate.java +0 -22
  1465. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/CurrentModeUpdateSessionUpdate.java +0 -20
  1466. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/PlanSessionUpdate.java +0 -23
  1467. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/SessionUpdate.java +0 -23
  1468. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/ToolCallSessionUpdate.java +0 -11
  1469. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/ToolCallUpdateSessionUpdate.java +0 -11
  1470. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/session/update/UnstructuredCommandInput.java +0 -16
  1471. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/terminal/EnvVariable.java +0 -25
  1472. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/tool/ToolCallLocation.java +0 -25
  1473. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/tool/ToolCallStatus.java +0 -17
  1474. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/tool/ToolCallUpdate.java +0 -82
  1475. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/domain/tool/ToolKind.java +0 -35
  1476. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/Error.java +0 -181
  1477. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/ExtNotification.java +0 -4
  1478. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/ExtRequest.java +0 -4
  1479. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/ExtResponse.java +0 -5
  1480. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/Message.java +0 -22
  1481. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/Meta.java +0 -48
  1482. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/MethodMessage.java +0 -72
  1483. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/Request.java +0 -10
  1484. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/jsonrpc/Response.java +0 -35
  1485. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/protocol/schema.json +0 -3105
  1486. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/Session.java +0 -312
  1487. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/AgentEventConsumer.java +0 -118
  1488. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/ContentEventConsumer.java +0 -110
  1489. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/ContentEventSimpleConsumer.java +0 -84
  1490. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/FileEventConsumer.java +0 -53
  1491. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/FileEventSimpleConsumer.java +0 -168
  1492. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/PermissionEventConsumer.java +0 -34
  1493. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/PromptEndEventConsumer.java +0 -29
  1494. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/TerminalEventConsumer.java +0 -110
  1495. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/event/consumer/exception/EventConsumeException.java +0 -89
  1496. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/exception/SessionLoadException.java +0 -65
  1497. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/session/exception/SessionNewException.java +0 -73
  1498. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/transport/Transport.java +0 -74
  1499. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/transport/process/ProcessTransport.java +0 -228
  1500. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/transport/process/ProcessTransportOptions.java +0 -122
  1501. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/utils/AgentInitializeException.java +0 -73
  1502. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/utils/MyConcurrentUtils.java +0 -83
  1503. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/utils/ThreadPoolConfig.java +0 -77
  1504. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/utils/Timeout.java +0 -72
  1505. package/packages/sdk-java/client/src/main/java/com/alibaba/acp/sdk/utils/TransportUtils.java +0 -38
  1506. package/packages/sdk-java/client/src/test/java/com/alibaba/acp/sdk/protocol/client/session/PermissionOptionKindTest.java +0 -31
  1507. package/packages/sdk-java/client/src/test/java/com/alibaba/acp/sdk/protocol/client/session/PlanEntryPriorityTest.java +0 -27
  1508. package/packages/sdk-java/client/src/test/java/com/alibaba/acp/sdk/protocol/client/session/PlanEntryStatusTest.java +0 -27
  1509. package/packages/sdk-java/client/src/test/java/com/alibaba/acp/sdk/protocol/client/session/StopReasonTest.java +0 -35
  1510. package/packages/sdk-java/client/src/test/java/com/alibaba/acp/sdk/protocol/client/session/ToolCallStatusTest.java +0 -31
  1511. package/packages/sdk-java/client/src/test/java/com/alibaba/acp/sdk/protocol/client/session/ToolKindTest.java +0 -55
  1512. package/packages/sdk-java/client/src/test/java/com/alibaba/acp/sdk/session/SessionTest.java +0 -128
  1513. package/packages/sdk-java/client/src/test/java/com/alibaba/acp/sdk/test/EnumTest.java +0 -22
  1514. package/packages/sdk-java/client/src/test/resources/schema/schema.json +0 -3105
  1515. package/packages/sdk-java/qwencode/.editorconfig +0 -24
  1516. package/packages/sdk-java/qwencode/LICENSE +0 -201
  1517. package/packages/sdk-java/qwencode/QWEN.md +0 -377
  1518. package/packages/sdk-java/qwencode/README.md +0 -307
  1519. package/packages/sdk-java/qwencode/RELEASE.md +0 -150
  1520. package/packages/sdk-java/qwencode/checkstyle.xml +0 -131
  1521. package/packages/sdk-java/qwencode/pom.xml +0 -193
  1522. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/QwenCodeCli.java +0 -142
  1523. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/AssistantContent.java +0 -95
  1524. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/AssistantUsage.java +0 -76
  1525. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/CLIPermissionDenial.java +0 -83
  1526. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/Capabilities.java +0 -131
  1527. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/ExtendedUsage.java +0 -147
  1528. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/InitializeConfig.java +0 -98
  1529. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/ModelUsage.java +0 -142
  1530. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/PermissionMode.java +0 -56
  1531. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/Usage.java +0 -137
  1532. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/behavior/Allow.java +0 -46
  1533. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/behavior/Behavior.java +0 -62
  1534. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/data/behavior/Deny.java +0 -45
  1535. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/Message.java +0 -23
  1536. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/MessageBase.java +0 -64
  1537. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/SDKResultMessage.java +0 -332
  1538. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/SDKSystemMessage.java +0 -486
  1539. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/SDKUserMessage.java +0 -196
  1540. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/APIAssistantMessage.java +0 -172
  1541. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/SDKAssistantMessage.java +0 -121
  1542. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/SDKPartialAssistantMessage.java +0 -116
  1543. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/block/Annotation.java +0 -59
  1544. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/block/ContentBlock.java +0 -87
  1545. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/block/TextBlock.java +0 -42
  1546. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/block/ThinkingBlock.java +0 -64
  1547. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/block/ToolResultBlock.java +0 -92
  1548. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/block/ToolUseBlock.java +0 -122
  1549. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/event/ContentBlockDeltaEvent.java +0 -224
  1550. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/event/ContentBlockStartEvent.java +0 -25
  1551. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/event/ContentBlockStopEvent.java +0 -35
  1552. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/event/MessageStartStreamEvent.java +0 -107
  1553. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/event/MessageStopStreamEvent.java +0 -13
  1554. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/assistant/event/StreamEvent.java +0 -37
  1555. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/CLIControlRequest.java +0 -90
  1556. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/CLIControlResponse.java +0 -138
  1557. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/CLIControlInitializeRequest.java +0 -45
  1558. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/CLIControlInitializeResponse.java +0 -41
  1559. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/CLIControlInterruptRequest.java +0 -17
  1560. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/CLIControlPermissionRequest.java +0 -235
  1561. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/CLIControlPermissionResponse.java +0 -45
  1562. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/CLIControlSetModelRequest.java +0 -40
  1563. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/CLIControlSetModelResponse.java +0 -54
  1564. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/CLIControlSetPermissionModeRequest.java +0 -40
  1565. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/ControlRequestPayload.java +0 -26
  1566. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/message/control/payload/ControlResponsePayload.java +0 -26
  1567. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/protocol/protocol.ts +0 -594
  1568. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/session/Session.java +0 -302
  1569. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/session/event/consumers/AssistantContentConsumers.java +0 -159
  1570. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/session/event/consumers/AssistantContentSimpleConsumers.java +0 -193
  1571. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/session/event/consumers/SessionEventConsumers.java +0 -158
  1572. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/session/event/consumers/SessionEventSimpleConsumers.java +0 -339
  1573. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/session/exception/SessionControlException.java +0 -55
  1574. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/session/exception/SessionSendPromptException.java +0 -55
  1575. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/transport/Transport.java +0 -78
  1576. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/transport/TransportOptions.java +0 -386
  1577. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/transport/process/ProcessTransport.java +0 -224
  1578. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/transport/process/TransportOptionsAdapter.java +0 -153
  1579. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/utils/MyConcurrentUtils.java +0 -94
  1580. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/utils/ThreadPoolConfig.java +0 -64
  1581. package/packages/sdk-java/qwencode/src/main/java/com/alibaba/qwen/code/cli/utils/Timeout.java +0 -68
  1582. package/packages/sdk-java/qwencode/src/test/java/com/alibaba/qwen/code/cli/QwenCodeCliTest.java +0 -29
  1583. package/packages/sdk-java/qwencode/src/test/java/com/alibaba/qwen/code/cli/example/QuickStartExample.java +0 -109
  1584. package/packages/sdk-java/qwencode/src/test/java/com/alibaba/qwen/code/cli/example/SessionExample.java +0 -256
  1585. package/packages/sdk-java/qwencode/src/test/java/com/alibaba/qwen/code/cli/example/ThreadPoolConfigurationExample.java +0 -50
  1586. package/packages/sdk-java/qwencode/src/test/java/com/alibaba/qwen/code/cli/session/SessionTest.java +0 -185
  1587. package/packages/sdk-java/qwencode/src/test/java/com/alibaba/qwen/code/cli/transport/PermissionModeTest.java +0 -19
  1588. package/packages/sdk-java/qwencode/src/test/java/com/alibaba/qwen/code/cli/transport/process/ProcessTransportTest.java +0 -87
  1589. package/packages/sdk-typescript/README.md +0 -395
  1590. package/packages/sdk-typescript/package.json +0 -75
  1591. package/packages/sdk-typescript/scripts/build.js +0 -93
  1592. package/packages/sdk-typescript/scripts/bundle-cli-from-npm.js +0 -88
  1593. package/packages/sdk-typescript/scripts/bundle-cli.js +0 -83
  1594. package/packages/sdk-typescript/scripts/get-release-version.js +0 -363
  1595. package/packages/sdk-typescript/src/index.ts +0 -64
  1596. package/packages/sdk-typescript/src/mcp/SdkControlServerTransport.ts +0 -105
  1597. package/packages/sdk-typescript/src/mcp/createSdkMcpServer.ts +0 -107
  1598. package/packages/sdk-typescript/src/mcp/formatters.ts +0 -194
  1599. package/packages/sdk-typescript/src/mcp/tool.ts +0 -90
  1600. package/packages/sdk-typescript/src/query/Query.ts +0 -937
  1601. package/packages/sdk-typescript/src/query/createQuery.ts +0 -140
  1602. package/packages/sdk-typescript/src/transport/ProcessTransport.ts +0 -474
  1603. package/packages/sdk-typescript/src/transport/Transport.ts +0 -22
  1604. package/packages/sdk-typescript/src/types/errors.ts +0 -17
  1605. package/packages/sdk-typescript/src/types/protocol.ts +0 -605
  1606. package/packages/sdk-typescript/src/types/queryOptionsSchema.ts +0 -173
  1607. package/packages/sdk-typescript/src/types/types.ts +0 -477
  1608. package/packages/sdk-typescript/src/utils/Stream.ts +0 -79
  1609. package/packages/sdk-typescript/src/utils/cliPath.ts +0 -364
  1610. package/packages/sdk-typescript/src/utils/jsonLines.ts +0 -65
  1611. package/packages/sdk-typescript/src/utils/logger.ts +0 -147
  1612. package/packages/sdk-typescript/src/utils/validation.ts +0 -33
  1613. package/packages/sdk-typescript/test/unit/ProcessTransport.test.ts +0 -1754
  1614. package/packages/sdk-typescript/test/unit/Query.test.ts +0 -1433
  1615. package/packages/sdk-typescript/test/unit/Stream.test.ts +0 -255
  1616. package/packages/sdk-typescript/test/unit/cliPath.test.ts +0 -423
  1617. package/packages/sdk-typescript/test/unit/createSdkMcpServer.test.ts +0 -386
  1618. package/packages/sdk-typescript/tsconfig.build.json +0 -15
  1619. package/packages/sdk-typescript/tsconfig.json +0 -41
  1620. package/packages/sdk-typescript/vitest.config.ts +0 -47
  1621. package/packages/test-utils/index.ts +0 -7
  1622. package/packages/test-utils/package.json +0 -18
  1623. package/packages/test-utils/src/file-system-test-helpers.ts +0 -98
  1624. package/packages/test-utils/src/index.ts +0 -7
  1625. package/packages/test-utils/tsconfig.json +0 -11
  1626. package/packages/test-utils/vitest.config.ts +0 -23
  1627. package/packages/vscode-ide-companion/.vscode/launch.json +0 -13
  1628. package/packages/vscode-ide-companion/.vscode/tasks.json +0 -18
  1629. package/packages/vscode-ide-companion/.vscodeignore +0 -10
  1630. package/packages/vscode-ide-companion/LICENSE +0 -202
  1631. package/packages/vscode-ide-companion/NOTICES.txt +0 -2553
  1632. package/packages/vscode-ide-companion/README.md +0 -70
  1633. package/packages/vscode-ide-companion/assets/icon.png +0 -0
  1634. package/packages/vscode-ide-companion/development.md +0 -24
  1635. package/packages/vscode-ide-companion/esbuild.js +0 -197
  1636. package/packages/vscode-ide-companion/eslint.config.mjs +0 -75
  1637. package/packages/vscode-ide-companion/package.json +0 -172
  1638. package/packages/vscode-ide-companion/postcss.config.js +0 -13
  1639. package/packages/vscode-ide-companion/schemas/settings.schema.json +0 -622
  1640. package/packages/vscode-ide-companion/scripts/copy-bundled-cli.js +0 -67
  1641. package/packages/vscode-ide-companion/scripts/generate-notices.js +0 -160
  1642. package/packages/vscode-ide-companion/scripts/prepackage.js +0 -252
  1643. package/packages/vscode-ide-companion/src/commands/index.ts +0 -86
  1644. package/packages/vscode-ide-companion/src/constants/acpSchema.ts +0 -35
  1645. package/packages/vscode-ide-companion/src/constants/loadingMessages.ts +0 -146
  1646. package/packages/vscode-ide-companion/src/diff-manager.ts +0 -433
  1647. package/packages/vscode-ide-companion/src/extension.test.ts +0 -298
  1648. package/packages/vscode-ide-companion/src/extension.ts +0 -380
  1649. package/packages/vscode-ide-companion/src/ide-server.test.ts +0 -536
  1650. package/packages/vscode-ide-companion/src/ide-server.ts +0 -477
  1651. package/packages/vscode-ide-companion/src/open-files-manager.test.ts +0 -441
  1652. package/packages/vscode-ide-companion/src/open-files-manager.ts +0 -215
  1653. package/packages/vscode-ide-companion/src/services/acpConnection.ts +0 -532
  1654. package/packages/vscode-ide-companion/src/services/acpFileHandler.test.ts +0 -131
  1655. package/packages/vscode-ide-companion/src/services/acpFileHandler.ts +0 -117
  1656. package/packages/vscode-ide-companion/src/services/conversationStore.ts +0 -83
  1657. package/packages/vscode-ide-companion/src/services/open-files-manager/constants.ts +0 -8
  1658. package/packages/vscode-ide-companion/src/services/open-files-manager/notebook-handler.ts +0 -119
  1659. package/packages/vscode-ide-companion/src/services/open-files-manager/text-handler.ts +0 -61
  1660. package/packages/vscode-ide-companion/src/services/open-files-manager/utils.ts +0 -101
  1661. package/packages/vscode-ide-companion/src/services/qwenAgentManager.ts +0 -1495
  1662. package/packages/vscode-ide-companion/src/services/qwenConnectionHandler.ts +0 -237
  1663. package/packages/vscode-ide-companion/src/services/qwenSessionManager.ts +0 -151
  1664. package/packages/vscode-ide-companion/src/services/qwenSessionReader.ts +0 -353
  1665. package/packages/vscode-ide-companion/src/services/qwenSessionUpdateHandler.test.ts +0 -358
  1666. package/packages/vscode-ide-companion/src/services/qwenSessionUpdateHandler.ts +0 -274
  1667. package/packages/vscode-ide-companion/src/services/readonlyFileSystemProvider.ts +0 -204
  1668. package/packages/vscode-ide-companion/src/types/acpTypes.ts +0 -68
  1669. package/packages/vscode-ide-companion/src/types/approvalModeTypes.ts +0 -79
  1670. package/packages/vscode-ide-companion/src/types/approvalModeValueTypes.ts +0 -11
  1671. package/packages/vscode-ide-companion/src/types/chatTypes.ts +0 -113
  1672. package/packages/vscode-ide-companion/src/types/completionItemTypes.ts +0 -7
  1673. package/packages/vscode-ide-companion/src/types/connectionTypes.ts +0 -43
  1674. package/packages/vscode-ide-companion/src/types/webviewMessageTypes.ts +0 -25
  1675. package/packages/vscode-ide-companion/src/utils/acpModelInfo.test.ts +0 -208
  1676. package/packages/vscode-ide-companion/src/utils/acpModelInfo.ts +0 -288
  1677. package/packages/vscode-ide-companion/src/utils/authErrors.ts +0 -36
  1678. package/packages/vscode-ide-companion/src/utils/authNotificationHandler.ts +0 -50
  1679. package/packages/vscode-ide-companion/src/utils/editorGroupUtils.ts +0 -162
  1680. package/packages/vscode-ide-companion/src/utils/logger.ts +0 -18
  1681. package/packages/vscode-ide-companion/src/utils/platform.ts +0 -8
  1682. package/packages/vscode-ide-companion/src/webview/App.tsx +0 -1060
  1683. package/packages/vscode-ide-companion/src/webview/MessageHandler.ts +0 -89
  1684. package/packages/vscode-ide-companion/src/webview/PanelManager.ts +0 -385
  1685. package/packages/vscode-ide-companion/src/webview/WebViewContent.ts +0 -50
  1686. package/packages/vscode-ide-companion/src/webview/WebViewProvider.ts +0 -1450
  1687. package/packages/vscode-ide-companion/src/webview/components/layout/InputForm.tsx +0 -88
  1688. package/packages/vscode-ide-companion/src/webview/components/layout/ModelSelector.tsx +0 -197
  1689. package/packages/vscode-ide-companion/src/webview/components/layout/Onboarding.tsx +0 -26
  1690. package/packages/vscode-ide-companion/src/webview/components/messages/toolcalls/ToolCall.tsx +0 -29
  1691. package/packages/vscode-ide-companion/src/webview/components/messages/toolcalls/index.tsx +0 -101
  1692. package/packages/vscode-ide-companion/src/webview/context/VSCodePlatformProvider.tsx +0 -171
  1693. package/packages/vscode-ide-companion/src/webview/handlers/AuthMessageHandler.ts +0 -83
  1694. package/packages/vscode-ide-companion/src/webview/handlers/BaseMessageHandler.ts +0 -58
  1695. package/packages/vscode-ide-companion/src/webview/handlers/EditorMessageHandler.ts +0 -111
  1696. package/packages/vscode-ide-companion/src/webview/handlers/FileMessageHandler.test.ts +0 -118
  1697. package/packages/vscode-ide-companion/src/webview/handlers/FileMessageHandler.ts +0 -565
  1698. package/packages/vscode-ide-companion/src/webview/handlers/MessageRouter.ts +0 -175
  1699. package/packages/vscode-ide-companion/src/webview/handlers/SessionMessageHandler.ts +0 -994
  1700. package/packages/vscode-ide-companion/src/webview/hooks/file/useFileContext.ts +0 -189
  1701. package/packages/vscode-ide-companion/src/webview/hooks/message/useMessageHandling.ts +0 -182
  1702. package/packages/vscode-ide-companion/src/webview/hooks/session/useSessionManagement.ts +0 -127
  1703. package/packages/vscode-ide-companion/src/webview/hooks/useCompletionTrigger.ts +0 -357
  1704. package/packages/vscode-ide-companion/src/webview/hooks/useMessageSubmit.ts +0 -171
  1705. package/packages/vscode-ide-companion/src/webview/hooks/useToolCalls.ts +0 -271
  1706. package/packages/vscode-ide-companion/src/webview/hooks/useVSCode.ts +0 -54
  1707. package/packages/vscode-ide-companion/src/webview/hooks/useWebViewMessages.ts +0 -988
  1708. package/packages/vscode-ide-companion/src/webview/index.tsx +0 -28
  1709. package/packages/vscode-ide-companion/src/webview/styles/App.css +0 -175
  1710. package/packages/vscode-ide-companion/src/webview/styles/tailwind.css +0 -27
  1711. package/packages/vscode-ide-companion/src/webview/utils/diffStats.ts +0 -160
  1712. package/packages/vscode-ide-companion/src/webview/utils/diffUtils.ts +0 -49
  1713. package/packages/vscode-ide-companion/src/webview/utils/resourceUrl.ts +0 -115
  1714. package/packages/vscode-ide-companion/src/webview/utils/sessionGrouping.ts +0 -10
  1715. package/packages/vscode-ide-companion/src/webview/utils/utils.test.ts +0 -134
  1716. package/packages/vscode-ide-companion/src/webview/utils/utils.ts +0 -26
  1717. package/packages/vscode-ide-companion/src/webview/utils/webviewUtils.ts +0 -31
  1718. package/packages/vscode-ide-companion/tailwind.config.js +0 -74
  1719. package/packages/vscode-ide-companion/tsconfig.json +0 -17
  1720. package/packages/vscode-ide-companion/vitest.config.ts +0 -15
  1721. package/packages/web-templates/build.mjs +0 -57
  1722. package/packages/web-templates/package.json +0 -6
  1723. package/packages/web-templates/src/export-html/build.mjs +0 -87
  1724. package/packages/web-templates/src/export-html/esbuild.config.mjs +0 -35
  1725. package/packages/web-templates/src/export-html/package.json +0 -14
  1726. package/packages/web-templates/src/export-html/src/components/TempFileModal.css +0 -70
  1727. package/packages/web-templates/src/export-html/src/components/TempFileModal.tsx +0 -65
  1728. package/packages/web-templates/src/export-html/src/favicon.svg +0 -6
  1729. package/packages/web-templates/src/export-html/src/index.html +0 -59
  1730. package/packages/web-templates/src/export-html/src/main.tsx +0 -186
  1731. package/packages/web-templates/src/export-html/src/styles.css +0 -203
  1732. package/packages/web-templates/src/export-html/src/types.d.ts +0 -9
  1733. package/packages/web-templates/src/export-html/tsconfig.json +0 -15
  1734. package/packages/web-templates/src/index.ts +0 -9
  1735. package/packages/web-templates/src/insight/build.mjs +0 -57
  1736. package/packages/web-templates/src/insight/index.html +0 -17
  1737. package/packages/web-templates/src/insight/package.json +0 -9
  1738. package/packages/web-templates/src/insight/postcss.config.js +0 -5
  1739. package/packages/web-templates/src/insight/src/App.tsx +0 -287
  1740. package/packages/web-templates/src/insight/src/Charts.tsx +0 -300
  1741. package/packages/web-templates/src/insight/src/Components.tsx +0 -45
  1742. package/packages/web-templates/src/insight/src/Header.tsx +0 -79
  1743. package/packages/web-templates/src/insight/src/Qualitative.tsx +0 -718
  1744. package/packages/web-templates/src/insight/src/ShareCard.tsx +0 -598
  1745. package/packages/web-templates/src/insight/src/dev.tsx +0 -363
  1746. package/packages/web-templates/src/insight/src/styles.css +0 -1290
  1747. package/packages/web-templates/src/insight/src/types.ts +0 -15
  1748. package/packages/web-templates/src/insight/tailwind.config.js +0 -8
  1749. package/packages/web-templates/src/insight/tsconfig.json +0 -15
  1750. package/packages/web-templates/src/insight/vite.config.mjs +0 -39
  1751. package/packages/web-templates/tsconfig.json +0 -12
  1752. package/packages/webui/.storybook/main.ts +0 -44
  1753. package/packages/webui/.storybook/preview.css +0 -54
  1754. package/packages/webui/.storybook/preview.ts +0 -67
  1755. package/packages/webui/README.md +0 -347
  1756. package/packages/webui/docs/WEBUI_MIGRATION_PLAN_EN.md +0 -428
  1757. package/packages/webui/examples/README.md +0 -8
  1758. package/packages/webui/examples/cdn-usage-demo.html +0 -161
  1759. package/packages/webui/examples/complex-chat-demo.html +0 -428
  1760. package/packages/webui/package.json +0 -80
  1761. package/packages/webui/postcss.config.cjs +0 -13
  1762. package/packages/webui/scripts/add-license-header.sh +0 -48
  1763. package/packages/webui/src/adapters/ACPAdapter.ts +0 -109
  1764. package/packages/webui/src/adapters/JSONLAdapter.ts +0 -126
  1765. package/packages/webui/src/adapters/index.ts +0 -28
  1766. package/packages/webui/src/adapters/types.ts +0 -82
  1767. package/packages/webui/src/components/ChatViewer/ChatViewer.css +0 -192
  1768. package/packages/webui/src/components/ChatViewer/ChatViewer.stories.tsx +0 -1650
  1769. package/packages/webui/src/components/ChatViewer/ChatViewer.tsx +0 -424
  1770. package/packages/webui/src/components/ChatViewer/index.ts +0 -16
  1771. package/packages/webui/src/components/PermissionDrawer.css +0 -249
  1772. package/packages/webui/src/components/PermissionDrawer.stories.tsx +0 -81
  1773. package/packages/webui/src/components/PermissionDrawer.tsx +0 -259
  1774. package/packages/webui/src/components/WebviewContainer.tsx +0 -17
  1775. package/packages/webui/src/components/icons/CloseIcon.tsx +0 -36
  1776. package/packages/webui/src/components/icons/EditIcons.tsx +0 -389
  1777. package/packages/webui/src/components/icons/FileIcons.tsx +0 -99
  1778. package/packages/webui/src/components/icons/Icon.tsx +0 -41
  1779. package/packages/webui/src/components/icons/NavigationIcons.tsx +0 -270
  1780. package/packages/webui/src/components/icons/SendIcon.tsx +0 -36
  1781. package/packages/webui/src/components/icons/SpecialIcons.tsx +0 -79
  1782. package/packages/webui/src/components/icons/StatusIcons.tsx +0 -235
  1783. package/packages/webui/src/components/icons/StopIcon.tsx +0 -29
  1784. package/packages/webui/src/components/icons/index.ts +0 -60
  1785. package/packages/webui/src/components/icons/types.ts +0 -22
  1786. package/packages/webui/src/components/layout/ChatHeader.stories.tsx +0 -66
  1787. package/packages/webui/src/components/layout/ChatHeader.tsx +0 -77
  1788. package/packages/webui/src/components/layout/CompletionMenu.stories.tsx +0 -129
  1789. package/packages/webui/src/components/layout/CompletionMenu.tsx +0 -280
  1790. package/packages/webui/src/components/layout/Container.tsx +0 -18
  1791. package/packages/webui/src/components/layout/ContextIndicator.stories.tsx +0 -85
  1792. package/packages/webui/src/components/layout/ContextIndicator.tsx +0 -129
  1793. package/packages/webui/src/components/layout/EmptyState.stories.tsx +0 -100
  1794. package/packages/webui/src/components/layout/EmptyState.tsx +0 -99
  1795. package/packages/webui/src/components/layout/FileLink.tsx +0 -189
  1796. package/packages/webui/src/components/layout/Footer.tsx +0 -11
  1797. package/packages/webui/src/components/layout/Header.tsx +0 -11
  1798. package/packages/webui/src/components/layout/InputForm.stories.tsx +0 -205
  1799. package/packages/webui/src/components/layout/InputForm.tsx +0 -367
  1800. package/packages/webui/src/components/layout/Main.tsx +0 -11
  1801. package/packages/webui/src/components/layout/Onboarding.stories.tsx +0 -69
  1802. package/packages/webui/src/components/layout/Onboarding.tsx +0 -70
  1803. package/packages/webui/src/components/layout/SessionSelector.stories.tsx +0 -154
  1804. package/packages/webui/src/components/layout/SessionSelector.tsx +0 -194
  1805. package/packages/webui/src/components/layout/Sidebar.tsx +0 -11
  1806. package/packages/webui/src/components/messages/AskUserQuestionDialog.tsx +0 -525
  1807. package/packages/webui/src/components/messages/Assistant/AssistantMessage.css +0 -104
  1808. package/packages/webui/src/components/messages/Assistant/AssistantMessage.stories.tsx +0 -207
  1809. package/packages/webui/src/components/messages/Assistant/AssistantMessage.tsx +0 -99
  1810. package/packages/webui/src/components/messages/Assistant/index.ts +0 -11
  1811. package/packages/webui/src/components/messages/CollapsibleFileContent.tsx +0 -264
  1812. package/packages/webui/src/components/messages/MarkdownRenderer/MarkdownRenderer.css +0 -222
  1813. package/packages/webui/src/components/messages/MarkdownRenderer/MarkdownRenderer.tsx +0 -360
  1814. package/packages/webui/src/components/messages/MarkdownRenderer/index.ts +0 -8
  1815. package/packages/webui/src/components/messages/Message.tsx +0 -45
  1816. package/packages/webui/src/components/messages/MessageContent.tsx +0 -31
  1817. package/packages/webui/src/components/messages/MessageInput.tsx +0 -11
  1818. package/packages/webui/src/components/messages/MessageList.tsx +0 -11
  1819. package/packages/webui/src/components/messages/ThinkingMessage.css +0 -150
  1820. package/packages/webui/src/components/messages/ThinkingMessage.stories.tsx +0 -141
  1821. package/packages/webui/src/components/messages/ThinkingMessage.tsx +0 -83
  1822. package/packages/webui/src/components/messages/UserMessage.stories.tsx +0 -121
  1823. package/packages/webui/src/components/messages/UserMessage.tsx +0 -91
  1824. package/packages/webui/src/components/messages/Waiting/InterruptedMessage.tsx +0 -22
  1825. package/packages/webui/src/components/messages/Waiting/WaitingMessage.tsx +0 -83
  1826. package/packages/webui/src/components/toolcalls/CheckboxDisplay.stories.tsx +0 -63
  1827. package/packages/webui/src/components/toolcalls/CheckboxDisplay.tsx +0 -79
  1828. package/packages/webui/src/components/toolcalls/EditToolCall.stories.tsx +0 -92
  1829. package/packages/webui/src/components/toolcalls/EditToolCall.tsx +0 -216
  1830. package/packages/webui/src/components/toolcalls/GenericToolCall.stories.tsx +0 -102
  1831. package/packages/webui/src/components/toolcalls/GenericToolCall.tsx +0 -148
  1832. package/packages/webui/src/components/toolcalls/ReadToolCall.stories.tsx +0 -171
  1833. package/packages/webui/src/components/toolcalls/ReadToolCall.tsx +0 -338
  1834. package/packages/webui/src/components/toolcalls/SaveMemoryToolCall.tsx +0 -69
  1835. package/packages/webui/src/components/toolcalls/SearchToolCall.stories.tsx +0 -85
  1836. package/packages/webui/src/components/toolcalls/SearchToolCall.tsx +0 -210
  1837. package/packages/webui/src/components/toolcalls/ShellToolCall.css +0 -190
  1838. package/packages/webui/src/components/toolcalls/ShellToolCall.stories.tsx +0 -183
  1839. package/packages/webui/src/components/toolcalls/ShellToolCall.tsx +0 -297
  1840. package/packages/webui/src/components/toolcalls/ThinkToolCall.stories.tsx +0 -98
  1841. package/packages/webui/src/components/toolcalls/ThinkToolCall.tsx +0 -86
  1842. package/packages/webui/src/components/toolcalls/UpdatedPlanToolCall.stories.tsx +0 -100
  1843. package/packages/webui/src/components/toolcalls/UpdatedPlanToolCall.tsx +0 -188
  1844. package/packages/webui/src/components/toolcalls/WebFetchToolCall.tsx +0 -195
  1845. package/packages/webui/src/components/toolcalls/WriteToolCall.stories.tsx +0 -68
  1846. package/packages/webui/src/components/toolcalls/WriteToolCall.tsx +0 -132
  1847. package/packages/webui/src/components/toolcalls/index.ts +0 -22
  1848. package/packages/webui/src/components/toolcalls/shared/CodeBlock.stories.tsx +0 -52
  1849. package/packages/webui/src/components/toolcalls/shared/CopyButton.stories.tsx +0 -54
  1850. package/packages/webui/src/components/toolcalls/shared/LayoutComponents.css +0 -207
  1851. package/packages/webui/src/components/toolcalls/shared/LayoutComponents.tsx +0 -188
  1852. package/packages/webui/src/components/toolcalls/shared/LocationsList.stories.tsx +0 -45
  1853. package/packages/webui/src/components/toolcalls/shared/StatusIndicator.stories.tsx +0 -51
  1854. package/packages/webui/src/components/toolcalls/shared/ToolCallCard.stories.tsx +0 -80
  1855. package/packages/webui/src/components/toolcalls/shared/ToolCallContainer.stories.tsx +0 -79
  1856. package/packages/webui/src/components/toolcalls/shared/copyUtils.tsx +0 -99
  1857. package/packages/webui/src/components/toolcalls/shared/index.ts +0 -43
  1858. package/packages/webui/src/components/toolcalls/shared/types.ts +0 -95
  1859. package/packages/webui/src/components/toolcalls/shared/utils.ts +0 -284
  1860. package/packages/webui/src/components/ui/Button.stories.tsx +0 -83
  1861. package/packages/webui/src/components/ui/Button.tsx +0 -143
  1862. package/packages/webui/src/components/ui/Input.tsx +0 -149
  1863. package/packages/webui/src/components/ui/Tooltip.stories.tsx +0 -68
  1864. package/packages/webui/src/components/ui/Tooltip.tsx +0 -73
  1865. package/packages/webui/src/context/PlatformContext.tsx +0 -104
  1866. package/packages/webui/src/hooks/useLocalStorage.ts +0 -33
  1867. package/packages/webui/src/hooks/useTheme.ts +0 -35
  1868. package/packages/webui/src/index.ts +0 -256
  1869. package/packages/webui/src/styles/components.css +0 -524
  1870. package/packages/webui/src/styles/timeline.css +0 -69
  1871. package/packages/webui/src/styles/variables.css +0 -197
  1872. package/packages/webui/src/types/chat.ts +0 -28
  1873. package/packages/webui/src/types/completion.ts +0 -42
  1874. package/packages/webui/src/types/messages.ts +0 -13
  1875. package/packages/webui/src/types/theme.ts +0 -7
  1876. package/packages/webui/src/types/toolCall.ts +0 -48
  1877. package/packages/webui/src/utils/sessionGrouping.ts +0 -126
  1878. package/packages/webui/tailwind.config.cjs +0 -11
  1879. package/packages/webui/tailwind.preset.cjs +0 -90
  1880. package/packages/webui/tsconfig.json +0 -21
  1881. package/packages/webui/vite.config.ts +0 -59
  1882. package/packages/zed-extension/LICENSE +0 -22
  1883. package/packages/zed-extension/README.md +0 -126
  1884. package/packages/zed-extension/extension.toml +0 -32
  1885. package/packages/zed-extension/qwen-code.svg +0 -1
  1886. package/patches/README.md +0 -293
  1887. package/pyproject.toml +0 -54
  1888. package/requirements.txt +0 -10
  1889. package/scripts/build.js +0 -88
  1890. package/scripts/build_package.js +0 -37
  1891. package/scripts/build_sandbox.js +0 -174
  1892. package/scripts/build_vscode_companion.js +0 -30
  1893. package/scripts/check-build-status.js +0 -148
  1894. package/scripts/check-i18n.ts +0 -462
  1895. package/scripts/check-lockfile.js +0 -74
  1896. package/scripts/clean.js +0 -59
  1897. package/scripts/copy_bundle_assets.js +0 -90
  1898. package/scripts/copy_files.js +0 -86
  1899. package/scripts/create_alias.sh +0 -39
  1900. package/scripts/dev.js +0 -109
  1901. package/scripts/esbuild-shims.js +0 -29
  1902. package/scripts/generate-git-commit-info.js +0 -71
  1903. package/scripts/generate-settings-schema.ts +0 -146
  1904. package/scripts/get-release-version.js +0 -411
  1905. package/scripts/ice-mobile.js +0 -5
  1906. package/scripts/ice-session.js +0 -6
  1907. package/scripts/ice-skills.js +0 -31
  1908. package/scripts/ice-teams.js +0 -34
  1909. package/scripts/ice-v10.js +0 -276
  1910. package/scripts/ice-v11.js +0 -276
  1911. package/scripts/ice-v12.js +0 -383
  1912. package/scripts/ice-v13.js +0 -383
  1913. package/scripts/ice-v14.js +0 -568
  1914. package/scripts/ice-v2.js +0 -26
  1915. package/scripts/ice-v3-core.js +0 -261
  1916. package/scripts/ice-v3.js +0 -46
  1917. package/scripts/ice-v4.js +0 -657
  1918. package/scripts/ice-v5.js +0 -371
  1919. package/scripts/ice-v6.js +0 -305
  1920. package/scripts/ice-v7.js +0 -291
  1921. package/scripts/ice-v8.js +0 -550
  1922. package/scripts/ice-v9.js +0 -546
  1923. package/scripts/install-ice.sh +0 -70
  1924. package/scripts/install.sh +0 -136
  1925. package/scripts/installation/INSTALLATION_GUIDE.md +0 -250
  1926. package/scripts/installation/install-qwen-with-source.bat +0 -302
  1927. package/scripts/installation/install-qwen-with-source.sh +0 -570
  1928. package/scripts/lint.js +0 -205
  1929. package/scripts/local_telemetry.js +0 -219
  1930. package/scripts/postinstall.cjs +0 -14
  1931. package/scripts/pre-commit.js +0 -22
  1932. package/scripts/prepare-package.js +0 -186
  1933. package/scripts/prepare-termux.cjs +0 -26
  1934. package/scripts/sandbox_command.js +0 -128
  1935. package/scripts/start.js +0 -86
  1936. package/scripts/telemetry.js +0 -85
  1937. package/scripts/telemetry_gcp.js +0 -188
  1938. package/scripts/telemetry_utils.js +0 -450
  1939. package/scripts/test-v10.js +0 -18
  1940. package/scripts/test-v11.js +0 -18
  1941. package/scripts/test-v12.js +0 -18
  1942. package/scripts/test-v13.js +0 -18
  1943. package/scripts/test-v14.js +0 -18
  1944. package/scripts/test-v3.js +0 -47
  1945. package/scripts/test-v4.js +0 -47
  1946. package/scripts/test-v6.js +0 -59
  1947. package/scripts/test-v8.js +0 -42
  1948. package/scripts/test-v9.js +0 -18
  1949. package/scripts/test-windows-paths.js +0 -51
  1950. package/scripts/tests/get-release-version.test.js +0 -186
  1951. package/scripts/tests/test-setup.ts +0 -12
  1952. package/scripts/tests/vitest.config.ts +0 -26
  1953. package/scripts/unused-keys-only-in-locales.json +0 -62
  1954. package/scripts/version.js +0 -112
  1955. package/test-reports/0.10.3-termux/README.md +0 -213
  1956. package/test-reports/0.10.3-termux/TEST-REPORT-2026-02-17.md +0 -114
  1957. package/test-reports/0.11.0-termux/TEST-REPORT-2026-03-01.md +0 -104
  1958. package/test-reports/0.11.3-termux/TEST-REPORT-2026-03-07.md +0 -156
  1959. package/test-reports/0.12.0-termux/CHECKLIST-MANUALE.md +0 -217
  1960. package/test-reports/0.12.0-termux/TEST-REPORT-2026-03-09.md +0 -225
  1961. package/test-reports/README.md +0 -60
  1962. package/test-reports/suites/README.md +0 -22
  1963. package/test-reports/suites/basic-smoke.md +0 -162
  1964. package/test-reports/suites/latest/termux.md +0 -202
  1965. package/test-reports/suites/qwen-test-suite.md +0 -200
  1966. package/test-reports/suites/termux-runtime.md +0 -201
  1967. package/tsconfig.json +0 -32
  1968. package/vitest.config.ts +0 -14
@@ -1,2946 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- /* eslint-disable @typescript-eslint/no-explicit-any */
8
- import type { Mock, MockInstance } from 'vitest';
9
- import { describe, it, expect, vi, beforeEach } from 'vitest';
10
- import { renderHook, act, waitFor } from '@testing-library/react';
11
- import { useGeminiStream } from './useGeminiStream.js';
12
- import * as atCommandProcessor from './atCommandProcessor.js';
13
- import type {
14
- TrackedToolCall,
15
- TrackedCompletedToolCall,
16
- TrackedExecutingToolCall,
17
- TrackedCancelledToolCall,
18
- TrackedWaitingToolCall,
19
- } from './useReactToolScheduler.js';
20
- import { useReactToolScheduler } from './useReactToolScheduler.js';
21
- import type {
22
- Config,
23
- EditorType,
24
- GeminiClient,
25
- AnyToolInvocation,
26
- } from '@mmmbuto/qwen-code-termux-core';
27
- import {
28
- ApprovalMode,
29
- AuthType,
30
- GeminiEventType as ServerGeminiEventType,
31
- ToolErrorType,
32
- ToolConfirmationOutcome,
33
- } from '@mmmbuto/qwen-code-termux-core';
34
- import type { Part, PartListUnion } from '@google/genai';
35
- import type { UseHistoryManagerReturn } from './useHistoryManager.js';
36
- import type { HistoryItem, SlashCommandProcessorResult } from '../types.js';
37
- import { MessageType, StreamingState } from '../types.js';
38
- import type { LoadedSettings } from '../../config/settings.js';
39
-
40
- // --- MOCKS ---
41
- const mockSendMessageStream = vi
42
- .fn()
43
- .mockReturnValue((async function* () {})());
44
- const mockStartChat = vi.fn();
45
-
46
- const MockedGeminiClientClass = vi.hoisted(() =>
47
- vi.fn().mockImplementation(function (this: any, _config: any) {
48
- // _config
49
- this.startChat = mockStartChat;
50
- this.sendMessageStream = mockSendMessageStream;
51
- this.addHistory = vi.fn();
52
- this.getChatRecordingService = vi.fn().mockReturnValue({
53
- recordThought: vi.fn(),
54
- initialize: vi.fn(),
55
- recordMessage: vi.fn(),
56
- recordMessageTokens: vi.fn(),
57
- recordToolCalls: vi.fn(),
58
- getConversationFile: vi.fn(),
59
- });
60
- }),
61
- );
62
-
63
- const MockedUserPromptEvent = vi.hoisted(() =>
64
- vi.fn().mockImplementation(() => {}),
65
- );
66
- const MockedApiCancelEvent = vi.hoisted(() =>
67
- vi.fn().mockImplementation(() => {}),
68
- );
69
- const mockParseAndFormatApiError = vi.hoisted(() =>
70
- vi.fn(
71
- (msg: unknown) =>
72
- `[API Error: ${typeof msg === 'string' ? msg : 'An unknown error occurred.'}]`,
73
- ),
74
- );
75
- const mockLogApiCancel = vi.hoisted(() => vi.fn());
76
-
77
- vi.mock('@mmmbuto/qwen-code-termux-core', async (importOriginal) => {
78
- const actualCoreModule = (await importOriginal()) as any;
79
- return {
80
- ...actualCoreModule,
81
- GitService: vi.fn(),
82
- GeminiClient: MockedGeminiClientClass,
83
- UserPromptEvent: MockedUserPromptEvent,
84
- ApiCancelEvent: MockedApiCancelEvent,
85
- parseAndFormatApiError: mockParseAndFormatApiError,
86
- logApiCancel: mockLogApiCancel,
87
- };
88
- });
89
-
90
- const mockUseReactToolScheduler = useReactToolScheduler as Mock;
91
- vi.mock('./useReactToolScheduler.js', async (importOriginal) => {
92
- const actualSchedulerModule = (await importOriginal()) as any;
93
- return {
94
- ...(actualSchedulerModule || {}),
95
- useReactToolScheduler: vi.fn(),
96
- };
97
- });
98
-
99
- vi.mock('./shellCommandProcessor.js', () => ({
100
- useShellCommandProcessor: vi.fn().mockReturnValue({
101
- handleShellCommand: vi.fn(),
102
- }),
103
- }));
104
-
105
- vi.mock('./atCommandProcessor.js');
106
-
107
- vi.mock('../utils/markdownUtilities.js', () => ({
108
- findLastSafeSplitPoint: vi.fn((s: string) => s.length),
109
- }));
110
-
111
- vi.mock('./useLogger.js', () => ({
112
- useLogger: vi.fn().mockReturnValue({
113
- logMessage: vi.fn().mockResolvedValue(undefined),
114
- }),
115
- }));
116
-
117
- const mockStartNewPrompt = vi.fn();
118
- const mockAddUsage = vi.fn();
119
- vi.mock('../contexts/SessionContext.js', () => ({
120
- useSessionStats: vi.fn(() => ({
121
- startNewPrompt: mockStartNewPrompt,
122
- addUsage: mockAddUsage,
123
- getPromptCount: vi.fn(() => 5),
124
- stats: {
125
- sessionId: 'test-session-id',
126
- },
127
- })),
128
- }));
129
-
130
- vi.mock('./slashCommandProcessor.js', () => ({
131
- handleSlashCommand: vi.fn().mockReturnValue(false),
132
- }));
133
-
134
- // --- END MOCKS ---
135
-
136
- // --- Tests for useGeminiStream Hook ---
137
- describe('useGeminiStream', () => {
138
- let mockAddItem: Mock;
139
- let mockConfig: Config;
140
- let mockOnDebugMessage: Mock;
141
- let mockHandleSlashCommand: Mock;
142
- let mockScheduleToolCalls: Mock;
143
- let mockCancelAllToolCalls: Mock;
144
- let mockMarkToolsAsSubmitted: Mock;
145
- let handleAtCommandSpy: MockInstance;
146
-
147
- beforeEach(() => {
148
- vi.clearAllMocks(); // Clear mocks before each test
149
-
150
- mockAddItem = vi.fn();
151
- // Define the mock for getGeminiClient
152
- const mockGetGeminiClient = vi.fn().mockImplementation(() => {
153
- // MockedGeminiClientClass is defined in the module scope by the previous change.
154
- // It will use the mockStartChat and mockSendMessageStream that are managed within beforeEach.
155
- const clientInstance = new MockedGeminiClientClass(mockConfig);
156
- return clientInstance;
157
- });
158
-
159
- const contentGeneratorConfig = {
160
- model: 'test-model',
161
- apiKey: 'test-key',
162
- vertexai: false,
163
- authType: AuthType.USE_GEMINI,
164
- };
165
-
166
- mockConfig = {
167
- apiKey: 'test-api-key',
168
- model: 'gemini-pro',
169
- sandbox: false,
170
- targetDir: '/test/dir',
171
- debugMode: false,
172
- question: undefined,
173
- fullContext: false,
174
- coreTools: [],
175
- toolDiscoveryCommand: undefined,
176
- toolCallCommand: undefined,
177
- mcpServerCommand: undefined,
178
- mcpServers: undefined,
179
- userAgent: 'test-agent',
180
- userMemory: '',
181
- geminiMdFileCount: 0,
182
- alwaysSkipModificationConfirmation: false,
183
- vertexai: false,
184
- contextFileName: undefined,
185
- getToolRegistry: vi.fn(
186
- () => ({ getToolSchemaList: vi.fn(() => []) }) as any,
187
- ),
188
- getProjectRoot: vi.fn(() => '/test/dir'),
189
- getCheckpointingEnabled: vi.fn(() => false),
190
- getGeminiClient: mockGetGeminiClient,
191
- getApprovalMode: () => ApprovalMode.DEFAULT,
192
- getUsageStatisticsEnabled: () => true,
193
- getDebugMode: () => false,
194
- addHistory: vi.fn(),
195
- getSessionId() {
196
- return 'test-session-id';
197
- },
198
- setQuotaErrorOccurred: vi.fn(),
199
- getQuotaErrorOccurred: vi.fn(() => false),
200
- getModel: vi.fn(() => 'gemini-2.5-pro'),
201
- getContentGeneratorConfig: vi
202
- .fn()
203
- .mockReturnValue(contentGeneratorConfig),
204
- getMaxSessionTurns: vi.fn(() => 50),
205
- } as unknown as Config;
206
- mockOnDebugMessage = vi.fn();
207
- mockHandleSlashCommand = vi.fn().mockResolvedValue(false);
208
-
209
- // Mock return value for useReactToolScheduler
210
- mockScheduleToolCalls = vi.fn();
211
- mockCancelAllToolCalls = vi.fn();
212
- mockMarkToolsAsSubmitted = vi.fn();
213
-
214
- // Default mock for useReactToolScheduler to prevent toolCalls being undefined initially
215
- mockUseReactToolScheduler.mockReturnValue([
216
- [], // Default to empty array for toolCalls
217
- mockScheduleToolCalls,
218
- mockCancelAllToolCalls,
219
- mockMarkToolsAsSubmitted,
220
- ]);
221
-
222
- // Reset mocks for GeminiClient instance methods (startChat and sendMessageStream)
223
- // The GeminiClient constructor itself is mocked at the module level.
224
- mockStartChat.mockClear().mockResolvedValue({
225
- sendMessageStream: mockSendMessageStream,
226
- } as unknown as any); // GeminiChat -> any
227
- mockSendMessageStream
228
- .mockClear()
229
- .mockReturnValue((async function* () {})());
230
- handleAtCommandSpy = vi.spyOn(atCommandProcessor, 'handleAtCommand');
231
- });
232
-
233
- const mockLoadedSettings: LoadedSettings = {
234
- merged: { preferredEditor: 'vscode' },
235
- user: { path: '/user/settings.json', settings: {} },
236
- workspace: { path: '/workspace/.qwen/settings.json', settings: {} },
237
- errors: [],
238
- forScope: vi.fn(),
239
- setValue: vi.fn(),
240
- } as unknown as LoadedSettings;
241
-
242
- const renderTestHook = (
243
- initialToolCalls: TrackedToolCall[] = [],
244
- geminiClient?: any,
245
- ) => {
246
- let currentToolCalls = initialToolCalls;
247
- const setToolCalls = (newToolCalls: TrackedToolCall[]) => {
248
- currentToolCalls = newToolCalls;
249
- };
250
-
251
- mockUseReactToolScheduler.mockImplementation(() => [
252
- currentToolCalls,
253
- mockScheduleToolCalls,
254
- mockCancelAllToolCalls,
255
- mockMarkToolsAsSubmitted,
256
- ]);
257
-
258
- const client = geminiClient || mockConfig.getGeminiClient();
259
-
260
- const { result, rerender } = renderHook(
261
- (props: {
262
- client: any;
263
- history: HistoryItem[];
264
- addItem: UseHistoryManagerReturn['addItem'];
265
- config: Config;
266
- onDebugMessage: (message: string) => void;
267
- handleSlashCommand: (
268
- cmd: PartListUnion,
269
- ) => Promise<SlashCommandProcessorResult | false>;
270
- shellModeActive: boolean;
271
- loadedSettings: LoadedSettings;
272
- toolCalls?: TrackedToolCall[]; // Allow passing updated toolCalls
273
- }) => {
274
- // Update the mock's return value if new toolCalls are passed in props
275
- if (props.toolCalls) {
276
- setToolCalls(props.toolCalls);
277
- }
278
- return useGeminiStream(
279
- props.client,
280
- props.history,
281
- props.addItem,
282
- props.config,
283
- props.loadedSettings,
284
- props.onDebugMessage,
285
- props.handleSlashCommand,
286
- props.shellModeActive,
287
- () => 'vscode' as EditorType,
288
- () => {},
289
- () => Promise.resolve(),
290
- false,
291
- () => {},
292
- () => {},
293
- () => {},
294
- () => {},
295
- 80,
296
- 24,
297
- );
298
- },
299
- {
300
- initialProps: {
301
- client,
302
- history: [],
303
- addItem: mockAddItem as unknown as UseHistoryManagerReturn['addItem'],
304
- config: mockConfig,
305
- onDebugMessage: mockOnDebugMessage,
306
- handleSlashCommand: mockHandleSlashCommand as unknown as (
307
- cmd: PartListUnion,
308
- ) => Promise<SlashCommandProcessorResult | false>,
309
- shellModeActive: false,
310
- loadedSettings: mockLoadedSettings,
311
- toolCalls: initialToolCalls,
312
- },
313
- },
314
- );
315
- return {
316
- result,
317
- rerender,
318
- mockMarkToolsAsSubmitted,
319
- mockSendMessageStream,
320
- client,
321
- };
322
- };
323
-
324
- it('should not submit tool responses if not all tool calls are completed', () => {
325
- const toolCalls: TrackedToolCall[] = [
326
- {
327
- request: {
328
- callId: 'call1',
329
- name: 'tool1',
330
- args: {},
331
- isClientInitiated: false,
332
- prompt_id: 'prompt-id-1',
333
- },
334
- status: 'success',
335
- responseSubmittedToGemini: false,
336
- response: {
337
- callId: 'call1',
338
- responseParts: [{ text: 'tool 1 response' }],
339
- error: undefined,
340
- errorType: undefined, // FIX: Added missing property
341
- resultDisplay: 'Tool 1 success display',
342
- },
343
- tool: {
344
- name: 'tool1',
345
- displayName: 'tool1',
346
- description: 'desc1',
347
- build: vi.fn(),
348
- } as any,
349
- invocation: {
350
- getDescription: () => `Mock description`,
351
- } as unknown as AnyToolInvocation,
352
- startTime: Date.now(),
353
- endTime: Date.now(),
354
- } as TrackedCompletedToolCall,
355
- {
356
- request: {
357
- callId: 'call2',
358
- name: 'tool2',
359
- args: {},
360
- prompt_id: 'prompt-id-1',
361
- },
362
- status: 'executing',
363
- responseSubmittedToGemini: false,
364
- tool: {
365
- name: 'tool2',
366
- displayName: 'tool2',
367
- description: 'desc2',
368
- build: vi.fn(),
369
- } as any,
370
- invocation: {
371
- getDescription: () => `Mock description`,
372
- } as unknown as AnyToolInvocation,
373
- startTime: Date.now(),
374
- liveOutput: '...',
375
- } as TrackedExecutingToolCall,
376
- ];
377
-
378
- const { mockMarkToolsAsSubmitted, mockSendMessageStream } =
379
- renderTestHook(toolCalls);
380
-
381
- // Effect for submitting tool responses depends on toolCalls and isResponding
382
- // isResponding is initially false, so the effect should run.
383
-
384
- expect(mockMarkToolsAsSubmitted).not.toHaveBeenCalled();
385
- expect(mockSendMessageStream).not.toHaveBeenCalled(); // submitQuery uses this
386
- });
387
-
388
- it('should submit tool responses when all tool calls are completed and ready', async () => {
389
- const toolCall1ResponseParts: Part[] = [{ text: 'tool 1 final response' }];
390
- const toolCall2ResponseParts: Part[] = [{ text: 'tool 2 final response' }];
391
- const completedToolCalls: TrackedToolCall[] = [
392
- {
393
- request: {
394
- callId: 'call1',
395
- name: 'tool1',
396
- args: {},
397
- isClientInitiated: false,
398
- prompt_id: 'prompt-id-2',
399
- },
400
- status: 'success',
401
- responseSubmittedToGemini: false,
402
- response: {
403
- callId: 'call1',
404
- responseParts: toolCall1ResponseParts,
405
- errorType: undefined, // FIX: Added missing property
406
- },
407
- tool: {
408
- displayName: 'MockTool',
409
- },
410
- invocation: {
411
- getDescription: () => `Mock description`,
412
- } as unknown as AnyToolInvocation,
413
- } as TrackedCompletedToolCall,
414
- {
415
- request: {
416
- callId: 'call2',
417
- name: 'tool2',
418
- args: {},
419
- isClientInitiated: false,
420
- prompt_id: 'prompt-id-2',
421
- },
422
- status: 'error',
423
- responseSubmittedToGemini: false,
424
- response: {
425
- callId: 'call2',
426
- responseParts: toolCall2ResponseParts,
427
- errorType: ToolErrorType.UNHANDLED_EXCEPTION, // FIX: Added missing property
428
- },
429
- } as TrackedCompletedToolCall, // Treat error as a form of completion for submission
430
- ];
431
-
432
- // Capture the onComplete callback
433
- let capturedOnComplete:
434
- | ((completedTools: TrackedToolCall[]) => Promise<void>)
435
- | null = null;
436
-
437
- mockUseReactToolScheduler.mockImplementation((onComplete) => {
438
- capturedOnComplete = onComplete;
439
- return [[], mockScheduleToolCalls, mockMarkToolsAsSubmitted];
440
- });
441
-
442
- renderHook(() =>
443
- useGeminiStream(
444
- new MockedGeminiClientClass(mockConfig),
445
- [],
446
- mockAddItem,
447
- mockConfig,
448
- mockLoadedSettings,
449
- mockOnDebugMessage,
450
- mockHandleSlashCommand,
451
- false,
452
- () => 'vscode' as EditorType,
453
- () => {},
454
- () => Promise.resolve(),
455
- false,
456
- () => {},
457
- () => {},
458
- () => {},
459
- () => {},
460
- 80,
461
- 24,
462
- ),
463
- );
464
-
465
- // Trigger the onComplete callback with completed tools
466
- await act(async () => {
467
- if (capturedOnComplete) {
468
- await capturedOnComplete(completedToolCalls);
469
- }
470
- });
471
-
472
- await waitFor(() => {
473
- expect(mockMarkToolsAsSubmitted).toHaveBeenCalledTimes(1);
474
- expect(mockSendMessageStream).toHaveBeenCalledTimes(1);
475
- });
476
-
477
- const expectedMergedResponse = [
478
- ...toolCall1ResponseParts,
479
- ...toolCall2ResponseParts,
480
- ];
481
- expect(mockSendMessageStream).toHaveBeenCalledWith(
482
- expectedMergedResponse,
483
- expect.any(AbortSignal),
484
- 'prompt-id-2',
485
- { isContinuation: true },
486
- );
487
- });
488
-
489
- it('should handle all tool calls being cancelled', async () => {
490
- const cancelledToolCalls: TrackedToolCall[] = [
491
- {
492
- request: {
493
- callId: '1',
494
- name: 'testTool',
495
- args: {},
496
- isClientInitiated: false,
497
- prompt_id: 'prompt-id-3',
498
- },
499
- status: 'cancelled',
500
- response: {
501
- callId: '1',
502
- responseParts: [{ text: 'cancelled' }],
503
- errorType: undefined, // FIX: Added missing property
504
- },
505
- responseSubmittedToGemini: false,
506
- tool: {
507
- displayName: 'mock tool',
508
- },
509
- invocation: {
510
- getDescription: () => `Mock description`,
511
- } as unknown as AnyToolInvocation,
512
- } as TrackedCancelledToolCall,
513
- ];
514
- const client = new MockedGeminiClientClass(mockConfig);
515
-
516
- // Capture the onComplete callback
517
- let capturedOnComplete:
518
- | ((completedTools: TrackedToolCall[]) => Promise<void>)
519
- | null = null;
520
-
521
- mockUseReactToolScheduler.mockImplementation((onComplete) => {
522
- capturedOnComplete = onComplete;
523
- return [[], mockScheduleToolCalls, mockMarkToolsAsSubmitted];
524
- });
525
-
526
- renderHook(() =>
527
- useGeminiStream(
528
- client,
529
- [],
530
- mockAddItem,
531
- mockConfig,
532
- mockLoadedSettings,
533
- mockOnDebugMessage,
534
- mockHandleSlashCommand,
535
- false,
536
- () => 'vscode' as EditorType,
537
- () => {},
538
- () => Promise.resolve(),
539
- false,
540
- () => {},
541
- () => {},
542
- () => {},
543
- () => {},
544
- 80,
545
- 24,
546
- ),
547
- );
548
-
549
- // Trigger the onComplete callback with cancelled tools
550
- await act(async () => {
551
- if (capturedOnComplete) {
552
- await capturedOnComplete(cancelledToolCalls);
553
- }
554
- });
555
-
556
- await waitFor(() => {
557
- expect(mockMarkToolsAsSubmitted).toHaveBeenCalledWith(['1']);
558
- expect(client.addHistory).toHaveBeenCalledWith({
559
- role: 'user',
560
- parts: [{ text: 'cancelled' }],
561
- });
562
- // Ensure we do NOT call back to the API
563
- expect(mockSendMessageStream).not.toHaveBeenCalled();
564
- });
565
- });
566
-
567
- it('should group multiple cancelled tool call responses into a single history entry', async () => {
568
- const cancelledToolCall1: TrackedCancelledToolCall = {
569
- request: {
570
- callId: 'cancel-1',
571
- name: 'toolA',
572
- args: {},
573
- isClientInitiated: false,
574
- prompt_id: 'prompt-id-7',
575
- },
576
- tool: {
577
- name: 'toolA',
578
- displayName: 'toolA',
579
- description: 'descA',
580
- build: vi.fn(),
581
- } as any,
582
- invocation: {
583
- getDescription: () => `Mock description`,
584
- } as unknown as AnyToolInvocation,
585
- status: 'cancelled',
586
- response: {
587
- callId: 'cancel-1',
588
- responseParts: [
589
- { functionResponse: { name: 'toolA', id: 'cancel-1' } },
590
- ],
591
- resultDisplay: undefined,
592
- error: undefined,
593
- errorType: undefined, // FIX: Added missing property
594
- },
595
- responseSubmittedToGemini: false,
596
- };
597
- const cancelledToolCall2: TrackedCancelledToolCall = {
598
- request: {
599
- callId: 'cancel-2',
600
- name: 'toolB',
601
- args: {},
602
- isClientInitiated: false,
603
- prompt_id: 'prompt-id-8',
604
- },
605
- tool: {
606
- name: 'toolB',
607
- displayName: 'toolB',
608
- description: 'descB',
609
- build: vi.fn(),
610
- } as any,
611
- invocation: {
612
- getDescription: () => `Mock description`,
613
- } as unknown as AnyToolInvocation,
614
- status: 'cancelled',
615
- response: {
616
- callId: 'cancel-2',
617
- responseParts: [
618
- { functionResponse: { name: 'toolB', id: 'cancel-2' } },
619
- ],
620
- resultDisplay: undefined,
621
- error: undefined,
622
- errorType: undefined, // FIX: Added missing property
623
- },
624
- responseSubmittedToGemini: false,
625
- };
626
- const allCancelledTools = [cancelledToolCall1, cancelledToolCall2];
627
- const client = new MockedGeminiClientClass(mockConfig);
628
-
629
- let capturedOnComplete:
630
- | ((completedTools: TrackedToolCall[]) => Promise<void>)
631
- | null = null;
632
-
633
- mockUseReactToolScheduler.mockImplementation((onComplete) => {
634
- capturedOnComplete = onComplete;
635
- return [[], mockScheduleToolCalls, mockMarkToolsAsSubmitted];
636
- });
637
-
638
- renderHook(() =>
639
- useGeminiStream(
640
- client,
641
- [],
642
- mockAddItem,
643
- mockConfig,
644
- mockLoadedSettings,
645
- mockOnDebugMessage,
646
- mockHandleSlashCommand,
647
- false,
648
- () => 'vscode' as EditorType,
649
- () => {},
650
- () => Promise.resolve(),
651
- false,
652
- () => {},
653
- () => {},
654
- () => {},
655
- () => {},
656
- 80,
657
- 24,
658
- ),
659
- );
660
-
661
- // Trigger the onComplete callback with multiple cancelled tools
662
- await act(async () => {
663
- if (capturedOnComplete) {
664
- await capturedOnComplete(allCancelledTools);
665
- }
666
- });
667
-
668
- await waitFor(() => {
669
- // The tools should be marked as submitted locally
670
- expect(mockMarkToolsAsSubmitted).toHaveBeenCalledWith([
671
- 'cancel-1',
672
- 'cancel-2',
673
- ]);
674
-
675
- // Crucially, addHistory should be called only ONCE
676
- expect(client.addHistory).toHaveBeenCalledTimes(1);
677
-
678
- // And that single call should contain BOTH function responses
679
- expect(client.addHistory).toHaveBeenCalledWith({
680
- role: 'user',
681
- parts: [
682
- ...(cancelledToolCall1.response.responseParts as Part[]),
683
- ...(cancelledToolCall2.response.responseParts as Part[]),
684
- ],
685
- });
686
-
687
- // No message should be sent back to the API for a turn with only cancellations
688
- expect(mockSendMessageStream).not.toHaveBeenCalled();
689
- });
690
- });
691
-
692
- it('should not flicker streaming state to Idle between tool completion and submission', async () => {
693
- const toolCallResponseParts: PartListUnion = [
694
- { text: 'tool 1 final response' },
695
- ];
696
-
697
- const initialToolCalls: TrackedToolCall[] = [
698
- {
699
- request: {
700
- callId: 'call1',
701
- name: 'tool1',
702
- args: {},
703
- isClientInitiated: false,
704
- prompt_id: 'prompt-id-4',
705
- },
706
- status: 'executing',
707
- responseSubmittedToGemini: false,
708
- tool: {
709
- name: 'tool1',
710
- displayName: 'tool1',
711
- description: 'desc',
712
- build: vi.fn(),
713
- } as any,
714
- invocation: {
715
- getDescription: () => `Mock description`,
716
- } as unknown as AnyToolInvocation,
717
- startTime: Date.now(),
718
- } as TrackedExecutingToolCall,
719
- ];
720
-
721
- const completedToolCalls: TrackedToolCall[] = [
722
- {
723
- ...(initialToolCalls[0] as TrackedExecutingToolCall),
724
- status: 'success',
725
- response: {
726
- callId: 'call1',
727
- responseParts: toolCallResponseParts,
728
- error: undefined,
729
- errorType: undefined, // FIX: Added missing property
730
- resultDisplay: 'Tool 1 success display',
731
- },
732
- endTime: Date.now(),
733
- } as TrackedCompletedToolCall,
734
- ];
735
-
736
- // Capture the onComplete callback
737
- let capturedOnComplete:
738
- | ((completedTools: TrackedToolCall[]) => Promise<void>)
739
- | null = null;
740
- let currentToolCalls = initialToolCalls;
741
-
742
- mockUseReactToolScheduler.mockImplementation((onComplete) => {
743
- capturedOnComplete = onComplete;
744
- return [
745
- currentToolCalls,
746
- mockScheduleToolCalls,
747
- mockMarkToolsAsSubmitted,
748
- ];
749
- });
750
-
751
- const { result, rerender } = renderHook(() =>
752
- useGeminiStream(
753
- new MockedGeminiClientClass(mockConfig),
754
- [],
755
- mockAddItem,
756
- mockConfig,
757
- mockLoadedSettings,
758
- mockOnDebugMessage,
759
- mockHandleSlashCommand,
760
- false,
761
- () => 'vscode' as EditorType,
762
- () => {},
763
- () => Promise.resolve(),
764
- false,
765
- () => {},
766
- () => {},
767
- () => {},
768
- () => {},
769
- 80,
770
- 24,
771
- ),
772
- );
773
-
774
- // 1. Initial state should be Responding because a tool is executing.
775
- expect(result.current.streamingState).toBe(StreamingState.Responding);
776
-
777
- // 2. Update the tool calls to completed state and rerender
778
- currentToolCalls = completedToolCalls;
779
- mockUseReactToolScheduler.mockImplementation((onComplete) => {
780
- capturedOnComplete = onComplete;
781
- return [
782
- completedToolCalls,
783
- mockScheduleToolCalls,
784
- mockMarkToolsAsSubmitted,
785
- ];
786
- });
787
-
788
- act(() => {
789
- rerender();
790
- });
791
-
792
- // 3. The state should *still* be Responding, not Idle.
793
- // This is because the completed tool's response has not been submitted yet.
794
- expect(result.current.streamingState).toBe(StreamingState.Responding);
795
-
796
- // 4. Trigger the onComplete callback to simulate tool completion
797
- await act(async () => {
798
- if (capturedOnComplete) {
799
- await capturedOnComplete(completedToolCalls);
800
- }
801
- });
802
-
803
- // 5. Wait for submitQuery to be called
804
- await waitFor(() => {
805
- expect(mockSendMessageStream).toHaveBeenCalledWith(
806
- toolCallResponseParts,
807
- expect.any(AbortSignal),
808
- 'prompt-id-4',
809
- { isContinuation: true },
810
- );
811
- });
812
-
813
- // 6. After submission, the state should remain Responding until the stream completes.
814
- expect(result.current.streamingState).toBe(StreamingState.Responding);
815
- });
816
-
817
- describe('Cancellation', () => {
818
- it('should cancel an in-progress stream when cancelOngoingRequest is called', async () => {
819
- const mockStream = (async function* () {
820
- yield { type: 'content', value: 'Part 1' };
821
- // Keep the stream open
822
- await new Promise(() => {});
823
- })();
824
- mockSendMessageStream.mockReturnValue(mockStream);
825
-
826
- const { result } = renderTestHook();
827
-
828
- // Start a query
829
- await act(async () => {
830
- result.current.submitQuery('test query');
831
- });
832
-
833
- // Wait for the first part of the response
834
- await waitFor(() => {
835
- expect(result.current.streamingState).toBe(StreamingState.Responding);
836
- });
837
-
838
- // Call cancelOngoingRequest directly
839
- act(() => {
840
- result.current.cancelOngoingRequest();
841
- });
842
-
843
- // Verify cancellation message is added
844
- await waitFor(() => {
845
- expect(mockAddItem).toHaveBeenCalledWith(
846
- {
847
- type: MessageType.INFO,
848
- text: 'Request cancelled.',
849
- },
850
- expect.any(Number),
851
- );
852
- });
853
-
854
- // Verify state is reset
855
- expect(result.current.streamingState).toBe(StreamingState.Idle);
856
- });
857
-
858
- it('should call onCancelSubmit handler when cancelOngoingRequest is called', async () => {
859
- const cancelSubmitSpy = vi.fn();
860
- const mockStream = (async function* () {
861
- yield { type: 'content', value: 'Part 1' };
862
- // Keep the stream open
863
- await new Promise(() => {});
864
- })();
865
- mockSendMessageStream.mockReturnValue(mockStream);
866
-
867
- const { result } = renderHook(() =>
868
- useGeminiStream(
869
- mockConfig.getGeminiClient(),
870
- [],
871
- mockAddItem,
872
- mockConfig,
873
- mockLoadedSettings,
874
- mockOnDebugMessage,
875
- mockHandleSlashCommand,
876
- false,
877
- () => 'vscode' as EditorType,
878
- () => {},
879
- () => Promise.resolve(),
880
- false,
881
- () => {},
882
- () => {},
883
- cancelSubmitSpy,
884
- () => {},
885
- 80,
886
- 24,
887
- ),
888
- );
889
-
890
- // Start a query
891
- await act(async () => {
892
- result.current.submitQuery('test query');
893
- });
894
-
895
- act(() => {
896
- result.current.cancelOngoingRequest();
897
- });
898
-
899
- expect(cancelSubmitSpy).toHaveBeenCalled();
900
- });
901
-
902
- it('should call setShellInputFocused(false) when cancelOngoingRequest is called', async () => {
903
- const setShellInputFocusedSpy = vi.fn();
904
- const mockStream = (async function* () {
905
- yield { type: 'content', value: 'Part 1' };
906
- await new Promise(() => {}); // Keep stream open
907
- })();
908
- mockSendMessageStream.mockReturnValue(mockStream);
909
-
910
- const { result } = renderHook(() =>
911
- useGeminiStream(
912
- mockConfig.getGeminiClient(),
913
- [],
914
- mockAddItem,
915
- mockConfig,
916
- mockLoadedSettings,
917
- mockOnDebugMessage,
918
- mockHandleSlashCommand,
919
- false,
920
- () => 'vscode' as EditorType,
921
- () => {},
922
- () => Promise.resolve(),
923
- false,
924
- () => {},
925
- () => {},
926
- vi.fn(),
927
- setShellInputFocusedSpy, // Pass the spy here
928
- 80,
929
- 24,
930
- ),
931
- );
932
-
933
- // Start a query
934
- await act(async () => {
935
- result.current.submitQuery('test query');
936
- });
937
-
938
- act(() => {
939
- result.current.cancelOngoingRequest();
940
- });
941
-
942
- expect(setShellInputFocusedSpy).toHaveBeenCalledWith(false);
943
- });
944
-
945
- it('should not do anything if cancelOngoingRequest is called when not responding', () => {
946
- const { result } = renderTestHook();
947
-
948
- expect(result.current.streamingState).toBe(StreamingState.Idle);
949
-
950
- // Call cancelOngoingRequest
951
- act(() => {
952
- result.current.cancelOngoingRequest();
953
- });
954
-
955
- // No change should happen, no cancellation message
956
- expect(mockAddItem).not.toHaveBeenCalledWith(
957
- expect.objectContaining({
958
- text: 'Request cancelled.',
959
- }),
960
- expect.any(Number),
961
- );
962
- });
963
-
964
- it('should prevent further processing after cancellation', async () => {
965
- let continueStream: () => void;
966
- const streamPromise = new Promise<void>((resolve) => {
967
- continueStream = resolve;
968
- });
969
-
970
- const mockStream = (async function* () {
971
- yield { type: 'content', value: 'Initial' };
972
- await streamPromise; // Wait until we manually continue
973
- yield { type: 'content', value: ' Canceled' };
974
- })();
975
- mockSendMessageStream.mockReturnValue(mockStream);
976
-
977
- const { result } = renderTestHook();
978
-
979
- await act(async () => {
980
- result.current.submitQuery('long running query');
981
- });
982
-
983
- await waitFor(() => {
984
- expect(result.current.streamingState).toBe(StreamingState.Responding);
985
- });
986
-
987
- // Cancel the request
988
- act(() => {
989
- result.current.cancelOngoingRequest();
990
- });
991
-
992
- // Allow the stream to continue
993
- act(() => {
994
- continueStream();
995
- });
996
-
997
- // Wait a bit to see if the second part is processed
998
- await new Promise((resolve) => setTimeout(resolve, 50));
999
-
1000
- // The text should not have been updated with " Canceled"
1001
- const lastCall = mockAddItem.mock.calls.find(
1002
- (call) => call[0].type === 'gemini',
1003
- );
1004
- expect(lastCall?.[0].text).toBe('Initial');
1005
-
1006
- // The final state should be idle after cancellation
1007
- expect(result.current.streamingState).toBe(StreamingState.Idle);
1008
- });
1009
-
1010
- it('should not cancel if a tool call is in progress (not just responding)', async () => {
1011
- const toolCalls: TrackedToolCall[] = [
1012
- {
1013
- request: { callId: 'call1', name: 'tool1', args: {} },
1014
- status: 'executing',
1015
- responseSubmittedToGemini: false,
1016
- tool: {
1017
- name: 'tool1',
1018
- description: 'desc1',
1019
- build: vi.fn().mockImplementation((_) => ({
1020
- getDescription: () => `Mock description`,
1021
- })),
1022
- } as any,
1023
- invocation: {
1024
- getDescription: () => `Mock description`,
1025
- },
1026
- startTime: Date.now(),
1027
- liveOutput: '...',
1028
- } as TrackedExecutingToolCall,
1029
- ];
1030
-
1031
- const abortSpy = vi.spyOn(AbortController.prototype, 'abort');
1032
- const { result } = renderTestHook(toolCalls);
1033
-
1034
- // State is `Responding` because a tool is running
1035
- expect(result.current.streamingState).toBe(StreamingState.Responding);
1036
-
1037
- // Try to cancel
1038
- act(() => {
1039
- result.current.cancelOngoingRequest();
1040
- });
1041
-
1042
- // Nothing should happen because the state is not `Responding`
1043
- expect(abortSpy).not.toHaveBeenCalled();
1044
- });
1045
- });
1046
-
1047
- describe('Slash Command Handling', () => {
1048
- it('should schedule a tool call when the command processor returns a schedule_tool action', async () => {
1049
- const clientToolRequest: SlashCommandProcessorResult = {
1050
- type: 'schedule_tool',
1051
- toolName: 'save_memory',
1052
- toolArgs: { fact: 'test fact' },
1053
- };
1054
- mockHandleSlashCommand.mockResolvedValue(clientToolRequest);
1055
-
1056
- const { result } = renderTestHook();
1057
-
1058
- await act(async () => {
1059
- await result.current.submitQuery('/memory add "test fact"');
1060
- });
1061
-
1062
- await waitFor(() => {
1063
- expect(mockScheduleToolCalls).toHaveBeenCalledWith(
1064
- [
1065
- expect.objectContaining({
1066
- name: 'save_memory',
1067
- args: { fact: 'test fact' },
1068
- isClientInitiated: true,
1069
- }),
1070
- ],
1071
- expect.any(AbortSignal),
1072
- );
1073
- expect(mockSendMessageStream).not.toHaveBeenCalled();
1074
- });
1075
- });
1076
-
1077
- it('should stop processing and not call Gemini when a command is handled without a tool call', async () => {
1078
- const uiOnlyCommandResult: SlashCommandProcessorResult = {
1079
- type: 'handled',
1080
- };
1081
- mockHandleSlashCommand.mockResolvedValue(uiOnlyCommandResult);
1082
-
1083
- const { result } = renderTestHook();
1084
-
1085
- await act(async () => {
1086
- await result.current.submitQuery('/help');
1087
- });
1088
-
1089
- await waitFor(() => {
1090
- expect(mockHandleSlashCommand).toHaveBeenCalledWith('/help');
1091
- expect(mockScheduleToolCalls).not.toHaveBeenCalled();
1092
- expect(mockSendMessageStream).not.toHaveBeenCalled(); // No LLM call made
1093
- });
1094
- });
1095
-
1096
- it('should call Gemini with prompt content when slash command returns a `submit_prompt` action', async () => {
1097
- const customCommandResult: SlashCommandProcessorResult = {
1098
- type: 'submit_prompt',
1099
- content: 'This is the actual prompt from the command file.',
1100
- };
1101
- mockHandleSlashCommand.mockResolvedValue(customCommandResult);
1102
-
1103
- const { result, mockSendMessageStream: localMockSendMessageStream } =
1104
- renderTestHook();
1105
-
1106
- await act(async () => {
1107
- await result.current.submitQuery('/my-custom-command');
1108
- });
1109
-
1110
- await waitFor(() => {
1111
- expect(mockHandleSlashCommand).toHaveBeenCalledWith(
1112
- '/my-custom-command',
1113
- );
1114
-
1115
- expect(localMockSendMessageStream).not.toHaveBeenCalledWith(
1116
- '/my-custom-command',
1117
- expect.anything(),
1118
- expect.anything(),
1119
- );
1120
-
1121
- expect(localMockSendMessageStream).toHaveBeenCalledWith(
1122
- 'This is the actual prompt from the command file.',
1123
- expect.any(AbortSignal),
1124
- expect.any(String),
1125
- undefined,
1126
- );
1127
-
1128
- expect(mockScheduleToolCalls).not.toHaveBeenCalled();
1129
- });
1130
- });
1131
-
1132
- it('should correctly handle a submit_prompt action with empty content', async () => {
1133
- const emptyPromptResult: SlashCommandProcessorResult = {
1134
- type: 'submit_prompt',
1135
- content: '',
1136
- };
1137
- mockHandleSlashCommand.mockResolvedValue(emptyPromptResult);
1138
-
1139
- const { result, mockSendMessageStream: localMockSendMessageStream } =
1140
- renderTestHook();
1141
-
1142
- await act(async () => {
1143
- await result.current.submitQuery('/emptycmd');
1144
- });
1145
-
1146
- await waitFor(() => {
1147
- expect(mockHandleSlashCommand).toHaveBeenCalledWith('/emptycmd');
1148
- expect(localMockSendMessageStream).toHaveBeenCalledWith(
1149
- '',
1150
- expect.any(AbortSignal),
1151
- expect.any(String),
1152
- undefined,
1153
- );
1154
- });
1155
- });
1156
-
1157
- it('should not call handleSlashCommand for line comments', async () => {
1158
- const { result, mockSendMessageStream: localMockSendMessageStream } =
1159
- renderTestHook();
1160
-
1161
- await act(async () => {
1162
- await result.current.submitQuery('// This is a line comment');
1163
- });
1164
-
1165
- await waitFor(() => {
1166
- expect(mockHandleSlashCommand).not.toHaveBeenCalled();
1167
- expect(localMockSendMessageStream).toHaveBeenCalledWith(
1168
- '// This is a line comment',
1169
- expect.any(AbortSignal),
1170
- expect.any(String),
1171
- undefined,
1172
- );
1173
- });
1174
- });
1175
-
1176
- it('should not call handleSlashCommand for block comments', async () => {
1177
- const { result, mockSendMessageStream: localMockSendMessageStream } =
1178
- renderTestHook();
1179
-
1180
- await act(async () => {
1181
- await result.current.submitQuery('/* This is a block comment */');
1182
- });
1183
-
1184
- await waitFor(() => {
1185
- expect(mockHandleSlashCommand).not.toHaveBeenCalled();
1186
- expect(localMockSendMessageStream).toHaveBeenCalledWith(
1187
- '/* This is a block comment */',
1188
- expect.any(AbortSignal),
1189
- expect.any(String),
1190
- undefined,
1191
- );
1192
- });
1193
- });
1194
- });
1195
-
1196
- describe('Memory Refresh on save_memory', () => {
1197
- it('should call performMemoryRefresh when a save_memory tool call completes successfully', async () => {
1198
- const mockPerformMemoryRefresh = vi.fn();
1199
- const completedToolCall: TrackedCompletedToolCall = {
1200
- request: {
1201
- callId: 'save-mem-call-1',
1202
- name: 'save_memory',
1203
- args: { fact: 'test' },
1204
- isClientInitiated: true,
1205
- prompt_id: 'prompt-id-6',
1206
- },
1207
- status: 'success',
1208
- responseSubmittedToGemini: false,
1209
- response: {
1210
- callId: 'save-mem-call-1',
1211
- responseParts: [{ text: 'Memory saved' }],
1212
- resultDisplay: 'Success: Memory saved',
1213
- error: undefined,
1214
- errorType: undefined, // FIX: Added missing property
1215
- },
1216
- tool: {
1217
- name: 'save_memory',
1218
- displayName: 'save_memory',
1219
- description: 'Saves memory',
1220
- build: vi.fn(),
1221
- } as any,
1222
- invocation: {
1223
- getDescription: () => `Mock description`,
1224
- } as unknown as AnyToolInvocation,
1225
- };
1226
-
1227
- // Capture the onComplete callback
1228
- let capturedOnComplete:
1229
- | ((completedTools: TrackedToolCall[]) => Promise<void>)
1230
- | null = null;
1231
-
1232
- mockUseReactToolScheduler.mockImplementation((onComplete) => {
1233
- capturedOnComplete = onComplete;
1234
- return [[], mockScheduleToolCalls, mockMarkToolsAsSubmitted];
1235
- });
1236
-
1237
- renderHook(() =>
1238
- useGeminiStream(
1239
- new MockedGeminiClientClass(mockConfig),
1240
- [],
1241
- mockAddItem,
1242
- mockConfig,
1243
- mockLoadedSettings,
1244
- mockOnDebugMessage,
1245
- mockHandleSlashCommand,
1246
- false,
1247
- () => 'vscode' as EditorType,
1248
- () => {},
1249
- mockPerformMemoryRefresh,
1250
- false,
1251
- () => {},
1252
- () => {},
1253
- () => {},
1254
- () => {},
1255
- 80,
1256
- 24,
1257
- ),
1258
- );
1259
-
1260
- // Trigger the onComplete callback with the completed save_memory tool
1261
- await act(async () => {
1262
- if (capturedOnComplete) {
1263
- await capturedOnComplete([completedToolCall]);
1264
- }
1265
- });
1266
-
1267
- await waitFor(() => {
1268
- expect(mockPerformMemoryRefresh).toHaveBeenCalledTimes(1);
1269
- });
1270
- });
1271
- });
1272
-
1273
- describe('Error Handling', () => {
1274
- it('should call parseAndFormatApiError with the correct authType on stream initialization failure', async () => {
1275
- // 1. Setup
1276
- const mockError = new Error('Rate limit exceeded');
1277
- const mockAuthType = AuthType.USE_VERTEX_AI;
1278
- mockParseAndFormatApiError.mockClear();
1279
- mockSendMessageStream.mockReturnValue(
1280
- (async function* () {
1281
- yield { type: 'content', value: '' };
1282
- throw mockError;
1283
- })(),
1284
- );
1285
-
1286
- const testConfig = {
1287
- ...mockConfig,
1288
- getContentGeneratorConfig: vi.fn(() => ({
1289
- authType: mockAuthType,
1290
- })),
1291
- getModel: vi.fn(() => 'gemini-2.5-pro'),
1292
- } as unknown as Config;
1293
-
1294
- const { result } = renderHook(() =>
1295
- useGeminiStream(
1296
- new MockedGeminiClientClass(testConfig),
1297
- [],
1298
- mockAddItem,
1299
- testConfig,
1300
- mockLoadedSettings,
1301
- mockOnDebugMessage,
1302
- mockHandleSlashCommand,
1303
- false,
1304
- () => 'vscode' as EditorType,
1305
- () => {},
1306
- () => Promise.resolve(),
1307
- false,
1308
- () => {},
1309
- () => {},
1310
- () => {},
1311
- () => {},
1312
- 80,
1313
- 24,
1314
- ),
1315
- );
1316
-
1317
- // 2. Action
1318
- await act(async () => {
1319
- await result.current.submitQuery('test query');
1320
- });
1321
-
1322
- // 3. Assertion
1323
- await waitFor(() => {
1324
- expect(mockParseAndFormatApiError).toHaveBeenCalledWith(
1325
- 'Rate limit exceeded',
1326
- mockAuthType,
1327
- );
1328
- });
1329
- });
1330
- });
1331
-
1332
- describe('handleApprovalModeChange', () => {
1333
- it('should auto-approve all pending tool calls when switching to YOLO mode', async () => {
1334
- const mockOnConfirm = vi.fn().mockResolvedValue(undefined);
1335
- const awaitingApprovalToolCalls: TrackedToolCall[] = [
1336
- {
1337
- request: {
1338
- callId: 'call1',
1339
- name: 'replace',
1340
- args: { old_string: 'old', new_string: 'new' },
1341
- isClientInitiated: false,
1342
- prompt_id: 'prompt-id-1',
1343
- },
1344
- status: 'awaiting_approval',
1345
- responseSubmittedToGemini: false,
1346
- confirmationDetails: {
1347
- onConfirm: mockOnConfirm,
1348
- onCancel: vi.fn(),
1349
- message: 'Replace text?',
1350
- displayedText: 'Replace old with new',
1351
- },
1352
- tool: {
1353
- name: 'replace',
1354
- displayName: 'replace',
1355
- description: 'Replace text',
1356
- build: vi.fn(),
1357
- } as any,
1358
- invocation: {
1359
- getDescription: () => 'Mock description',
1360
- } as unknown as AnyToolInvocation,
1361
- } as unknown as TrackedWaitingToolCall,
1362
- {
1363
- request: {
1364
- callId: 'call2',
1365
- name: 'read_file',
1366
- args: { path: '/test/file.txt' },
1367
- isClientInitiated: false,
1368
- prompt_id: 'prompt-id-1',
1369
- },
1370
- status: 'awaiting_approval',
1371
- responseSubmittedToGemini: false,
1372
- confirmationDetails: {
1373
- onConfirm: mockOnConfirm,
1374
- onCancel: vi.fn(),
1375
- message: 'Read file?',
1376
- displayedText: 'Read /test/file.txt',
1377
- },
1378
- tool: {
1379
- name: 'read_file',
1380
- displayName: 'read_file',
1381
- description: 'Read file',
1382
- build: vi.fn(),
1383
- } as any,
1384
- invocation: {
1385
- getDescription: () => 'Mock description',
1386
- } as unknown as AnyToolInvocation,
1387
- } as unknown as TrackedWaitingToolCall,
1388
- ];
1389
-
1390
- const { result } = renderTestHook(awaitingApprovalToolCalls);
1391
-
1392
- await act(async () => {
1393
- await result.current.handleApprovalModeChange(ApprovalMode.YOLO);
1394
- });
1395
-
1396
- // Both tool calls should be auto-approved
1397
- expect(mockOnConfirm).toHaveBeenCalledTimes(2);
1398
- expect(mockOnConfirm).toHaveBeenNthCalledWith(
1399
- 1,
1400
- ToolConfirmationOutcome.ProceedOnce,
1401
- );
1402
- expect(mockOnConfirm).toHaveBeenNthCalledWith(
1403
- 2,
1404
- ToolConfirmationOutcome.ProceedOnce,
1405
- );
1406
- });
1407
-
1408
- it('should only auto-approve edit tools when switching to AUTO_EDIT mode', async () => {
1409
- const mockOnConfirmReplace = vi.fn().mockResolvedValue(undefined);
1410
- const mockOnConfirmWrite = vi.fn().mockResolvedValue(undefined);
1411
- const mockOnConfirmRead = vi.fn().mockResolvedValue(undefined);
1412
-
1413
- const awaitingApprovalToolCalls: TrackedToolCall[] = [
1414
- {
1415
- request: {
1416
- callId: 'call1',
1417
- name: 'replace',
1418
- args: { old_string: 'old', new_string: 'new' },
1419
- isClientInitiated: false,
1420
- prompt_id: 'prompt-id-1',
1421
- },
1422
- status: 'awaiting_approval',
1423
- responseSubmittedToGemini: false,
1424
- confirmationDetails: {
1425
- onConfirm: mockOnConfirmReplace,
1426
- onCancel: vi.fn(),
1427
- message: 'Replace text?',
1428
- displayedText: 'Replace old with new',
1429
- },
1430
- tool: {
1431
- name: 'replace',
1432
- displayName: 'replace',
1433
- description: 'Replace text',
1434
- build: vi.fn(),
1435
- } as any,
1436
- invocation: {
1437
- getDescription: () => 'Mock description',
1438
- } as unknown as AnyToolInvocation,
1439
- } as unknown as TrackedWaitingToolCall,
1440
- {
1441
- request: {
1442
- callId: 'call2',
1443
- name: 'write_file',
1444
- args: { path: '/test/new.txt', content: 'content' },
1445
- isClientInitiated: false,
1446
- prompt_id: 'prompt-id-1',
1447
- },
1448
- status: 'awaiting_approval',
1449
- responseSubmittedToGemini: false,
1450
- confirmationDetails: {
1451
- onConfirm: mockOnConfirmWrite,
1452
- onCancel: vi.fn(),
1453
- message: 'Write file?',
1454
- displayedText: 'Write to /test/new.txt',
1455
- },
1456
- tool: {
1457
- name: 'write_file',
1458
- displayName: 'write_file',
1459
- description: 'Write file',
1460
- build: vi.fn(),
1461
- } as any,
1462
- invocation: {
1463
- getDescription: () => 'Mock description',
1464
- } as unknown as AnyToolInvocation,
1465
- } as unknown as TrackedWaitingToolCall,
1466
- {
1467
- request: {
1468
- callId: 'call3',
1469
- name: 'read_file',
1470
- args: { path: '/test/file.txt' },
1471
- isClientInitiated: false,
1472
- prompt_id: 'prompt-id-1',
1473
- },
1474
- status: 'awaiting_approval',
1475
- responseSubmittedToGemini: false,
1476
- confirmationDetails: {
1477
- onConfirm: mockOnConfirmRead,
1478
- onCancel: vi.fn(),
1479
- message: 'Read file?',
1480
- displayedText: 'Read /test/file.txt',
1481
- },
1482
- tool: {
1483
- name: 'read_file',
1484
- displayName: 'read_file',
1485
- description: 'Read file',
1486
- build: vi.fn(),
1487
- } as any,
1488
- invocation: {
1489
- getDescription: () => 'Mock description',
1490
- } as unknown as AnyToolInvocation,
1491
- } as unknown as TrackedWaitingToolCall,
1492
- ];
1493
-
1494
- const { result } = renderTestHook(awaitingApprovalToolCalls);
1495
-
1496
- await act(async () => {
1497
- await result.current.handleApprovalModeChange(ApprovalMode.AUTO_EDIT);
1498
- });
1499
-
1500
- // Only replace and write_file should be auto-approved
1501
- expect(mockOnConfirmReplace).toHaveBeenCalledTimes(1);
1502
- expect(mockOnConfirmReplace).toHaveBeenCalledWith(
1503
- ToolConfirmationOutcome.ProceedOnce,
1504
- );
1505
- expect(mockOnConfirmWrite).toHaveBeenCalledTimes(1);
1506
- expect(mockOnConfirmWrite).toHaveBeenCalledWith(
1507
- ToolConfirmationOutcome.ProceedOnce,
1508
- );
1509
-
1510
- // read_file should not be auto-approved
1511
- expect(mockOnConfirmRead).not.toHaveBeenCalled();
1512
- });
1513
-
1514
- it('should not auto-approve any tools when switching to REQUIRE_CONFIRMATION mode', async () => {
1515
- const mockOnConfirm = vi.fn().mockResolvedValue(undefined);
1516
- const awaitingApprovalToolCalls: TrackedToolCall[] = [
1517
- {
1518
- request: {
1519
- callId: 'call1',
1520
- name: 'replace',
1521
- args: { old_string: 'old', new_string: 'new' },
1522
- isClientInitiated: false,
1523
- prompt_id: 'prompt-id-1',
1524
- },
1525
- status: 'awaiting_approval',
1526
- responseSubmittedToGemini: false,
1527
- confirmationDetails: {
1528
- onConfirm: mockOnConfirm,
1529
- onCancel: vi.fn(),
1530
- message: 'Replace text?',
1531
- displayedText: 'Replace old with new',
1532
- },
1533
- tool: {
1534
- name: 'replace',
1535
- displayName: 'replace',
1536
- description: 'Replace text',
1537
- build: vi.fn(),
1538
- } as any,
1539
- invocation: {
1540
- getDescription: () => 'Mock description',
1541
- } as unknown as AnyToolInvocation,
1542
- } as unknown as TrackedWaitingToolCall,
1543
- ];
1544
-
1545
- const { result } = renderTestHook(awaitingApprovalToolCalls);
1546
-
1547
- await act(async () => {
1548
- await result.current.handleApprovalModeChange(ApprovalMode.DEFAULT);
1549
- });
1550
-
1551
- // No tools should be auto-approved
1552
- expect(mockOnConfirm).not.toHaveBeenCalled();
1553
- });
1554
-
1555
- it('should handle errors gracefully when auto-approving tool calls', async () => {
1556
- const mockOnConfirmSuccess = vi.fn().mockResolvedValue(undefined);
1557
- const mockOnConfirmError = vi
1558
- .fn()
1559
- .mockRejectedValue(new Error('Approval failed'));
1560
-
1561
- const awaitingApprovalToolCalls: TrackedToolCall[] = [
1562
- {
1563
- request: {
1564
- callId: 'call1',
1565
- name: 'replace',
1566
- args: { old_string: 'old', new_string: 'new' },
1567
- isClientInitiated: false,
1568
- prompt_id: 'prompt-id-1',
1569
- },
1570
- status: 'awaiting_approval',
1571
- responseSubmittedToGemini: false,
1572
- confirmationDetails: {
1573
- onConfirm: mockOnConfirmSuccess,
1574
- onCancel: vi.fn(),
1575
- message: 'Replace text?',
1576
- displayedText: 'Replace old with new',
1577
- },
1578
- tool: {
1579
- name: 'replace',
1580
- displayName: 'replace',
1581
- description: 'Replace text',
1582
- build: vi.fn(),
1583
- } as any,
1584
- invocation: {
1585
- getDescription: () => 'Mock description',
1586
- } as unknown as AnyToolInvocation,
1587
- } as unknown as TrackedWaitingToolCall,
1588
- {
1589
- request: {
1590
- callId: 'call2',
1591
- name: 'write_file',
1592
- args: { path: '/test/file.txt', content: 'content' },
1593
- isClientInitiated: false,
1594
- prompt_id: 'prompt-id-1',
1595
- },
1596
- status: 'awaiting_approval',
1597
- responseSubmittedToGemini: false,
1598
- confirmationDetails: {
1599
- onConfirm: mockOnConfirmError,
1600
- onCancel: vi.fn(),
1601
- message: 'Write file?',
1602
- displayedText: 'Write to /test/file.txt',
1603
- },
1604
- tool: {
1605
- name: 'write_file',
1606
- displayName: 'write_file',
1607
- description: 'Write file',
1608
- build: vi.fn(),
1609
- } as any,
1610
- invocation: {
1611
- getDescription: () => 'Mock description',
1612
- } as unknown as AnyToolInvocation,
1613
- } as unknown as TrackedWaitingToolCall,
1614
- ];
1615
-
1616
- const { result } = renderTestHook(awaitingApprovalToolCalls);
1617
-
1618
- await act(async () => {
1619
- await result.current.handleApprovalModeChange(ApprovalMode.YOLO);
1620
- });
1621
-
1622
- // Both confirmation methods should be called
1623
- expect(mockOnConfirmSuccess).toHaveBeenCalledTimes(1);
1624
- expect(mockOnConfirmError).toHaveBeenCalledTimes(1);
1625
- });
1626
-
1627
- it('should skip tool calls without confirmationDetails', async () => {
1628
- const awaitingApprovalToolCalls: TrackedToolCall[] = [
1629
- {
1630
- request: {
1631
- callId: 'call1',
1632
- name: 'replace',
1633
- args: { old_string: 'old', new_string: 'new' },
1634
- isClientInitiated: false,
1635
- prompt_id: 'prompt-id-1',
1636
- },
1637
- status: 'awaiting_approval',
1638
- responseSubmittedToGemini: false,
1639
- // No confirmationDetails
1640
- tool: {
1641
- name: 'replace',
1642
- displayName: 'replace',
1643
- description: 'Replace text',
1644
- build: vi.fn(),
1645
- } as any,
1646
- invocation: {
1647
- getDescription: () => 'Mock description',
1648
- } as unknown as AnyToolInvocation,
1649
- } as unknown as TrackedWaitingToolCall,
1650
- ];
1651
-
1652
- const { result } = renderTestHook(awaitingApprovalToolCalls);
1653
-
1654
- // Should not throw an error
1655
- await act(async () => {
1656
- await result.current.handleApprovalModeChange(ApprovalMode.YOLO);
1657
- });
1658
- });
1659
-
1660
- it('should skip tool calls without onConfirm method in confirmationDetails', async () => {
1661
- const awaitingApprovalToolCalls: TrackedToolCall[] = [
1662
- {
1663
- request: {
1664
- callId: 'call1',
1665
- name: 'replace',
1666
- args: { old_string: 'old', new_string: 'new' },
1667
- isClientInitiated: false,
1668
- prompt_id: 'prompt-id-1',
1669
- },
1670
- status: 'awaiting_approval',
1671
- responseSubmittedToGemini: false,
1672
- confirmationDetails: {
1673
- onCancel: vi.fn(),
1674
- message: 'Replace text?',
1675
- displayedText: 'Replace old with new',
1676
- // No onConfirm method
1677
- } as any,
1678
- tool: {
1679
- name: 'replace',
1680
- displayName: 'replace',
1681
- description: 'Replace text',
1682
- build: vi.fn(),
1683
- } as any,
1684
- invocation: {
1685
- getDescription: () => 'Mock description',
1686
- } as unknown as AnyToolInvocation,
1687
- } as unknown as TrackedWaitingToolCall,
1688
- ];
1689
-
1690
- const { result } = renderTestHook(awaitingApprovalToolCalls);
1691
-
1692
- // Should not throw an error
1693
- await act(async () => {
1694
- await result.current.handleApprovalModeChange(ApprovalMode.YOLO);
1695
- });
1696
- });
1697
-
1698
- it('should only process tool calls with awaiting_approval status', async () => {
1699
- const mockOnConfirmAwaiting = vi.fn().mockResolvedValue(undefined);
1700
- const mockOnConfirmExecuting = vi.fn().mockResolvedValue(undefined);
1701
-
1702
- const mixedStatusToolCalls: TrackedToolCall[] = [
1703
- {
1704
- request: {
1705
- callId: 'call1',
1706
- name: 'replace',
1707
- args: { old_string: 'old', new_string: 'new' },
1708
- isClientInitiated: false,
1709
- prompt_id: 'prompt-id-1',
1710
- },
1711
- status: 'awaiting_approval',
1712
- responseSubmittedToGemini: false,
1713
- confirmationDetails: {
1714
- onConfirm: mockOnConfirmAwaiting,
1715
- onCancel: vi.fn(),
1716
- message: 'Replace text?',
1717
- displayedText: 'Replace old with new',
1718
- },
1719
- tool: {
1720
- name: 'replace',
1721
- displayName: 'replace',
1722
- description: 'Replace text',
1723
- build: vi.fn(),
1724
- } as any,
1725
- invocation: {
1726
- getDescription: () => 'Mock description',
1727
- } as unknown as AnyToolInvocation,
1728
- } as unknown as TrackedWaitingToolCall,
1729
- {
1730
- request: {
1731
- callId: 'call2',
1732
- name: 'write_file',
1733
- args: { path: '/test/file.txt', content: 'content' },
1734
- isClientInitiated: false,
1735
- prompt_id: 'prompt-id-1',
1736
- },
1737
- status: 'executing',
1738
- responseSubmittedToGemini: false,
1739
- confirmationDetails: {
1740
- onConfirm: mockOnConfirmExecuting,
1741
- onCancel: vi.fn(),
1742
- message: 'Write file?',
1743
- displayedText: 'Write to /test/file.txt',
1744
- },
1745
- tool: {
1746
- name: 'write_file',
1747
- displayName: 'write_file',
1748
- description: 'Write file',
1749
- build: vi.fn(),
1750
- } as any,
1751
- invocation: {
1752
- getDescription: () => 'Mock description',
1753
- } as unknown as AnyToolInvocation,
1754
- startTime: Date.now(),
1755
- liveOutput: 'Writing...',
1756
- } as TrackedExecutingToolCall,
1757
- ];
1758
-
1759
- const { result } = renderTestHook(mixedStatusToolCalls);
1760
-
1761
- await act(async () => {
1762
- await result.current.handleApprovalModeChange(ApprovalMode.YOLO);
1763
- });
1764
-
1765
- // Only the awaiting_approval tool should be processed
1766
- expect(mockOnConfirmAwaiting).toHaveBeenCalledTimes(1);
1767
- expect(mockOnConfirmExecuting).not.toHaveBeenCalled();
1768
- });
1769
- });
1770
-
1771
- describe('handleFinishedEvent', () => {
1772
- it('should add info message for MAX_TOKENS finish reason', async () => {
1773
- // Setup mock to return a stream with MAX_TOKENS finish reason
1774
- mockSendMessageStream.mockReturnValue(
1775
- (async function* () {
1776
- yield {
1777
- type: ServerGeminiEventType.Content,
1778
- value: 'This is a truncated response...',
1779
- };
1780
- yield {
1781
- type: ServerGeminiEventType.Finished,
1782
- value: { reason: 'MAX_TOKENS', usageMetadata: undefined },
1783
- };
1784
- })(),
1785
- );
1786
-
1787
- const { result } = renderHook(() =>
1788
- useGeminiStream(
1789
- new MockedGeminiClientClass(mockConfig),
1790
- [],
1791
- mockAddItem,
1792
- mockConfig,
1793
- mockLoadedSettings,
1794
- mockOnDebugMessage,
1795
- mockHandleSlashCommand,
1796
- false,
1797
- () => 'vscode' as EditorType,
1798
- () => {},
1799
- () => Promise.resolve(),
1800
- false,
1801
- () => {},
1802
- () => {},
1803
- () => {},
1804
- () => {},
1805
- 80,
1806
- 24,
1807
- ),
1808
- );
1809
-
1810
- // Submit a query
1811
- await act(async () => {
1812
- await result.current.submitQuery('Generate long text');
1813
- });
1814
-
1815
- // Check that the info message was added
1816
- await waitFor(() => {
1817
- expect(mockAddItem).toHaveBeenCalledWith(
1818
- {
1819
- type: 'info',
1820
- text: '⚠️ Response truncated due to token limits.',
1821
- },
1822
- expect.any(Number),
1823
- );
1824
- });
1825
- });
1826
-
1827
- it('should not add message for STOP finish reason', async () => {
1828
- // Setup mock to return a stream with STOP finish reason
1829
- mockSendMessageStream.mockReturnValue(
1830
- (async function* () {
1831
- yield {
1832
- type: ServerGeminiEventType.Content,
1833
- value: 'Complete response',
1834
- };
1835
- yield {
1836
- type: ServerGeminiEventType.Finished,
1837
- value: { reason: 'STOP', usageMetadata: undefined },
1838
- };
1839
- })(),
1840
- );
1841
-
1842
- const { result } = renderHook(() =>
1843
- useGeminiStream(
1844
- new MockedGeminiClientClass(mockConfig),
1845
- [],
1846
- mockAddItem,
1847
- mockConfig,
1848
- mockLoadedSettings,
1849
- mockOnDebugMessage,
1850
- mockHandleSlashCommand,
1851
- false,
1852
- () => 'vscode' as EditorType,
1853
- () => {},
1854
- () => Promise.resolve(),
1855
- false,
1856
- () => {},
1857
- () => {},
1858
- () => {},
1859
- () => {},
1860
- 80,
1861
- 24,
1862
- ),
1863
- );
1864
-
1865
- // Submit a query
1866
- await act(async () => {
1867
- await result.current.submitQuery('Test normal completion');
1868
- });
1869
-
1870
- // Wait a bit to ensure no message is added
1871
- await new Promise((resolve) => setTimeout(resolve, 100));
1872
-
1873
- // Check that no info message was added for STOP
1874
- const infoMessages = mockAddItem.mock.calls.filter(
1875
- (call) => call[0].type === 'info',
1876
- );
1877
- expect(infoMessages).toHaveLength(0);
1878
- });
1879
-
1880
- it('should not add message for FINISH_REASON_UNSPECIFIED', async () => {
1881
- // Setup mock to return a stream with FINISH_REASON_UNSPECIFIED
1882
- mockSendMessageStream.mockReturnValue(
1883
- (async function* () {
1884
- yield {
1885
- type: ServerGeminiEventType.Content,
1886
- value: 'Response with unspecified finish',
1887
- };
1888
- yield {
1889
- type: ServerGeminiEventType.Finished,
1890
- value: {
1891
- reason: 'FINISH_REASON_UNSPECIFIED',
1892
- usageMetadata: undefined,
1893
- },
1894
- };
1895
- })(),
1896
- );
1897
-
1898
- const { result } = renderHook(() =>
1899
- useGeminiStream(
1900
- new MockedGeminiClientClass(mockConfig),
1901
- [],
1902
- mockAddItem,
1903
- mockConfig,
1904
- mockLoadedSettings,
1905
- mockOnDebugMessage,
1906
- mockHandleSlashCommand,
1907
- false,
1908
- () => 'vscode' as EditorType,
1909
- () => {},
1910
- () => Promise.resolve(),
1911
- false,
1912
- () => {},
1913
- () => {},
1914
- () => {},
1915
- () => {},
1916
- 80,
1917
- 24,
1918
- ),
1919
- );
1920
-
1921
- // Submit a query
1922
- await act(async () => {
1923
- await result.current.submitQuery('Test unspecified finish');
1924
- });
1925
-
1926
- // Wait a bit to ensure no message is added
1927
- await new Promise((resolve) => setTimeout(resolve, 100));
1928
-
1929
- // Check that no info message was added
1930
- const infoMessages = mockAddItem.mock.calls.filter(
1931
- (call) => call[0].type === 'info',
1932
- );
1933
- expect(infoMessages).toHaveLength(0);
1934
- });
1935
-
1936
- it('should add appropriate messages for other finish reasons', async () => {
1937
- const testCases = [
1938
- {
1939
- reason: 'SAFETY',
1940
- message: '⚠️ Response stopped due to safety reasons.',
1941
- },
1942
- {
1943
- reason: 'RECITATION',
1944
- message: '⚠️ Response stopped due to recitation policy.',
1945
- },
1946
- {
1947
- reason: 'LANGUAGE',
1948
- message: '⚠️ Response stopped due to unsupported language.',
1949
- },
1950
- {
1951
- reason: 'BLOCKLIST',
1952
- message: '⚠️ Response stopped due to forbidden terms.',
1953
- },
1954
- {
1955
- reason: 'PROHIBITED_CONTENT',
1956
- message: '⚠️ Response stopped due to prohibited content.',
1957
- },
1958
- {
1959
- reason: 'SPII',
1960
- message:
1961
- '⚠️ Response stopped due to sensitive personally identifiable information.',
1962
- },
1963
- { reason: 'OTHER', message: '⚠️ Response stopped for other reasons.' },
1964
- {
1965
- reason: 'MALFORMED_FUNCTION_CALL',
1966
- message: '⚠️ Response stopped due to malformed function call.',
1967
- },
1968
- {
1969
- reason: 'IMAGE_SAFETY',
1970
- message: '⚠️ Response stopped due to image safety violations.',
1971
- },
1972
- {
1973
- reason: 'UNEXPECTED_TOOL_CALL',
1974
- message: '⚠️ Response stopped due to unexpected tool call.',
1975
- },
1976
- ];
1977
-
1978
- for (const { reason, message } of testCases) {
1979
- // Reset mocks for each test case
1980
- mockAddItem.mockClear();
1981
- mockSendMessageStream.mockReturnValue(
1982
- (async function* () {
1983
- yield {
1984
- type: ServerGeminiEventType.Content,
1985
- value: `Response for ${reason}`,
1986
- };
1987
- yield {
1988
- type: ServerGeminiEventType.Finished,
1989
- value: { reason, usageMetadata: undefined },
1990
- };
1991
- })(),
1992
- );
1993
-
1994
- const { result } = renderHook(() =>
1995
- useGeminiStream(
1996
- new MockedGeminiClientClass(mockConfig),
1997
- [],
1998
- mockAddItem,
1999
- mockConfig,
2000
- mockLoadedSettings,
2001
- mockOnDebugMessage,
2002
- mockHandleSlashCommand,
2003
- false,
2004
- () => 'vscode' as EditorType,
2005
- () => {},
2006
- () => Promise.resolve(),
2007
- false,
2008
- () => {},
2009
- () => {},
2010
- () => {},
2011
- vi.fn(),
2012
- 80,
2013
- 24,
2014
- ),
2015
- );
2016
-
2017
- await act(async () => {
2018
- await result.current.submitQuery(`Test ${reason}`);
2019
- });
2020
-
2021
- await waitFor(() => {
2022
- expect(mockAddItem).toHaveBeenCalledWith(
2023
- {
2024
- type: 'info',
2025
- text: message,
2026
- },
2027
- expect.any(Number),
2028
- );
2029
- });
2030
- }
2031
- });
2032
- });
2033
-
2034
- it('should process @include commands, adding user turn after processing to prevent race conditions', async () => {
2035
- const rawQuery = '@include file.txt Summarize this.';
2036
- const processedQueryParts = [
2037
- { text: 'Summarize this with content from @file.txt' },
2038
- { text: 'File content...' },
2039
- ];
2040
- const userMessageTimestamp = Date.now();
2041
- vi.spyOn(Date, 'now').mockReturnValue(userMessageTimestamp);
2042
-
2043
- handleAtCommandSpy.mockResolvedValue({
2044
- processedQuery: processedQueryParts,
2045
- shouldProceed: true,
2046
- });
2047
-
2048
- const { result } = renderHook(() =>
2049
- useGeminiStream(
2050
- mockConfig.getGeminiClient() as GeminiClient,
2051
- [],
2052
- mockAddItem,
2053
- mockConfig,
2054
- mockLoadedSettings,
2055
- mockOnDebugMessage,
2056
- mockHandleSlashCommand,
2057
- false, // shellModeActive
2058
- vi.fn(), // getPreferredEditor
2059
- vi.fn(), // onAuthError
2060
- vi.fn(), // performMemoryRefresh
2061
- false, // modelSwitched
2062
- vi.fn(), // setModelSwitched
2063
- vi.fn(), // onEditorClose
2064
- vi.fn(), // onCancelSubmit
2065
- vi.fn(), // setShellInputFocused
2066
- 80, // terminalWidth
2067
- 24, // terminalHeight
2068
- ),
2069
- );
2070
-
2071
- await act(async () => {
2072
- await result.current.submitQuery(rawQuery);
2073
- });
2074
-
2075
- expect(handleAtCommandSpy).toHaveBeenCalledWith(
2076
- expect.objectContaining({
2077
- query: rawQuery,
2078
- }),
2079
- );
2080
-
2081
- expect(mockAddItem).toHaveBeenCalledWith(
2082
- {
2083
- type: MessageType.USER,
2084
- text: rawQuery,
2085
- },
2086
- userMessageTimestamp,
2087
- );
2088
-
2089
- // FIX: The expectation now matches the actual call signature.
2090
- expect(mockSendMessageStream).toHaveBeenCalledWith(
2091
- processedQueryParts, // Argument 1: The parts array directly
2092
- expect.any(AbortSignal), // Argument 2: An AbortSignal
2093
- expect.any(String), // Argument 3: The prompt_id string
2094
- undefined, // Argument 4: Options (undefined for normal prompts)
2095
- );
2096
- });
2097
-
2098
- describe('Thought Reset', () => {
2099
- it('should reset thought to null when starting a new prompt', async () => {
2100
- // First, simulate a response with a thought
2101
- mockSendMessageStream.mockReturnValue(
2102
- (async function* () {
2103
- yield {
2104
- type: ServerGeminiEventType.Thought,
2105
- value: {
2106
- subject: 'Previous thought',
2107
- description: 'Old description',
2108
- },
2109
- };
2110
- yield {
2111
- type: ServerGeminiEventType.Content,
2112
- value: 'Some response content',
2113
- };
2114
- yield {
2115
- type: ServerGeminiEventType.Finished,
2116
- value: { reason: 'STOP', usageMetadata: undefined },
2117
- };
2118
- })(),
2119
- );
2120
-
2121
- const { result } = renderHook(() =>
2122
- useGeminiStream(
2123
- new MockedGeminiClientClass(mockConfig),
2124
- [],
2125
- mockAddItem,
2126
- mockConfig,
2127
- mockLoadedSettings,
2128
- mockOnDebugMessage,
2129
- mockHandleSlashCommand,
2130
- false,
2131
- () => 'vscode' as EditorType,
2132
- () => {},
2133
- () => Promise.resolve(),
2134
- false,
2135
- () => {},
2136
- () => {},
2137
- () => {},
2138
- () => {},
2139
- 80,
2140
- 24,
2141
- ),
2142
- );
2143
-
2144
- // Submit first query to set a thought
2145
- await act(async () => {
2146
- await result.current.submitQuery('First query');
2147
- });
2148
-
2149
- // Wait for the first response to complete
2150
- await waitFor(() => {
2151
- expect(mockAddItem).toHaveBeenCalledWith(
2152
- expect.objectContaining({
2153
- type: 'gemini',
2154
- text: 'Some response content',
2155
- }),
2156
- expect.any(Number),
2157
- );
2158
- });
2159
-
2160
- // Now simulate a new response without a thought
2161
- mockSendMessageStream.mockReturnValue(
2162
- (async function* () {
2163
- yield {
2164
- type: ServerGeminiEventType.Content,
2165
- value: 'New response content',
2166
- };
2167
- yield {
2168
- type: ServerGeminiEventType.Finished,
2169
- value: { reason: 'STOP', usageMetadata: undefined },
2170
- };
2171
- })(),
2172
- );
2173
-
2174
- // Submit second query - thought should be reset
2175
- await act(async () => {
2176
- await result.current.submitQuery('Second query');
2177
- });
2178
-
2179
- // The thought should be reset to null when starting the new prompt
2180
- // We can verify this by checking that the LoadingIndicator would not show the previous thought
2181
- // The actual thought state is internal to the hook, but we can verify the behavior
2182
- // by ensuring the second response doesn't show the previous thought
2183
- await waitFor(() => {
2184
- expect(mockAddItem).toHaveBeenCalledWith(
2185
- expect.objectContaining({
2186
- type: 'gemini',
2187
- text: 'New response content',
2188
- }),
2189
- expect.any(Number),
2190
- );
2191
- });
2192
- });
2193
-
2194
- it('should accumulate streamed thought descriptions', async () => {
2195
- mockSendMessageStream.mockReturnValue(
2196
- (async function* () {
2197
- yield {
2198
- type: ServerGeminiEventType.Thought,
2199
- value: { subject: '', description: 'thinking ' },
2200
- };
2201
- yield {
2202
- type: ServerGeminiEventType.Thought,
2203
- value: { subject: '', description: 'more' },
2204
- };
2205
- yield {
2206
- type: ServerGeminiEventType.Finished,
2207
- value: { reason: 'STOP', usageMetadata: undefined },
2208
- };
2209
- })(),
2210
- );
2211
-
2212
- const { result } = renderHook(() =>
2213
- useGeminiStream(
2214
- new MockedGeminiClientClass(mockConfig),
2215
- [],
2216
- mockAddItem,
2217
- mockConfig,
2218
- mockLoadedSettings,
2219
- mockOnDebugMessage,
2220
- mockHandleSlashCommand,
2221
- false,
2222
- () => 'vscode' as EditorType,
2223
- () => {},
2224
- () => Promise.resolve(),
2225
- false,
2226
- () => {},
2227
- () => {},
2228
- () => {},
2229
- () => {},
2230
- 80,
2231
- 24,
2232
- ),
2233
- );
2234
-
2235
- await act(async () => {
2236
- await result.current.submitQuery('Streamed thought');
2237
- });
2238
-
2239
- await waitFor(() => {
2240
- expect(result.current.thought?.description).toBe('thinking more');
2241
- });
2242
- });
2243
-
2244
- it('should show a retry countdown and update pending history over time', async () => {
2245
- vi.useFakeTimers();
2246
- try {
2247
- let resolveStream: (() => void) | undefined;
2248
- mockSendMessageStream.mockReturnValue(
2249
- (async function* () {
2250
- yield {
2251
- type: ServerGeminiEventType.Retry,
2252
- retryInfo: {
2253
- message: '[API Error: Rate limit exceeded]',
2254
- attempt: 1,
2255
- maxRetries: 3,
2256
- delayMs: 3000,
2257
- },
2258
- };
2259
- yield {
2260
- type: ServerGeminiEventType.Retry,
2261
- };
2262
- await new Promise<void>((resolve) => {
2263
- resolveStream = resolve;
2264
- });
2265
- yield {
2266
- type: ServerGeminiEventType.Finished,
2267
- value: { reason: 'STOP', usageMetadata: undefined },
2268
- };
2269
- })(),
2270
- );
2271
-
2272
- const { result } = renderHook(() =>
2273
- useGeminiStream(
2274
- new MockedGeminiClientClass(mockConfig),
2275
- [],
2276
- mockAddItem,
2277
- mockConfig,
2278
- mockLoadedSettings,
2279
- mockOnDebugMessage,
2280
- mockHandleSlashCommand,
2281
- false,
2282
- () => 'vscode' as EditorType,
2283
- () => {},
2284
- () => Promise.resolve(),
2285
- false,
2286
- () => {},
2287
- () => {},
2288
- () => {},
2289
- () => {},
2290
- 80,
2291
- 24,
2292
- ),
2293
- );
2294
-
2295
- act(() => {
2296
- void result.current.submitQuery('Trigger retry');
2297
- });
2298
-
2299
- await act(async () => {
2300
- await Promise.resolve();
2301
- });
2302
-
2303
- const findErrorItem = () =>
2304
- result.current.pendingHistoryItems.find(
2305
- (item) => item.type === MessageType.ERROR,
2306
- );
2307
-
2308
- let errorItem = findErrorItem();
2309
- for (let attempts = 0; attempts < 5 && !errorItem; attempts++) {
2310
- await act(async () => {
2311
- await Promise.resolve();
2312
- });
2313
- errorItem = findErrorItem();
2314
- }
2315
-
2316
- // Error item should contain the error text and a retry hint
2317
- expect(errorItem?.text).toContain('Rate limit exceeded');
2318
- // Countdown hint should be inline on the error item (not a separate item)
2319
- expect((errorItem as { hint?: string })?.hint).toContain('3s');
2320
- expect((errorItem as { hint?: string })?.hint).toContain('attempt 1/3');
2321
-
2322
- await act(async () => {
2323
- await vi.advanceTimersByTimeAsync(1000);
2324
- });
2325
-
2326
- const errorAfterOneSecond = result.current.pendingHistoryItems.find(
2327
- (item) => item.type === MessageType.ERROR,
2328
- );
2329
- expect((errorAfterOneSecond as { hint?: string })?.hint).toContain(
2330
- '2s',
2331
- );
2332
-
2333
- resolveStream?.();
2334
-
2335
- await act(async () => {
2336
- await Promise.resolve();
2337
- await vi.runAllTimersAsync();
2338
- });
2339
-
2340
- // Error item (with hint) should be cleared after retry succeeds
2341
- const remainingError = result.current.pendingHistoryItems.find(
2342
- (item) => item.type === MessageType.ERROR,
2343
- );
2344
- expect(remainingError).toBeUndefined();
2345
- } finally {
2346
- vi.useRealTimers();
2347
- }
2348
- });
2349
-
2350
- it('should memoize pendingHistoryItems', () => {
2351
- mockUseReactToolScheduler.mockReturnValue([
2352
- [],
2353
- mockScheduleToolCalls,
2354
- mockCancelAllToolCalls,
2355
- mockMarkToolsAsSubmitted,
2356
- ]);
2357
-
2358
- const { result, rerender } = renderHook(() =>
2359
- useGeminiStream(
2360
- mockConfig.getGeminiClient(),
2361
- [],
2362
- mockAddItem,
2363
- mockConfig,
2364
- mockLoadedSettings,
2365
- mockOnDebugMessage,
2366
- mockHandleSlashCommand,
2367
- false,
2368
- () => 'vscode' as EditorType,
2369
- () => {},
2370
- () => Promise.resolve(),
2371
- false,
2372
- () => {},
2373
- () => {},
2374
- () => {},
2375
- vi.fn(), // setShellInputFocused
2376
- 80,
2377
- 24,
2378
- ),
2379
- );
2380
-
2381
- const firstResult = result.current.pendingHistoryItems;
2382
- rerender();
2383
- const secondResult = result.current.pendingHistoryItems;
2384
-
2385
- expect(firstResult).toStrictEqual(secondResult);
2386
-
2387
- const newToolCalls: TrackedToolCall[] = [
2388
- {
2389
- request: { callId: 'call1', name: 'tool1', args: {} },
2390
- status: 'executing',
2391
- tool: {
2392
- name: 'tool1',
2393
- displayName: 'tool1',
2394
- description: 'desc1',
2395
- build: vi.fn(),
2396
- },
2397
- invocation: {
2398
- getDescription: () => 'Mock description',
2399
- },
2400
- } as unknown as TrackedExecutingToolCall,
2401
- ];
2402
-
2403
- mockUseReactToolScheduler.mockReturnValue([
2404
- newToolCalls,
2405
- mockScheduleToolCalls,
2406
- mockCancelAllToolCalls,
2407
- mockMarkToolsAsSubmitted,
2408
- ]);
2409
-
2410
- rerender();
2411
- const thirdResult = result.current.pendingHistoryItems;
2412
-
2413
- expect(thirdResult).not.toStrictEqual(secondResult);
2414
- });
2415
-
2416
- it('should reset thought to null when user cancels', async () => {
2417
- // Mock a stream that yields a thought then gets cancelled
2418
- mockSendMessageStream.mockReturnValue(
2419
- (async function* () {
2420
- yield {
2421
- type: ServerGeminiEventType.Thought,
2422
- value: { subject: 'Some thought', description: 'Description' },
2423
- };
2424
- yield { type: ServerGeminiEventType.UserCancelled };
2425
- })(),
2426
- );
2427
-
2428
- const { result } = renderHook(() =>
2429
- useGeminiStream(
2430
- new MockedGeminiClientClass(mockConfig),
2431
- [],
2432
- mockAddItem,
2433
- mockConfig,
2434
- mockLoadedSettings,
2435
- mockOnDebugMessage,
2436
- mockHandleSlashCommand,
2437
- false,
2438
- () => 'vscode' as EditorType,
2439
- () => {},
2440
- () => Promise.resolve(),
2441
- false,
2442
- () => {},
2443
- () => {},
2444
- () => {},
2445
- () => {},
2446
- 80,
2447
- 24,
2448
- ),
2449
- );
2450
-
2451
- // Submit query
2452
- await act(async () => {
2453
- await result.current.submitQuery('Test query');
2454
- });
2455
-
2456
- // Verify cancellation message was added
2457
- await waitFor(() => {
2458
- expect(mockAddItem).toHaveBeenCalledWith(
2459
- expect.objectContaining({
2460
- type: 'info',
2461
- text: 'User cancelled the request.',
2462
- }),
2463
- expect.any(Number),
2464
- );
2465
- });
2466
-
2467
- // Verify state is reset to idle
2468
- expect(result.current.streamingState).toBe(StreamingState.Idle);
2469
- });
2470
-
2471
- it('should reset thought to null when there is an error', async () => {
2472
- // Mock a stream that yields a thought then encounters an error
2473
- mockSendMessageStream.mockReturnValue(
2474
- (async function* () {
2475
- yield {
2476
- type: ServerGeminiEventType.Thought,
2477
- value: { subject: 'Some thought', description: 'Description' },
2478
- };
2479
- yield {
2480
- type: ServerGeminiEventType.Error,
2481
- value: { error: { message: 'Test error' } },
2482
- };
2483
- })(),
2484
- );
2485
-
2486
- const { result } = renderHook(() =>
2487
- useGeminiStream(
2488
- new MockedGeminiClientClass(mockConfig),
2489
- [],
2490
- mockAddItem,
2491
- mockConfig,
2492
- mockLoadedSettings,
2493
- mockOnDebugMessage,
2494
- mockHandleSlashCommand,
2495
- false,
2496
- () => 'vscode' as EditorType,
2497
- () => {},
2498
- () => Promise.resolve(),
2499
- false,
2500
- () => {},
2501
- () => {},
2502
- () => {},
2503
- () => {},
2504
- 80,
2505
- 24,
2506
- ),
2507
- );
2508
-
2509
- // Submit query
2510
- await act(async () => {
2511
- await result.current.submitQuery('Test query');
2512
- });
2513
-
2514
- // Verify error message appears in pending history items (not via addItem,
2515
- // since errors with retry hints are now stored as pending items)
2516
- await waitFor(() => {
2517
- const errorItem = result.current.pendingHistoryItems.find(
2518
- (item) => item.type === 'error',
2519
- );
2520
- expect(errorItem).toBeDefined();
2521
- });
2522
-
2523
- // Verify parseAndFormatApiError was called
2524
- expect(mockParseAndFormatApiError).toHaveBeenCalledWith(
2525
- { message: 'Test error' },
2526
- expect.any(String),
2527
- );
2528
- });
2529
- });
2530
-
2531
- describe('Concurrent Execution Prevention', () => {
2532
- it('should prevent concurrent submitQuery calls', async () => {
2533
- let resolveFirstCall!: () => void;
2534
- let resolveSecondCall!: () => void;
2535
-
2536
- const firstCallPromise = new Promise<void>((resolve) => {
2537
- resolveFirstCall = resolve;
2538
- });
2539
-
2540
- const secondCallPromise = new Promise<void>((resolve) => {
2541
- resolveSecondCall = resolve;
2542
- });
2543
-
2544
- // Mock a long-running stream for the first call
2545
- const firstStream = (async function* () {
2546
- yield {
2547
- type: ServerGeminiEventType.Content,
2548
- value: 'First call content',
2549
- };
2550
- await firstCallPromise; // Wait until we manually resolve
2551
- yield { type: ServerGeminiEventType.Finished, value: 'STOP' };
2552
- })();
2553
-
2554
- // Mock a stream for the second call (should not be used)
2555
- const secondStream = (async function* () {
2556
- yield {
2557
- type: ServerGeminiEventType.Content,
2558
- value: 'Second call content',
2559
- };
2560
- await secondCallPromise;
2561
- yield { type: ServerGeminiEventType.Finished, value: 'STOP' };
2562
- })();
2563
-
2564
- let callCount = 0;
2565
- mockSendMessageStream.mockImplementation(() => {
2566
- callCount++;
2567
- if (callCount === 1) {
2568
- return firstStream;
2569
- } else {
2570
- return secondStream;
2571
- }
2572
- });
2573
-
2574
- const { result } = renderTestHook();
2575
-
2576
- // Start first call
2577
- const firstCallResult = act(async () => {
2578
- await result.current.submitQuery('First query');
2579
- });
2580
-
2581
- // Wait a bit to ensure first call has started
2582
- await new Promise((resolve) => setTimeout(resolve, 10));
2583
-
2584
- // Try to start second call while first is still running
2585
- const secondCallResult = act(async () => {
2586
- await result.current.submitQuery('Second query');
2587
- });
2588
-
2589
- // Resolve both calls
2590
- resolveFirstCall();
2591
- resolveSecondCall();
2592
-
2593
- await Promise.all([firstCallResult, secondCallResult]);
2594
-
2595
- // Verify only one call was made to sendMessageStream
2596
- expect(mockSendMessageStream).toHaveBeenCalledTimes(1);
2597
- expect(mockSendMessageStream).toHaveBeenCalledWith(
2598
- 'First query',
2599
- expect.any(AbortSignal),
2600
- expect.any(String),
2601
- undefined,
2602
- );
2603
-
2604
- // Verify only the first query was added to history
2605
- const userMessages = mockAddItem.mock.calls.filter(
2606
- (call) => call[0].type === MessageType.USER,
2607
- );
2608
- expect(userMessages).toHaveLength(1);
2609
- expect(userMessages[0][0].text).toBe('First query');
2610
- });
2611
-
2612
- it('should allow subsequent calls after first call completes', async () => {
2613
- // Mock streams that complete immediately
2614
- mockSendMessageStream
2615
- .mockReturnValueOnce(
2616
- (async function* () {
2617
- yield {
2618
- type: ServerGeminiEventType.Content,
2619
- value: 'First response',
2620
- };
2621
- yield { type: ServerGeminiEventType.Finished, value: 'STOP' };
2622
- })(),
2623
- )
2624
- .mockReturnValueOnce(
2625
- (async function* () {
2626
- yield {
2627
- type: ServerGeminiEventType.Content,
2628
- value: 'Second response',
2629
- };
2630
- yield { type: ServerGeminiEventType.Finished, value: 'STOP' };
2631
- })(),
2632
- );
2633
-
2634
- const { result } = renderTestHook();
2635
-
2636
- // First call
2637
- await act(async () => {
2638
- await result.current.submitQuery('First query');
2639
- });
2640
-
2641
- // Second call after first completes
2642
- await act(async () => {
2643
- await result.current.submitQuery('Second query');
2644
- });
2645
-
2646
- // Both calls should have been made
2647
- expect(mockSendMessageStream).toHaveBeenCalledTimes(2);
2648
- expect(mockSendMessageStream).toHaveBeenNthCalledWith(
2649
- 1,
2650
- 'First query',
2651
- expect.any(AbortSignal),
2652
- expect.any(String),
2653
- undefined,
2654
- );
2655
- expect(mockSendMessageStream).toHaveBeenNthCalledWith(
2656
- 2,
2657
- 'Second query',
2658
- expect.any(AbortSignal),
2659
- expect.any(String),
2660
- undefined,
2661
- );
2662
- });
2663
-
2664
- it('should reset execution flag even when query preparation fails', async () => {
2665
- const { result } = renderTestHook();
2666
-
2667
- // First call with empty query (should fail in preparation)
2668
- await act(async () => {
2669
- await result.current.submitQuery(' '); // Empty trimmed query
2670
- });
2671
-
2672
- // Second call should work normally
2673
- await act(async () => {
2674
- await result.current.submitQuery('Second query');
2675
- });
2676
-
2677
- // Verify that only the second call was made (empty query is filtered out)
2678
- expect(mockSendMessageStream).toHaveBeenCalledTimes(1);
2679
- expect(mockSendMessageStream).toHaveBeenCalledWith(
2680
- 'Second query',
2681
- expect.any(AbortSignal),
2682
- expect.any(String),
2683
- undefined,
2684
- );
2685
- });
2686
- });
2687
-
2688
- // --- New tests focused on recent modifications ---
2689
- describe('Loop Detection Confirmation', () => {
2690
- beforeEach(() => {
2691
- // Add mock for getLoopDetectionService to the config
2692
- const mockLoopDetectionService = {
2693
- disableForSession: vi.fn(),
2694
- };
2695
- mockConfig.getGeminiClient = vi.fn().mockReturnValue({
2696
- ...new MockedGeminiClientClass(mockConfig),
2697
- getLoopDetectionService: () => mockLoopDetectionService,
2698
- });
2699
- });
2700
-
2701
- it('should set loopDetectionConfirmationRequest when LoopDetected event is received', async () => {
2702
- mockSendMessageStream.mockReturnValue(
2703
- (async function* () {
2704
- yield {
2705
- type: ServerGeminiEventType.Content,
2706
- value: 'Some content',
2707
- };
2708
- yield {
2709
- type: ServerGeminiEventType.LoopDetected,
2710
- };
2711
- })(),
2712
- );
2713
-
2714
- const { result } = renderTestHook();
2715
-
2716
- await act(async () => {
2717
- await result.current.submitQuery('test query');
2718
- });
2719
-
2720
- await waitFor(() => {
2721
- expect(result.current.loopDetectionConfirmationRequest).not.toBeNull();
2722
- expect(
2723
- typeof result.current.loopDetectionConfirmationRequest?.onComplete,
2724
- ).toBe('function');
2725
- });
2726
- });
2727
-
2728
- it('should disable loop detection and show message when user selects "disable"', async () => {
2729
- const mockLoopDetectionService = {
2730
- disableForSession: vi.fn(),
2731
- };
2732
- const mockClient = {
2733
- ...new MockedGeminiClientClass(mockConfig),
2734
- getLoopDetectionService: () => mockLoopDetectionService,
2735
- };
2736
- mockConfig.getGeminiClient = vi.fn().mockReturnValue(mockClient);
2737
-
2738
- mockSendMessageStream.mockReturnValueOnce(
2739
- (async function* () {
2740
- yield {
2741
- type: ServerGeminiEventType.LoopDetected,
2742
- };
2743
- })(),
2744
- );
2745
-
2746
- const { result } = renderTestHook([], mockClient);
2747
-
2748
- await act(async () => {
2749
- await result.current.submitQuery('test query');
2750
- });
2751
-
2752
- // Wait for confirmation request to be set
2753
- await waitFor(() => {
2754
- expect(result.current.loopDetectionConfirmationRequest).not.toBeNull();
2755
- });
2756
-
2757
- // Simulate user selecting "disable"
2758
- await act(async () => {
2759
- result.current.loopDetectionConfirmationRequest?.onComplete({
2760
- userSelection: 'disable',
2761
- });
2762
- });
2763
-
2764
- // Verify loop detection was disabled
2765
- expect(mockLoopDetectionService.disableForSession).toHaveBeenCalledTimes(
2766
- 1,
2767
- );
2768
-
2769
- // Verify confirmation request was cleared
2770
- expect(result.current.loopDetectionConfirmationRequest).toBeNull();
2771
-
2772
- // Verify appropriate message was added
2773
- expect(mockAddItem).toHaveBeenCalledWith(
2774
- {
2775
- type: 'info',
2776
- text: 'Loop detection has been disabled for this session. Please try your request again.',
2777
- },
2778
- expect.any(Number),
2779
- );
2780
- });
2781
-
2782
- it('should keep loop detection enabled and show message when user selects "keep"', async () => {
2783
- const mockLoopDetectionService = {
2784
- disableForSession: vi.fn(),
2785
- };
2786
- const mockClient = {
2787
- ...new MockedGeminiClientClass(mockConfig),
2788
- getLoopDetectionService: () => mockLoopDetectionService,
2789
- };
2790
- mockConfig.getGeminiClient = vi.fn().mockReturnValue(mockClient);
2791
-
2792
- mockSendMessageStream.mockReturnValue(
2793
- (async function* () {
2794
- yield {
2795
- type: ServerGeminiEventType.LoopDetected,
2796
- };
2797
- })(),
2798
- );
2799
-
2800
- const { result } = renderTestHook();
2801
-
2802
- await act(async () => {
2803
- await result.current.submitQuery('test query');
2804
- });
2805
-
2806
- // Wait for confirmation request to be set
2807
- await waitFor(() => {
2808
- expect(result.current.loopDetectionConfirmationRequest).not.toBeNull();
2809
- });
2810
-
2811
- // Simulate user selecting "keep"
2812
- await act(async () => {
2813
- result.current.loopDetectionConfirmationRequest?.onComplete({
2814
- userSelection: 'keep',
2815
- });
2816
- });
2817
-
2818
- // Verify loop detection was NOT disabled
2819
- expect(mockLoopDetectionService.disableForSession).not.toHaveBeenCalled();
2820
-
2821
- // Verify confirmation request was cleared
2822
- expect(result.current.loopDetectionConfirmationRequest).toBeNull();
2823
-
2824
- // Verify appropriate message was added
2825
- expect(mockAddItem).toHaveBeenCalledWith(
2826
- {
2827
- type: 'info',
2828
- text: 'A potential loop was detected. This can happen due to repetitive tool calls or other model behavior. The request has been halted.',
2829
- },
2830
- expect.any(Number),
2831
- );
2832
- });
2833
-
2834
- it('should handle multiple loop detection events properly', async () => {
2835
- const { result } = renderTestHook();
2836
-
2837
- // First loop detection - set up fresh mock for first call
2838
- mockSendMessageStream.mockReturnValueOnce(
2839
- (async function* () {
2840
- yield {
2841
- type: ServerGeminiEventType.LoopDetected,
2842
- };
2843
- })(),
2844
- );
2845
-
2846
- // First loop detection
2847
- await act(async () => {
2848
- await result.current.submitQuery('first query');
2849
- });
2850
-
2851
- await waitFor(() => {
2852
- expect(result.current.loopDetectionConfirmationRequest).not.toBeNull();
2853
- });
2854
-
2855
- // Simulate user selecting "keep" for first request
2856
- await act(async () => {
2857
- result.current.loopDetectionConfirmationRequest?.onComplete({
2858
- userSelection: 'keep',
2859
- });
2860
- });
2861
-
2862
- expect(result.current.loopDetectionConfirmationRequest).toBeNull();
2863
-
2864
- // Verify first message was added
2865
- expect(mockAddItem).toHaveBeenCalledWith(
2866
- {
2867
- type: 'info',
2868
- text: 'A potential loop was detected. This can happen due to repetitive tool calls or other model behavior. The request has been halted.',
2869
- },
2870
- expect.any(Number),
2871
- );
2872
-
2873
- // Second loop detection - set up fresh mock for second call
2874
- mockSendMessageStream.mockReturnValueOnce(
2875
- (async function* () {
2876
- yield {
2877
- type: ServerGeminiEventType.LoopDetected,
2878
- };
2879
- })(),
2880
- );
2881
-
2882
- // Second loop detection
2883
- await act(async () => {
2884
- await result.current.submitQuery('second query');
2885
- });
2886
-
2887
- await waitFor(() => {
2888
- expect(result.current.loopDetectionConfirmationRequest).not.toBeNull();
2889
- });
2890
-
2891
- // Simulate user selecting "disable" for second request
2892
- await act(async () => {
2893
- result.current.loopDetectionConfirmationRequest?.onComplete({
2894
- userSelection: 'disable',
2895
- });
2896
- });
2897
-
2898
- expect(result.current.loopDetectionConfirmationRequest).toBeNull();
2899
-
2900
- // Verify second message was added
2901
- expect(mockAddItem).toHaveBeenCalledWith(
2902
- {
2903
- type: 'info',
2904
- text: 'Loop detection has been disabled for this session. Please try your request again.',
2905
- },
2906
- expect.any(Number),
2907
- );
2908
- });
2909
-
2910
- it('should process LoopDetected event after moving pending history to history', async () => {
2911
- mockSendMessageStream.mockReturnValue(
2912
- (async function* () {
2913
- yield {
2914
- type: ServerGeminiEventType.Content,
2915
- value: 'Some response content',
2916
- };
2917
- yield {
2918
- type: ServerGeminiEventType.LoopDetected,
2919
- };
2920
- })(),
2921
- );
2922
-
2923
- const { result } = renderTestHook();
2924
-
2925
- await act(async () => {
2926
- await result.current.submitQuery('test query');
2927
- });
2928
-
2929
- // Verify that the content was added to history before the loop detection dialog
2930
- await waitFor(() => {
2931
- expect(mockAddItem).toHaveBeenCalledWith(
2932
- expect.objectContaining({
2933
- type: 'gemini',
2934
- text: 'Some response content',
2935
- }),
2936
- expect.any(Number),
2937
- );
2938
- });
2939
-
2940
- // Then verify loop detection confirmation request was set
2941
- await waitFor(() => {
2942
- expect(result.current.loopDetectionConfirmationRequest).not.toBeNull();
2943
- });
2944
- });
2945
- });
2946
- });