@machina.ai/cell-cli 1.36.0-rc1 → 1.38.1-rc2

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 (580) hide show
  1. package/dist/index.d.ts +1 -1
  2. package/dist/index.js +1 -1
  3. package/dist/package.json +4 -4
  4. package/dist/src/acp/acpClient.js +297 -32
  5. package/dist/src/acp/acpClient.js.map +1 -1
  6. package/dist/src/acp/acpClient.test.js +419 -19
  7. package/dist/src/acp/acpClient.test.js.map +1 -1
  8. package/dist/src/acp/acpResume.test.js +8 -0
  9. package/dist/src/acp/acpResume.test.js.map +1 -1
  10. package/dist/src/acp/commandHandler.js +4 -0
  11. package/dist/src/acp/commandHandler.js.map +1 -1
  12. package/dist/src/acp/commandHandler.test.js +4 -0
  13. package/dist/src/acp/commandHandler.test.js.map +1 -1
  14. package/dist/src/acp/commands/about.d.ts +11 -0
  15. package/dist/src/acp/commands/about.js +53 -0
  16. package/dist/src/acp/commands/about.js.map +1 -0
  17. package/dist/src/acp/commands/extensions.js +1 -1
  18. package/dist/src/acp/commands/extensions.js.map +1 -1
  19. package/dist/src/acp/commands/help.d.ts +14 -0
  20. package/dist/src/acp/commands/help.js +35 -0
  21. package/dist/src/acp/commands/help.js.map +1 -0
  22. package/dist/src/acp/commands/help.test.d.ts +6 -0
  23. package/dist/src/acp/commands/help.test.js +40 -0
  24. package/dist/src/acp/commands/help.test.js.map +1 -0
  25. package/dist/src/acp/commands/restore.js +2 -2
  26. package/dist/src/acp/commands/restore.js.map +1 -1
  27. package/dist/src/commands/extensions/new.js +1 -1
  28. package/dist/src/commands/extensions/new.js.map +1 -1
  29. package/dist/src/commands/mcp/list.js +2 -2
  30. package/dist/src/commands/mcp/list.js.map +1 -1
  31. package/dist/src/commands/mcp.test.js +1 -1
  32. package/dist/src/commands/mcp.test.js.map +1 -1
  33. package/dist/src/commands/skills/list.js +5 -8
  34. package/dist/src/commands/skills/list.js.map +1 -1
  35. package/dist/src/commands/skills/list.test.js +17 -13
  36. package/dist/src/commands/skills/list.test.js.map +1 -1
  37. package/dist/src/config/config.js +22 -9
  38. package/dist/src/config/config.js.map +1 -1
  39. package/dist/src/config/config.test.js +121 -36
  40. package/dist/src/config/config.test.js.map +1 -1
  41. package/dist/src/config/extension-manager-permissions.test.js +1 -1
  42. package/dist/src/config/extension-manager-permissions.test.js.map +1 -1
  43. package/dist/src/config/extension-manager-themes.spec.js +1 -0
  44. package/dist/src/config/extension-manager-themes.spec.js.map +1 -1
  45. package/dist/src/config/extension-manager.test.js +1 -1
  46. package/dist/src/config/extension-manager.test.js.map +1 -1
  47. package/dist/src/config/extension.js +1 -1
  48. package/dist/src/config/extension.js.map +1 -1
  49. package/dist/src/config/extensions/github.js +1 -1
  50. package/dist/src/config/extensions/github.js.map +1 -1
  51. package/dist/src/config/footerItems.d.ts +4 -0
  52. package/dist/src/config/footerItems.js +12 -2
  53. package/dist/src/config/footerItems.js.map +1 -1
  54. package/dist/src/config/footerItems.test.js +129 -72
  55. package/dist/src/config/footerItems.test.js.map +1 -1
  56. package/dist/src/config/policy-engine.integration.test.js +1 -3
  57. package/dist/src/config/policy-engine.integration.test.js.map +1 -1
  58. package/dist/src/config/policy.d.ts +1 -1
  59. package/dist/src/config/policy.js +2 -2
  60. package/dist/src/config/policy.js.map +1 -1
  61. package/dist/src/config/settings.js +19 -3
  62. package/dist/src/config/settings.js.map +1 -1
  63. package/dist/src/config/settingsSchema.d.ts +272 -53
  64. package/dist/src/config/settingsSchema.js +262 -48
  65. package/dist/src/config/settingsSchema.js.map +1 -1
  66. package/dist/src/config/settingsSchema.test.js +22 -4
  67. package/dist/src/config/settingsSchema.test.js.map +1 -1
  68. package/dist/src/config/workspace-policy-cli.test.js +7 -7
  69. package/dist/src/config/workspace-policy-cli.test.js.map +1 -1
  70. package/dist/src/gemini.js +24 -7
  71. package/dist/src/gemini.js.map +1 -1
  72. package/dist/src/gemini.test.js +74 -4
  73. package/dist/src/gemini.test.js.map +1 -1
  74. package/dist/src/gemini_cleanup.test.js +69 -4
  75. package/dist/src/gemini_cleanup.test.js.map +1 -1
  76. package/dist/src/generated/git-commit.d.ts +2 -2
  77. package/dist/src/generated/git-commit.js +2 -2
  78. package/dist/src/integration-tests/modelSteering.test.js +1 -1
  79. package/dist/src/integration-tests/modelSteering.test.js.map +1 -1
  80. package/dist/src/interactiveCli.js +4 -2
  81. package/dist/src/interactiveCli.js.map +1 -1
  82. package/dist/src/nonInteractiveCli.d.ts +1 -1
  83. package/dist/src/nonInteractiveCli.js +11 -2
  84. package/dist/src/nonInteractiveCli.js.map +1 -1
  85. package/dist/src/nonInteractiveCli.test.js +4 -2
  86. package/dist/src/nonInteractiveCli.test.js.map +1 -1
  87. package/dist/src/nonInteractiveCliAgentSession.d.ts +16 -0
  88. package/dist/src/nonInteractiveCliAgentSession.js +484 -0
  89. package/dist/src/nonInteractiveCliAgentSession.js.map +1 -0
  90. package/dist/src/nonInteractiveCliAgentSession.test.js +1837 -0
  91. package/dist/src/nonInteractiveCliAgentSession.test.js.map +1 -0
  92. package/dist/src/services/BuiltinCommandLoader.js +4 -2
  93. package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
  94. package/dist/src/test-utils/mockCommandContext.js +1 -0
  95. package/dist/src/test-utils/mockCommandContext.js.map +1 -1
  96. package/dist/src/test-utils/mockConfig.js +16 -0
  97. package/dist/src/test-utils/mockConfig.js.map +1 -1
  98. package/dist/src/test-utils/mockSpinner.d.ts +6 -0
  99. package/dist/src/test-utils/mockSpinner.js +21 -0
  100. package/dist/src/test-utils/mockSpinner.js.map +1 -0
  101. package/dist/src/test-utils/render.d.ts +8 -1
  102. package/dist/src/test-utils/render.js +37 -11
  103. package/dist/src/test-utils/render.js.map +1 -1
  104. package/dist/src/ui/App.test.js +1 -1
  105. package/dist/src/ui/App.test.js.map +1 -1
  106. package/dist/src/ui/AppContainer.js +225 -99
  107. package/dist/src/ui/AppContainer.js.map +1 -1
  108. package/dist/src/ui/AppContainer.test.js +50 -38
  109. package/dist/src/ui/AppContainer.test.js.map +1 -1
  110. package/dist/src/ui/commands/chatCommand.js +15 -5
  111. package/dist/src/ui/commands/chatCommand.js.map +1 -1
  112. package/dist/src/ui/commands/clearCommand.js +3 -1
  113. package/dist/src/ui/commands/clearCommand.js.map +1 -1
  114. package/dist/src/ui/commands/directoryCommand.js +1 -1
  115. package/dist/src/ui/commands/directoryCommand.js.map +1 -1
  116. package/dist/src/ui/commands/extensionsCommand.js +22 -11
  117. package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
  118. package/dist/src/ui/commands/marketplaceCommand.d.ts +7 -0
  119. package/dist/src/ui/commands/marketplaceCommand.js +135 -0
  120. package/dist/src/ui/commands/marketplaceCommand.js.map +1 -0
  121. package/dist/src/ui/commands/mcpCommand.js +26 -7
  122. package/dist/src/ui/commands/mcpCommand.js.map +1 -1
  123. package/dist/src/ui/commands/mcpCommand.test.js +26 -0
  124. package/dist/src/ui/commands/mcpCommand.test.js.map +1 -1
  125. package/dist/src/ui/commands/planCommand.js +9 -0
  126. package/dist/src/ui/commands/planCommand.js.map +1 -1
  127. package/dist/src/ui/commands/planCommand.test.js +29 -0
  128. package/dist/src/ui/commands/planCommand.test.js.map +1 -1
  129. package/dist/src/ui/commands/restoreCommand.js +1 -1
  130. package/dist/src/ui/commands/restoreCommand.js.map +1 -1
  131. package/dist/src/ui/commands/rewindCommand.js +3 -1
  132. package/dist/src/ui/commands/rewindCommand.js.map +1 -1
  133. package/dist/src/ui/commands/rewindCommand.test.js +1 -1
  134. package/dist/src/ui/commands/rewindCommand.test.js.map +1 -1
  135. package/dist/src/ui/commands/setupGithubCommand.js +5 -5
  136. package/dist/src/ui/commands/setupGithubCommand.js.map +1 -1
  137. package/dist/src/ui/commands/skillsCommand.js +11 -1
  138. package/dist/src/ui/commands/skillsCommand.js.map +1 -1
  139. package/dist/src/ui/commands/skillsCommand.test.js +1 -0
  140. package/dist/src/ui/commands/skillsCommand.test.js.map +1 -1
  141. package/dist/src/ui/commands/{shellsCommand.d.ts → tasksCommand.d.ts} +1 -1
  142. package/dist/src/ui/commands/{shellsCommand.js → tasksCommand.js} +6 -6
  143. package/dist/src/ui/commands/tasksCommand.js.map +1 -0
  144. package/dist/src/ui/commands/tasksCommand.test.js +30 -0
  145. package/dist/src/ui/commands/tasksCommand.test.js.map +1 -0
  146. package/dist/src/ui/commands/types.d.ts +9 -1
  147. package/dist/src/ui/components/AnsiOutput.js +7 -5
  148. package/dist/src/ui/components/AnsiOutput.js.map +1 -1
  149. package/dist/src/ui/components/AnsiOutput.test.js +13 -0
  150. package/dist/src/ui/components/AnsiOutput.test.js.map +1 -1
  151. package/dist/src/ui/components/AppHeader.js +11 -11
  152. package/dist/src/ui/components/AppHeader.js.map +1 -1
  153. package/dist/src/ui/components/AppHeader.test.js +6 -2
  154. package/dist/src/ui/components/AppHeader.test.js.map +1 -1
  155. package/dist/src/ui/components/AsciiArt.d.ts +6 -6
  156. package/dist/src/ui/components/AsciiArt.js +6 -6
  157. package/dist/src/ui/components/AskUserDialog.js +13 -13
  158. package/dist/src/ui/components/AskUserDialog.js.map +1 -1
  159. package/dist/src/ui/components/AskUserDialog.test.js +31 -0
  160. package/dist/src/ui/components/AskUserDialog.test.js.map +1 -1
  161. package/dist/src/ui/components/BackgroundTaskDisplay.d.ts +16 -0
  162. package/dist/src/ui/components/{BackgroundShellDisplay.js → BackgroundTaskDisplay.js} +12 -12
  163. package/dist/src/ui/components/BackgroundTaskDisplay.js.map +1 -0
  164. package/dist/src/ui/components/{BackgroundShellDisplay.test.js → BackgroundTaskDisplay.test.js} +26 -26
  165. package/dist/src/ui/components/BackgroundTaskDisplay.test.js.map +1 -0
  166. package/dist/src/ui/components/Composer.js +20 -208
  167. package/dist/src/ui/components/Composer.js.map +1 -1
  168. package/dist/src/ui/components/Composer.test.js +22 -17
  169. package/dist/src/ui/components/Composer.test.js.map +1 -1
  170. package/dist/src/ui/components/ContextSummaryDisplay.js +3 -1
  171. package/dist/src/ui/components/ContextSummaryDisplay.js.map +1 -1
  172. package/dist/src/ui/components/CopyModeWarning.js +3 -6
  173. package/dist/src/ui/components/CopyModeWarning.js.map +1 -1
  174. package/dist/src/ui/components/CopyModeWarning.test.js +7 -8
  175. package/dist/src/ui/components/CopyModeWarning.test.js.map +1 -1
  176. package/dist/src/ui/components/ExitPlanModeDialog.js +9 -0
  177. package/dist/src/ui/components/ExitPlanModeDialog.js.map +1 -1
  178. package/dist/src/ui/components/ExitPlanModeDialog.test.js +15 -3
  179. package/dist/src/ui/components/ExitPlanModeDialog.test.js.map +1 -1
  180. package/dist/src/ui/components/FolderTrustDialog.test.js +7 -8
  181. package/dist/src/ui/components/FolderTrustDialog.test.js.map +1 -1
  182. package/dist/src/ui/components/Footer.js +36 -9
  183. package/dist/src/ui/components/Footer.js.map +1 -1
  184. package/dist/src/ui/components/Footer.test.js +85 -6
  185. package/dist/src/ui/components/Footer.test.js.map +1 -1
  186. package/dist/src/ui/components/FooterConfigDialog.js +1 -0
  187. package/dist/src/ui/components/FooterConfigDialog.js.map +1 -1
  188. package/dist/src/ui/components/FooterConfigDialog.test.js +1 -1
  189. package/dist/src/ui/components/Help.test.js +1 -1
  190. package/dist/src/ui/components/Help.test.js.map +1 -1
  191. package/dist/src/ui/components/HistoryItemDisplay.d.ts +2 -0
  192. package/dist/src/ui/components/HistoryItemDisplay.js +14 -12
  193. package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
  194. package/dist/src/ui/components/InputPrompt.d.ts +10 -5
  195. package/dist/src/ui/components/InputPrompt.js +195 -90
  196. package/dist/src/ui/components/InputPrompt.js.map +1 -1
  197. package/dist/src/ui/components/InputPrompt.test.d.ts +12 -1
  198. package/dist/src/ui/components/InputPrompt.test.js +370 -160
  199. package/dist/src/ui/components/InputPrompt.test.js.map +1 -1
  200. package/dist/src/ui/components/LoadingIndicator.js +1 -2
  201. package/dist/src/ui/components/LoadingIndicator.js.map +1 -1
  202. package/dist/src/ui/components/LoadingIndicator.test.js +7 -0
  203. package/dist/src/ui/components/LoadingIndicator.test.js.map +1 -1
  204. package/dist/src/ui/components/MainContent.d.ts +1 -1
  205. package/dist/src/ui/components/MainContent.js +105 -34
  206. package/dist/src/ui/components/MainContent.js.map +1 -1
  207. package/dist/src/ui/components/MainContent.test.js +12 -9
  208. package/dist/src/ui/components/MainContent.test.js.map +1 -1
  209. package/dist/src/ui/components/MemoryUsageDisplay.d.ts +1 -0
  210. package/dist/src/ui/components/MemoryUsageDisplay.js +5 -2
  211. package/dist/src/ui/components/MemoryUsageDisplay.js.map +1 -1
  212. package/dist/src/ui/components/ModelDialog.js +50 -72
  213. package/dist/src/ui/components/ModelDialog.js.map +1 -1
  214. package/dist/src/ui/components/ModelDialog.test.js +1 -0
  215. package/dist/src/ui/components/ModelDialog.test.js.map +1 -1
  216. package/dist/src/ui/components/ModelQuotaDisplay.d.ts +18 -0
  217. package/dist/src/ui/components/ModelQuotaDisplay.js +104 -0
  218. package/dist/src/ui/components/ModelQuotaDisplay.js.map +1 -0
  219. package/dist/src/ui/components/ModelQuotaDisplay.test.d.ts +6 -0
  220. package/dist/src/ui/components/ModelQuotaDisplay.test.js +62 -0
  221. package/dist/src/ui/components/ModelQuotaDisplay.test.js.map +1 -0
  222. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js +1 -1
  223. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js.map +1 -1
  224. package/dist/src/ui/components/ProgressBar.d.ts +13 -0
  225. package/dist/src/ui/components/ProgressBar.js +17 -0
  226. package/dist/src/ui/components/ProgressBar.js.map +1 -0
  227. package/dist/src/ui/components/ProgressBar.test.d.ts +6 -0
  228. package/dist/src/ui/components/ProgressBar.test.js +28 -0
  229. package/dist/src/ui/components/ProgressBar.test.js.map +1 -0
  230. package/dist/src/ui/components/StatsDisplay.d.ts +2 -2
  231. package/dist/src/ui/components/StatsDisplay.js +47 -128
  232. package/dist/src/ui/components/StatsDisplay.js.map +1 -1
  233. package/dist/src/ui/components/StatsDisplay.test.js +65 -136
  234. package/dist/src/ui/components/StatsDisplay.test.js.map +1 -1
  235. package/dist/src/ui/components/StatusDisplay.js +1 -1
  236. package/dist/src/ui/components/StatusDisplay.js.map +1 -1
  237. package/dist/src/ui/components/StatusDisplay.test.js +3 -3
  238. package/dist/src/ui/components/StatusDisplay.test.js.map +1 -1
  239. package/dist/src/ui/components/StatusRow.d.ts +32 -0
  240. package/dist/src/ui/components/StatusRow.js +180 -0
  241. package/dist/src/ui/components/StatusRow.js.map +1 -0
  242. package/dist/src/ui/components/StatusRow.test.d.ts +6 -0
  243. package/dist/src/ui/components/StatusRow.test.js +99 -0
  244. package/dist/src/ui/components/StatusRow.test.js.map +1 -0
  245. package/dist/src/ui/components/ToastDisplay.d.ts +2 -1
  246. package/dist/src/ui/components/ToastDisplay.js +7 -5
  247. package/dist/src/ui/components/ToastDisplay.js.map +1 -1
  248. package/dist/src/ui/components/ToastDisplay.test.js +34 -20
  249. package/dist/src/ui/components/ToastDisplay.test.js.map +1 -1
  250. package/dist/src/ui/components/ToolConfirmationQueue.js +24 -9
  251. package/dist/src/ui/components/ToolConfirmationQueue.js.map +1 -1
  252. package/dist/src/ui/components/ToolConfirmationQueue.test.js +4 -6
  253. package/dist/src/ui/components/ToolConfirmationQueue.test.js.map +1 -1
  254. package/dist/src/ui/components/UserIdentity.js +8 -5
  255. package/dist/src/ui/components/UserIdentity.js.map +1 -1
  256. package/dist/src/ui/components/messages/DenseToolMessage.d.ts +13 -0
  257. package/dist/src/ui/components/messages/DenseToolMessage.js +270 -0
  258. package/dist/src/ui/components/messages/DenseToolMessage.js.map +1 -0
  259. package/dist/src/ui/components/messages/DenseToolMessage.test.d.ts +6 -0
  260. package/dist/src/ui/components/messages/DenseToolMessage.test.js +383 -0
  261. package/dist/src/ui/components/messages/DenseToolMessage.test.js.map +1 -0
  262. package/dist/src/ui/components/messages/DiffRenderer.d.ts +18 -0
  263. package/dist/src/ui/components/messages/DiffRenderer.js +54 -34
  264. package/dist/src/ui/components/messages/DiffRenderer.js.map +1 -1
  265. package/dist/src/ui/components/messages/DiffRenderer.test.js +12 -6
  266. package/dist/src/ui/components/messages/DiffRenderer.test.js.map +1 -1
  267. package/dist/src/ui/components/messages/InfoMessage.d.ts +1 -0
  268. package/dist/src/ui/components/messages/InfoMessage.js +2 -2
  269. package/dist/src/ui/components/messages/InfoMessage.js.map +1 -1
  270. package/dist/src/ui/components/messages/RedirectionConfirmation.test.js +1 -1
  271. package/dist/src/ui/components/messages/RedirectionConfirmation.test.js.map +1 -1
  272. package/dist/src/ui/components/messages/ShellToolMessage.test.js +44 -33
  273. package/dist/src/ui/components/messages/ShellToolMessage.test.js.map +1 -1
  274. package/dist/src/ui/components/messages/SubagentGroupDisplay.js +3 -2
  275. package/dist/src/ui/components/messages/SubagentGroupDisplay.js.map +1 -1
  276. package/dist/src/ui/components/messages/SubagentGroupDisplay.test.js +1 -1
  277. package/dist/src/ui/components/messages/SubagentGroupDisplay.test.js.map +1 -1
  278. package/dist/src/ui/components/messages/SubagentHistoryMessage.d.ts +13 -0
  279. package/dist/src/ui/components/messages/SubagentHistoryMessage.js +4 -0
  280. package/dist/src/ui/components/messages/SubagentHistoryMessage.js.map +1 -0
  281. package/dist/src/ui/components/messages/SubagentHistoryMessage.test.d.ts +6 -0
  282. package/dist/src/ui/components/messages/SubagentHistoryMessage.test.js +68 -0
  283. package/dist/src/ui/components/messages/SubagentHistoryMessage.test.js.map +1 -0
  284. package/dist/src/ui/components/messages/SubagentProgressDisplay.d.ts +2 -1
  285. package/dist/src/ui/components/messages/SubagentProgressDisplay.js +2 -2
  286. package/dist/src/ui/components/messages/SubagentProgressDisplay.js.map +1 -1
  287. package/dist/src/ui/components/messages/SubagentProgressDisplay.test.js +0 -4
  288. package/dist/src/ui/components/messages/SubagentProgressDisplay.test.js.map +1 -1
  289. package/dist/src/ui/components/messages/ToolConfirmationMessage.d.ts +1 -0
  290. package/dist/src/ui/components/messages/ToolConfirmationMessage.js +108 -70
  291. package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
  292. package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js +40 -25
  293. package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js.map +1 -1
  294. package/dist/src/ui/components/messages/ToolGroupMessage.compact.test.d.ts +6 -0
  295. package/dist/src/ui/components/messages/ToolGroupMessage.compact.test.js +147 -0
  296. package/dist/src/ui/components/messages/ToolGroupMessage.compact.test.js.map +1 -0
  297. package/dist/src/ui/components/messages/ToolGroupMessage.d.ts +3 -0
  298. package/dist/src/ui/components/messages/ToolGroupMessage.js +219 -52
  299. package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
  300. package/dist/src/ui/components/messages/ToolGroupMessage.test.js +55 -3
  301. package/dist/src/ui/components/messages/ToolGroupMessage.test.js.map +1 -1
  302. package/dist/src/ui/components/messages/ToolMessage.test.js +8 -7
  303. package/dist/src/ui/components/messages/ToolMessage.test.js.map +1 -1
  304. package/dist/src/ui/components/messages/ToolOverflowConsistencyChecks.test.js +1 -1
  305. package/dist/src/ui/components/messages/ToolOverflowConsistencyChecks.test.js.map +1 -1
  306. package/dist/src/ui/components/messages/ToolResultDisplay.js +57 -15
  307. package/dist/src/ui/components/messages/ToolResultDisplay.js.map +1 -1
  308. package/dist/src/ui/components/messages/ToolResultDisplay.test.js +66 -3
  309. package/dist/src/ui/components/messages/ToolResultDisplay.test.js.map +1 -1
  310. package/dist/src/ui/components/messages/ToolResultDisplayOverflow.test.js +5 -4
  311. package/dist/src/ui/components/messages/ToolResultDisplayOverflow.test.js.map +1 -1
  312. package/dist/src/ui/components/messages/ToolStickyHeaderRegression.test.js +3 -3
  313. package/dist/src/ui/components/messages/ToolStickyHeaderRegression.test.js.map +1 -1
  314. package/dist/src/ui/components/messages/TopicMessage.d.ts +15 -0
  315. package/dist/src/ui/components/messages/TopicMessage.js +56 -0
  316. package/dist/src/ui/components/messages/TopicMessage.js.map +1 -0
  317. package/dist/src/ui/components/messages/TopicMessage.test.d.ts +6 -0
  318. package/dist/src/ui/components/messages/TopicMessage.test.js +77 -0
  319. package/dist/src/ui/components/messages/TopicMessage.test.js.map +1 -0
  320. package/dist/src/ui/components/shared/MaxSizedBox.d.ts +1 -0
  321. package/dist/src/ui/components/shared/MaxSizedBox.js +10 -7
  322. package/dist/src/ui/components/shared/MaxSizedBox.js.map +1 -1
  323. package/dist/src/ui/components/shared/Scrollable.d.ts +3 -0
  324. package/dist/src/ui/components/shared/Scrollable.js +6 -2
  325. package/dist/src/ui/components/shared/Scrollable.js.map +1 -1
  326. package/dist/src/ui/components/shared/ScrollableList.d.ts +9 -12
  327. package/dist/src/ui/components/shared/ScrollableList.js +2 -2
  328. package/dist/src/ui/components/shared/ScrollableList.js.map +1 -1
  329. package/dist/src/ui/components/shared/VirtualizedList.d.ts +13 -1
  330. package/dist/src/ui/components/shared/VirtualizedList.js +148 -37
  331. package/dist/src/ui/components/shared/VirtualizedList.js.map +1 -1
  332. package/dist/src/ui/components/shared/VirtualizedList.test.js +1 -10
  333. package/dist/src/ui/components/shared/VirtualizedList.test.js.map +1 -1
  334. package/dist/src/ui/components/shared/text-buffer.d.ts +1 -0
  335. package/dist/src/ui/components/shared/text-buffer.js +19 -21
  336. package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
  337. package/dist/src/ui/components/views/ExtensionDetails.d.ts +4 -1
  338. package/dist/src/ui/components/views/ExtensionDetails.js +14 -4
  339. package/dist/src/ui/components/views/ExtensionDetails.js.map +1 -1
  340. package/dist/src/ui/components/views/ExtensionDetails.test.js +25 -1
  341. package/dist/src/ui/components/views/ExtensionDetails.test.js.map +1 -1
  342. package/dist/src/ui/components/views/ExtensionRegistryView.js +19 -5
  343. package/dist/src/ui/components/views/ExtensionRegistryView.js.map +1 -1
  344. package/dist/src/ui/components/views/ExtensionRegistryView.test.js +38 -0
  345. package/dist/src/ui/components/views/ExtensionRegistryView.test.js.map +1 -1
  346. package/dist/src/ui/components/views/SkillsList.js +2 -1
  347. package/dist/src/ui/components/views/SkillsList.js.map +1 -1
  348. package/dist/src/ui/components/views/SkillsList.test.js +3 -1
  349. package/dist/src/ui/components/views/SkillsList.test.js.map +1 -1
  350. package/dist/src/ui/constants/tips.js +2 -2
  351. package/dist/src/ui/constants/tips.js.map +1 -1
  352. package/dist/src/ui/constants.d.ts +6 -0
  353. package/dist/src/ui/constants.js +15 -0
  354. package/dist/src/ui/constants.js.map +1 -1
  355. package/dist/src/ui/contexts/InputContext.d.ts +17 -0
  356. package/dist/src/ui/contexts/InputContext.js +15 -0
  357. package/dist/src/ui/contexts/InputContext.js.map +1 -0
  358. package/dist/src/ui/contexts/KeypressContext.js +1 -1
  359. package/dist/src/ui/contexts/KeypressContext.js.map +1 -1
  360. package/dist/src/ui/contexts/KeypressContext.test.js +25 -1
  361. package/dist/src/ui/contexts/KeypressContext.test.js.map +1 -1
  362. package/dist/src/ui/contexts/ScrollProvider.js +25 -3
  363. package/dist/src/ui/contexts/ScrollProvider.js.map +1 -1
  364. package/dist/src/ui/contexts/ScrollProvider.test.js +100 -0
  365. package/dist/src/ui/contexts/ScrollProvider.test.js.map +1 -1
  366. package/dist/src/ui/contexts/SessionContext.d.ts +2 -2
  367. package/dist/src/ui/contexts/SessionContext.js.map +1 -1
  368. package/dist/src/ui/contexts/ToolActionsContext.d.ts +6 -0
  369. package/dist/src/ui/contexts/ToolActionsContext.js +19 -11
  370. package/dist/src/ui/contexts/ToolActionsContext.js.map +1 -1
  371. package/dist/src/ui/contexts/ToolActionsContext.test.js +90 -7
  372. package/dist/src/ui/contexts/ToolActionsContext.test.js.map +1 -1
  373. package/dist/src/ui/contexts/UIActionsContext.d.ts +4 -3
  374. package/dist/src/ui/contexts/UIActionsContext.js.map +1 -1
  375. package/dist/src/ui/contexts/UIStateContext.d.ts +10 -16
  376. package/dist/src/ui/contexts/UIStateContext.js.map +1 -1
  377. package/dist/src/ui/hooks/atCommandProcessor.test.js +2 -1
  378. package/dist/src/ui/hooks/atCommandProcessor.test.js.map +1 -1
  379. package/dist/src/ui/hooks/atCommandProcessor_agents.test.js +2 -1
  380. package/dist/src/ui/hooks/atCommandProcessor_agents.test.js.map +1 -1
  381. package/dist/src/ui/hooks/shellReducer.d.ts +12 -10
  382. package/dist/src/ui/hooks/shellReducer.js +67 -37
  383. package/dist/src/ui/hooks/shellReducer.js.map +1 -1
  384. package/dist/src/ui/hooks/shellReducer.test.js +207 -36
  385. package/dist/src/ui/hooks/shellReducer.test.js.map +1 -1
  386. package/dist/src/ui/hooks/slashCommandProcessor.d.ts +1 -1
  387. package/dist/src/ui/hooks/slashCommandProcessor.js +1 -1
  388. package/dist/src/ui/hooks/slashCommandProcessor.test.js +1 -1
  389. package/dist/src/ui/hooks/toolMapping.js +7 -0
  390. package/dist/src/ui/hooks/toolMapping.js.map +1 -1
  391. package/dist/src/ui/hooks/useAlternateBuffer.js +6 -1
  392. package/dist/src/ui/hooks/useAlternateBuffer.js.map +1 -1
  393. package/dist/src/ui/hooks/useAlternateBuffer.test.js +5 -0
  394. package/dist/src/ui/hooks/useAlternateBuffer.test.js.map +1 -1
  395. package/dist/src/ui/hooks/useAnimatedScrollbar.js +2 -2
  396. package/dist/src/ui/hooks/useAnimatedScrollbar.js.map +1 -1
  397. package/dist/src/ui/hooks/useAtCompletion.js +1 -1
  398. package/dist/src/ui/hooks/useAtCompletion.js.map +1 -1
  399. package/dist/src/ui/hooks/useBackgroundTaskManager.d.ts +22 -0
  400. package/dist/src/ui/hooks/useBackgroundTaskManager.js +58 -0
  401. package/dist/src/ui/hooks/useBackgroundTaskManager.js.map +1 -0
  402. package/dist/src/ui/hooks/{useBackgroundShellManager.test.js → useBackgroundTaskManager.test.js} +50 -50
  403. package/dist/src/ui/hooks/useBackgroundTaskManager.test.js.map +1 -0
  404. package/dist/src/ui/hooks/useBanner.d.ts +1 -0
  405. package/dist/src/ui/hooks/useBanner.js +16 -9
  406. package/dist/src/ui/hooks/useBanner.js.map +1 -1
  407. package/dist/src/ui/hooks/useBanner.test.js +7 -4
  408. package/dist/src/ui/hooks/useBanner.test.js.map +1 -1
  409. package/dist/src/ui/hooks/useBatchedScroll.js +2 -2
  410. package/dist/src/ui/hooks/useBatchedScroll.js.map +1 -1
  411. package/dist/src/ui/hooks/useCommandCompletion.d.ts +2 -1
  412. package/dist/src/ui/hooks/useCommandCompletion.js +13 -3
  413. package/dist/src/ui/hooks/useCommandCompletion.js.map +1 -1
  414. package/dist/src/ui/hooks/useCommandCompletion.test.d.ts +1 -1
  415. package/dist/src/ui/hooks/useCommandCompletion.test.js +82 -6
  416. package/dist/src/ui/hooks/useCommandCompletion.test.js.map +1 -1
  417. package/dist/src/ui/hooks/useComposerStatus.d.ts +21 -0
  418. package/dist/src/ui/hooks/useComposerStatus.js +78 -0
  419. package/dist/src/ui/hooks/useComposerStatus.js.map +1 -0
  420. package/dist/src/ui/hooks/useConsoleMessages.test.js +2 -2
  421. package/dist/src/ui/hooks/useConsoleMessages.test.js.map +1 -1
  422. package/dist/src/ui/hooks/useExecutionLifecycle.d.ts +28 -0
  423. package/dist/src/ui/hooks/{shellCommandProcessor.js → useExecutionLifecycle.js} +140 -58
  424. package/dist/src/ui/hooks/useExecutionLifecycle.js.map +1 -0
  425. package/dist/src/ui/hooks/useExecutionLifecycle.test.d.ts +6 -0
  426. package/dist/src/ui/hooks/{shellCommandProcessor.test.js → useExecutionLifecycle.test.js} +123 -81
  427. package/dist/src/ui/hooks/useExecutionLifecycle.test.js.map +1 -0
  428. package/dist/src/ui/hooks/useFolderTrust.js +1 -1
  429. package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
  430. package/dist/src/ui/hooks/useFolderTrust.test.js +1 -1
  431. package/dist/src/ui/hooks/useFolderTrust.test.js.map +1 -1
  432. package/dist/src/ui/hooks/useGeminiStream.d.ts +6 -6
  433. package/dist/src/ui/hooks/useGeminiStream.js +140 -38
  434. package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
  435. package/dist/src/ui/hooks/useGeminiStream.test.js +176 -22
  436. package/dist/src/ui/hooks/useGeminiStream.test.js.map +1 -1
  437. package/dist/src/ui/hooks/useGitBranchName.js +2 -2
  438. package/dist/src/ui/hooks/useGitBranchName.js.map +1 -1
  439. package/dist/src/ui/hooks/useLoadingIndicator.js +1 -1
  440. package/dist/src/ui/hooks/useLoadingIndicator.js.map +1 -1
  441. package/dist/src/ui/hooks/useLoadingIndicator.test.js +10 -0
  442. package/dist/src/ui/hooks/useLoadingIndicator.test.js.map +1 -1
  443. package/dist/src/ui/hooks/usePermissionsModifyTrust.js +2 -2
  444. package/dist/src/ui/hooks/usePermissionsModifyTrust.js.map +1 -1
  445. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.js +1 -1
  446. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.js.map +1 -1
  447. package/dist/src/ui/hooks/usePhraseCycler.js +4 -2
  448. package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
  449. package/dist/src/ui/hooks/useSessionBrowser.d.ts +1 -1
  450. package/dist/src/ui/hooks/useSessionBrowser.js +2 -2
  451. package/dist/src/ui/hooks/useSessionBrowser.js.map +1 -1
  452. package/dist/src/ui/hooks/useSlashCompletion.d.ts +1 -1
  453. package/dist/src/ui/hooks/useSlashCompletion.js +37 -63
  454. package/dist/src/ui/hooks/useSlashCompletion.js.map +1 -1
  455. package/dist/src/ui/hooks/useSlashCompletion.test.d.ts +1 -1
  456. package/dist/src/ui/hooks/useSlashCompletion.test.js +57 -47
  457. package/dist/src/ui/hooks/useSlashCompletion.test.js.map +1 -1
  458. package/dist/src/ui/hooks/useToolScheduler.d.ts +2 -1
  459. package/dist/src/ui/hooks/useToolScheduler.js +55 -1
  460. package/dist/src/ui/hooks/useToolScheduler.js.map +1 -1
  461. package/dist/src/ui/hooks/useToolScheduler.test.js +107 -9
  462. package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
  463. package/dist/src/ui/key/keyBindings.d.ts +9 -1
  464. package/dist/src/ui/key/keyBindings.js +40 -3
  465. package/dist/src/ui/key/keyBindings.js.map +1 -1
  466. package/dist/src/ui/key/keyMatchers.test.js +12 -2
  467. package/dist/src/ui/key/keyMatchers.test.js.map +1 -1
  468. package/dist/src/ui/layouts/DefaultAppLayout.js +8 -6
  469. package/dist/src/ui/layouts/DefaultAppLayout.js.map +1 -1
  470. package/dist/src/ui/layouts/DefaultAppLayout.test.js +27 -22
  471. package/dist/src/ui/layouts/DefaultAppLayout.test.js.map +1 -1
  472. package/dist/src/ui/noninteractive/nonInteractiveUi.js +1 -1
  473. package/dist/src/ui/themes/builtin/dark/tokyonight-dark.d.ts +7 -0
  474. package/dist/src/ui/themes/builtin/dark/tokyonight-dark.js +147 -0
  475. package/dist/src/ui/themes/builtin/dark/tokyonight-dark.js.map +1 -0
  476. package/dist/src/ui/themes/theme-manager.js +2 -0
  477. package/dist/src/ui/themes/theme-manager.js.map +1 -1
  478. package/dist/src/ui/themes/theme.js +1 -1
  479. package/dist/src/ui/themes/theme.js.map +1 -1
  480. package/dist/src/ui/types.d.ts +10 -2
  481. package/dist/src/ui/types.js.map +1 -1
  482. package/dist/src/ui/utils/CodeColorizer.d.ts +1 -0
  483. package/dist/src/ui/utils/CodeColorizer.js +17 -18
  484. package/dist/src/ui/utils/CodeColorizer.js.map +1 -1
  485. package/dist/src/ui/utils/ConsolePatcher.d.ts +1 -0
  486. package/dist/src/ui/utils/ConsolePatcher.js +12 -5
  487. package/dist/src/ui/utils/ConsolePatcher.js.map +1 -1
  488. package/dist/src/ui/utils/ConsolePatcher.test.d.ts +6 -0
  489. package/dist/src/ui/utils/ConsolePatcher.test.js +199 -0
  490. package/dist/src/ui/utils/ConsolePatcher.test.js.map +1 -0
  491. package/dist/src/ui/utils/TableRenderer.js +3 -3
  492. package/dist/src/ui/utils/TableRenderer.js.map +1 -1
  493. package/dist/src/ui/utils/borderStyles.d.ts +2 -2
  494. package/dist/src/ui/utils/borderStyles.js +2 -2
  495. package/dist/src/ui/utils/borderStyles.js.map +1 -1
  496. package/dist/src/ui/utils/directoryUtils.js +1 -1
  497. package/dist/src/ui/utils/directoryUtils.js.map +1 -1
  498. package/dist/src/ui/utils/fileUtils.d.ts +10 -0
  499. package/dist/src/ui/utils/fileUtils.js +17 -0
  500. package/dist/src/ui/utils/fileUtils.js.map +1 -0
  501. package/dist/src/ui/utils/terminalCapabilityManager.d.ts +1 -0
  502. package/dist/src/ui/utils/terminalCapabilityManager.js +8 -0
  503. package/dist/src/ui/utils/terminalCapabilityManager.js.map +1 -1
  504. package/dist/src/ui/utils/terminalCapabilityManager.test.js +38 -0
  505. package/dist/src/ui/utils/terminalCapabilityManager.test.js.map +1 -1
  506. package/dist/src/ui/utils/toolLayoutUtils.d.ts +1 -1
  507. package/dist/src/ui/utils/toolLayoutUtils.js +1 -1
  508. package/dist/src/ui/utils/ui-sizing.test.js +1 -0
  509. package/dist/src/ui/utils/ui-sizing.test.js.map +1 -1
  510. package/dist/src/ui/utils/updateCheck.d.ts +1 -0
  511. package/dist/src/ui/utils/updateCheck.js.map +1 -1
  512. package/dist/src/utils/activityLogger.js +16 -0
  513. package/dist/src/utils/activityLogger.js.map +1 -1
  514. package/dist/src/utils/cleanup.js +12 -5
  515. package/dist/src/utils/cleanup.js.map +1 -1
  516. package/dist/src/utils/commands.js +15 -0
  517. package/dist/src/utils/commands.js.map +1 -1
  518. package/dist/src/utils/commands.test.js +79 -0
  519. package/dist/src/utils/commands.test.js.map +1 -1
  520. package/dist/src/utils/envVarResolver.d.ts +5 -2
  521. package/dist/src/utils/envVarResolver.js +15 -6
  522. package/dist/src/utils/envVarResolver.js.map +1 -1
  523. package/dist/src/utils/envVarResolver.test.js +41 -24
  524. package/dist/src/utils/envVarResolver.test.js.map +1 -1
  525. package/dist/src/utils/errors.js +4 -4
  526. package/dist/src/utils/errors.js.map +1 -1
  527. package/dist/src/utils/events.d.ts +3 -1
  528. package/dist/src/utils/events.js +1 -0
  529. package/dist/src/utils/events.js.map +1 -1
  530. package/dist/src/utils/gitUtils.js +4 -4
  531. package/dist/src/utils/gitUtils.js.map +1 -1
  532. package/dist/src/utils/handleAutoUpdate.js +10 -3
  533. package/dist/src/utils/handleAutoUpdate.js.map +1 -1
  534. package/dist/src/utils/handleAutoUpdate.test.js +8 -2
  535. package/dist/src/utils/handleAutoUpdate.test.js.map +1 -1
  536. package/dist/src/utils/installationInfo.js +1 -1
  537. package/dist/src/utils/installationInfo.js.map +1 -1
  538. package/dist/src/utils/jsonoutput.js +1 -1
  539. package/dist/src/utils/jsonoutput.js.map +1 -1
  540. package/dist/src/utils/sandboxUtils.js +1 -1
  541. package/dist/src/utils/sandboxUtils.js.map +1 -1
  542. package/dist/src/utils/sessionCleanup.js +7 -30
  543. package/dist/src/utils/sessionCleanup.js.map +1 -1
  544. package/dist/src/utils/sessionCleanup.test.js +3 -0
  545. package/dist/src/utils/sessionCleanup.test.js.map +1 -1
  546. package/dist/src/utils/sessionUtils.js +1 -0
  547. package/dist/src/utils/sessionUtils.js.map +1 -1
  548. package/dist/src/utils/sessionUtils.test.js +179 -3
  549. package/dist/src/utils/sessionUtils.test.js.map +1 -1
  550. package/dist/src/utils/sessions.js +1 -1
  551. package/dist/src/utils/sessions.js.map +1 -1
  552. package/dist/src/utils/skillUtils.js +3 -1
  553. package/dist/src/utils/skillUtils.js.map +1 -1
  554. package/dist/src/utils/skillUtils.test.js +4 -6
  555. package/dist/src/utils/skillUtils.test.js.map +1 -1
  556. package/dist/src/utils/terminalNotifications.js +2 -4
  557. package/dist/src/utils/terminalNotifications.js.map +1 -1
  558. package/dist/src/utils/terminalNotifications.test.js +5 -3
  559. package/dist/src/utils/terminalNotifications.test.js.map +1 -1
  560. package/dist/src/utils/userStartupWarnings.js +2 -2
  561. package/dist/src/utils/userStartupWarnings.js.map +1 -1
  562. package/dist/tsconfig.tsbuildinfo +1 -1
  563. package/package.json +4 -4
  564. package/dist/src/ui/commands/shellsCommand.js.map +0 -1
  565. package/dist/src/ui/commands/shellsCommand.test.js +0 -29
  566. package/dist/src/ui/commands/shellsCommand.test.js.map +0 -1
  567. package/dist/src/ui/components/BackgroundShellDisplay.d.ts +0 -16
  568. package/dist/src/ui/components/BackgroundShellDisplay.js.map +0 -1
  569. package/dist/src/ui/components/BackgroundShellDisplay.test.js.map +0 -1
  570. package/dist/src/ui/hooks/shellCommandProcessor.d.ts +0 -28
  571. package/dist/src/ui/hooks/shellCommandProcessor.js.map +0 -1
  572. package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +0 -1
  573. package/dist/src/ui/hooks/useBackgroundShellManager.d.ts +0 -22
  574. package/dist/src/ui/hooks/useBackgroundShellManager.js +0 -58
  575. package/dist/src/ui/hooks/useBackgroundShellManager.js.map +0 -1
  576. package/dist/src/ui/hooks/useBackgroundShellManager.test.js.map +0 -1
  577. /package/dist/src/{ui/commands/shellsCommand.test.d.ts → nonInteractiveCliAgentSession.test.d.ts} +0 -0
  578. /package/dist/src/ui/{components/BackgroundShellDisplay.test.d.ts → commands/tasksCommand.test.d.ts} +0 -0
  579. /package/dist/src/ui/{hooks/shellCommandProcessor.test.d.ts → components/BackgroundTaskDisplay.test.d.ts} +0 -0
  580. /package/dist/src/ui/hooks/{useBackgroundShellManager.test.d.ts → useBackgroundTaskManager.test.d.ts} +0 -0
@@ -6,7 +6,7 @@
6
6
  import { describe, it, expect, vi, beforeEach, afterEach, } from 'vitest';
7
7
  import { GeminiAgent, Session } from './acpClient.js';
8
8
  import * as acp from '@agentclientprotocol/sdk';
9
- import { AuthType, ToolConfirmationOutcome, StreamEventType, isWithinRoot, ReadManyFilesTool, LlmRole, } from '@google/gemini-cli-core';
9
+ import { AuthType, ToolConfirmationOutcome, StreamEventType, ReadManyFilesTool, LlmRole, processSingleFileContent, InvalidStreamError, } from '@google/gemini-cli-core';
10
10
  import { SettingScope, loadSettings, } from '../config/settings.js';
11
11
  import { loadCliConfig } from '../config/config.js';
12
12
  import * as fs from 'node:fs/promises';
@@ -61,19 +61,10 @@ vi.mock('@google/gemini-cli-core', async (importOriginal) => {
61
61
  const actual = await importOriginal();
62
62
  return {
63
63
  ...actual,
64
- ReadManyFilesTool: vi.fn().mockImplementation(() => ({
65
- name: 'read_many_files',
66
- kind: 'read',
67
- build: vi.fn().mockReturnValue({
68
- getDescription: () => 'Read files',
69
- toolLocations: () => [],
70
- execute: vi.fn().mockResolvedValue({
71
- llmContent: ['--- file.txt ---\n\nFile content\n\n'],
72
- }),
73
- }),
74
- })),
64
+ updatePolicy: vi.fn(),
65
+ createPolicyUpdater: vi.fn(),
66
+ ReadManyFilesTool: vi.fn(),
75
67
  logToolCall: vi.fn(),
76
- isWithinRoot: vi.fn().mockReturnValue(true),
77
68
  LlmRole: {
78
69
  MAIN: 'main',
79
70
  SUBAGENT: 'subagent',
@@ -96,6 +87,7 @@ vi.mock('@google/gemini-cli-core', async (importOriginal) => {
96
87
  Cancelled: 'cancelled',
97
88
  AwaitingApproval: 'awaiting_approval',
98
89
  },
90
+ processSingleFileContent: vi.fn(),
99
91
  };
100
92
  });
101
93
  // Helper to create mock streams
@@ -135,6 +127,24 @@ describe('GeminiAgent', () => {
135
127
  getHasAccessToPreviewModel: vi.fn().mockReturnValue(false),
136
128
  getCheckpointingEnabled: vi.fn().mockReturnValue(false),
137
129
  getDisableAlwaysAllow: vi.fn().mockReturnValue(false),
130
+ validatePathAccess: vi.fn().mockReturnValue(null),
131
+ getWorkspaceContext: vi.fn().mockReturnValue({
132
+ addReadOnlyPath: vi.fn(),
133
+ }),
134
+ getPolicyEngine: vi.fn().mockReturnValue({
135
+ addRule: vi.fn(),
136
+ }),
137
+ messageBus: {
138
+ publish: vi.fn(),
139
+ subscribe: vi.fn(),
140
+ unsubscribe: vi.fn(),
141
+ },
142
+ storage: {
143
+ getWorkspaceAutoSavedPolicyPath: vi.fn(),
144
+ getAutoSavedPolicyPath: vi.fn(),
145
+ setClientName: vi.fn(),
146
+ },
147
+ setClientName: vi.fn(),
138
148
  get config() {
139
149
  return this;
140
150
  },
@@ -149,11 +159,15 @@ describe('GeminiAgent', () => {
149
159
  mockArgv = {};
150
160
  mockConnection = {
151
161
  sessionUpdate: vi.fn(),
162
+ requestPermission: vi.fn(),
152
163
  };
153
164
  loadCliConfig.mockResolvedValue(mockConfig);
154
165
  loadSettings.mockImplementation(() => ({
155
166
  merged: {
156
- security: { auth: { selectedType: AuthType.LOGIN_WITH_GOOGLE } },
167
+ security: {
168
+ auth: { selectedType: AuthType.LOGIN_WITH_GOOGLE },
169
+ enablePermanentToolApproval: true,
170
+ },
157
171
  mcpServers: {},
158
172
  },
159
173
  setValue: vi.fn(),
@@ -296,6 +310,21 @@ describe('GeminiAgent', () => {
296
310
  }),
297
311
  ]));
298
312
  });
313
+ it('should include gemini-3.1-flash-lite when useGemini31FlashLite is true', async () => {
314
+ mockConfig.getHasAccessToPreviewModel = vi.fn().mockReturnValue(true);
315
+ mockConfig.getGemini31LaunchedSync = vi.fn().mockReturnValue(true);
316
+ mockConfig.getGemini31FlashLiteLaunchedSync = vi.fn().mockReturnValue(true);
317
+ const response = await agent.newSession({
318
+ cwd: '/tmp',
319
+ mcpServers: [],
320
+ });
321
+ expect(response.models?.availableModels).toEqual(expect.arrayContaining([
322
+ expect.objectContaining({
323
+ modelId: 'gemini-3.1-flash-lite-preview',
324
+ name: 'gemini-3.1-flash-lite-preview',
325
+ }),
326
+ ]));
327
+ });
299
328
  it('should return modes with plan mode when plan is enabled', async () => {
300
329
  mockConfig.getContentGeneratorConfig = vi.fn().mockReturnValue({
301
330
  apiKey: 'test-key',
@@ -472,6 +501,7 @@ describe('Session', () => {
472
501
  sendMessageStream: vi.fn(),
473
502
  addHistory: vi.fn(),
474
503
  recordCompletedToolCalls: vi.fn(),
504
+ getHistory: vi.fn().mockReturnValue([]),
475
505
  };
476
506
  mockTool = {
477
507
  kind: 'read',
@@ -493,12 +523,16 @@ describe('Session', () => {
493
523
  mockConfig = {
494
524
  getModel: vi.fn().mockReturnValue('gemini-pro'),
495
525
  getActiveModel: vi.fn().mockReturnValue('gemini-pro'),
526
+ getModelRouterService: vi.fn().mockReturnValue({
527
+ route: vi.fn().mockResolvedValue({ model: 'resolved-model' }),
528
+ }),
496
529
  getToolRegistry: vi.fn().mockReturnValue(mockToolRegistry),
497
530
  getMcpServers: vi.fn(),
498
531
  getFileService: vi.fn().mockReturnValue({
499
532
  shouldIgnoreFile: vi.fn().mockReturnValue(false),
500
533
  }),
501
534
  getFileFilteringOptions: vi.fn().mockReturnValue({}),
535
+ getFileSystemService: vi.fn().mockReturnValue({}),
502
536
  getTargetDir: vi.fn().mockReturnValue('/tmp'),
503
537
  getEnableRecursiveFileSearch: vi.fn().mockReturnValue(false),
504
538
  getDebugMode: vi.fn().mockReturnValue(false),
@@ -508,6 +542,10 @@ describe('Session', () => {
508
542
  isPlanEnabled: vi.fn().mockReturnValue(true),
509
543
  getCheckpointingEnabled: vi.fn().mockReturnValue(false),
510
544
  getGitService: vi.fn().mockResolvedValue({}),
545
+ validatePathAccess: vi.fn().mockReturnValue(null),
546
+ getWorkspaceContext: vi.fn().mockReturnValue({
547
+ addReadOnlyPath: vi.fn(),
548
+ }),
511
549
  waitForMcpInit: vi.fn(),
512
550
  getDisableAlwaysAllow: vi.fn().mockReturnValue(false),
513
551
  get config() {
@@ -527,12 +565,26 @@ describe('Session', () => {
527
565
  systemDefaults: { settings: {} },
528
566
  user: { settings: {} },
529
567
  workspace: { settings: {} },
530
- merged: { settings: {} },
568
+ merged: {
569
+ security: { enablePermanentToolApproval: true },
570
+ mcpServers: {},
571
+ },
531
572
  errors: [],
532
573
  });
574
+ ReadManyFilesTool.mockImplementation(() => ({
575
+ name: 'read_many_files',
576
+ kind: 'read',
577
+ build: vi.fn().mockReturnValue({
578
+ getDescription: () => 'Read files',
579
+ toolLocations: () => [],
580
+ execute: vi.fn().mockResolvedValue({
581
+ llmContent: ['--- file.txt ---\n\nFile content\n\n'],
582
+ }),
583
+ }),
584
+ }));
533
585
  });
534
586
  afterEach(() => {
535
- vi.clearAllMocks();
587
+ vi.restoreAllMocks();
536
588
  });
537
589
  it('should send available commands', async () => {
538
590
  await session.sendAvailableCommands();
@@ -591,6 +643,66 @@ describe('Session', () => {
591
643
  });
592
644
  expect(result).toMatchObject({ stopReason: 'end_turn' });
593
645
  });
646
+ it('should use model router to determine model', async () => {
647
+ const mockRouter = {
648
+ route: vi.fn().mockResolvedValue({ model: 'routed-model' }),
649
+ };
650
+ mockConfig.getModelRouterService.mockReturnValue(mockRouter);
651
+ const stream = createMockStream([
652
+ {
653
+ type: StreamEventType.CHUNK,
654
+ value: {
655
+ candidates: [{ content: { parts: [{ text: 'Hello' }] } }],
656
+ },
657
+ },
658
+ ]);
659
+ mockChat.sendMessageStream.mockResolvedValue(stream);
660
+ await session.prompt({
661
+ sessionId: 'session-1',
662
+ prompt: [{ type: 'text', text: 'Hi' }],
663
+ });
664
+ expect(mockRouter.route).toHaveBeenCalledWith(expect.objectContaining({
665
+ requestedModel: 'gemini-pro',
666
+ request: [{ text: 'Hi' }],
667
+ }));
668
+ expect(mockChat.sendMessageStream).toHaveBeenCalledWith(expect.objectContaining({ model: 'routed-model' }), expect.any(Array), expect.any(String), expect.any(Object), expect.any(String));
669
+ });
670
+ it('should handle prompt with empty response (InvalidStreamError)', async () => {
671
+ mockChat.sendMessageStream.mockRejectedValue(new InvalidStreamError('Empty response', 'NO_RESPONSE_TEXT'));
672
+ const result = await session.prompt({
673
+ sessionId: 'session-1',
674
+ prompt: [{ type: 'text', text: 'Hi' }],
675
+ });
676
+ expect(mockChat.sendMessageStream).toHaveBeenCalled();
677
+ expect(result).toMatchObject({ stopReason: 'end_turn' });
678
+ });
679
+ it('should handle prompt with empty response (NO_RESPONSE_TEXT anomaly)', async () => {
680
+ mockChat.sendMessageStream.mockRejectedValue({ type: 'NO_RESPONSE_TEXT' });
681
+ const result = await session.prompt({
682
+ sessionId: 'session-1',
683
+ prompt: [{ type: 'text', text: 'Hi' }],
684
+ });
685
+ expect(mockChat.sendMessageStream).toHaveBeenCalled();
686
+ expect(result).toMatchObject({ stopReason: 'end_turn' });
687
+ });
688
+ it('should handle prompt with no finish reason (InvalidStreamError)', async () => {
689
+ mockChat.sendMessageStream.mockRejectedValue(new InvalidStreamError('No finish reason', 'NO_FINISH_REASON'));
690
+ const result = await session.prompt({
691
+ sessionId: 'session-1',
692
+ prompt: [{ type: 'text', text: 'Hi' }],
693
+ });
694
+ expect(mockChat.sendMessageStream).toHaveBeenCalled();
695
+ expect(result).toMatchObject({ stopReason: 'end_turn' });
696
+ });
697
+ it('should handle prompt with no finish reason (NO_FINISH_REASON anomaly)', async () => {
698
+ mockChat.sendMessageStream.mockRejectedValue({ type: 'NO_FINISH_REASON' });
699
+ const result = await session.prompt({
700
+ sessionId: 'session-1',
701
+ prompt: [{ type: 'text', text: 'Hi' }],
702
+ });
703
+ expect(mockChat.sendMessageStream).toHaveBeenCalled();
704
+ expect(result).toMatchObject({ stopReason: 'end_turn' });
705
+ });
594
706
  it('should handle /memory command', async () => {
595
707
  const handleCommandSpy = vi
596
708
  .spyOn(session
@@ -788,6 +900,132 @@ describe('Session', () => {
788
900
  ]),
789
901
  }));
790
902
  });
903
+ it('should exclude always allow and save permanent option when enablePermanentToolApproval is false', async () => {
904
+ mockConfig.getDisableAlwaysAllow = vi.fn().mockReturnValue(false);
905
+ const confirmationDetails = {
906
+ type: 'edit',
907
+ onConfirm: vi.fn(),
908
+ };
909
+ mockTool.build.mockReturnValue({
910
+ getDescription: () => 'Test Tool',
911
+ toolLocations: () => [],
912
+ shouldConfirmExecute: vi.fn().mockResolvedValue(confirmationDetails),
913
+ execute: vi.fn().mockResolvedValue({ llmContent: 'Tool Result' }),
914
+ });
915
+ const customSettings = {
916
+ system: { settings: {} },
917
+ systemDefaults: { settings: {} },
918
+ user: { settings: {} },
919
+ workspace: { settings: {} },
920
+ merged: {
921
+ security: { enablePermanentToolApproval: false },
922
+ mcpServers: {},
923
+ },
924
+ errors: [],
925
+ };
926
+ const localSession = new Session('session-2', mockChat, mockConfig, mockConnection, customSettings);
927
+ mockConnection.requestPermission.mockResolvedValueOnce({
928
+ outcome: {
929
+ outcome: 'selected',
930
+ optionId: ToolConfirmationOutcome.ProceedOnce,
931
+ },
932
+ });
933
+ const stream1 = createMockStream([
934
+ {
935
+ type: StreamEventType.CHUNK,
936
+ value: {
937
+ functionCalls: [{ name: 'test_tool', args: {} }],
938
+ },
939
+ },
940
+ ]);
941
+ const stream2 = createMockStream([
942
+ {
943
+ type: StreamEventType.CHUNK,
944
+ value: { candidates: [] },
945
+ },
946
+ ]);
947
+ mockChat.sendMessageStream
948
+ .mockResolvedValueOnce(stream1)
949
+ .mockResolvedValueOnce(stream2);
950
+ await localSession.prompt({
951
+ sessionId: 'session-2',
952
+ prompt: [{ type: 'text', text: 'Call tool' }],
953
+ });
954
+ expect(mockConnection.requestPermission).toHaveBeenCalledWith(expect.objectContaining({
955
+ options: expect.not.arrayContaining([
956
+ expect.objectContaining({
957
+ optionId: ToolConfirmationOutcome.ProceedAlwaysAndSave,
958
+ }),
959
+ ]),
960
+ }));
961
+ expect(mockConnection.requestPermission).toHaveBeenCalledWith(expect.objectContaining({
962
+ options: expect.arrayContaining([
963
+ expect.objectContaining({
964
+ optionId: ToolConfirmationOutcome.ProceedAlways,
965
+ }),
966
+ ]),
967
+ }));
968
+ });
969
+ it('should include always allow and save permanent option when enablePermanentToolApproval is true', async () => {
970
+ mockConfig.getDisableAlwaysAllow = vi.fn().mockReturnValue(false);
971
+ const confirmationDetails = {
972
+ type: 'edit',
973
+ onConfirm: vi.fn(),
974
+ };
975
+ mockTool.build.mockReturnValue({
976
+ getDescription: () => 'Test Tool',
977
+ toolLocations: () => [],
978
+ shouldConfirmExecute: vi.fn().mockResolvedValue(confirmationDetails),
979
+ execute: vi.fn().mockResolvedValue({ llmContent: 'Tool Result' }),
980
+ });
981
+ const customSettings = {
982
+ system: { settings: {} },
983
+ systemDefaults: { settings: {} },
984
+ user: { settings: {} },
985
+ workspace: { settings: {} },
986
+ merged: {
987
+ security: { enablePermanentToolApproval: true },
988
+ mcpServers: {},
989
+ },
990
+ errors: [],
991
+ };
992
+ const localSession = new Session('session-2', mockChat, mockConfig, mockConnection, customSettings);
993
+ mockConnection.requestPermission.mockResolvedValueOnce({
994
+ outcome: {
995
+ outcome: 'selected',
996
+ optionId: ToolConfirmationOutcome.ProceedOnce,
997
+ },
998
+ });
999
+ const stream1 = createMockStream([
1000
+ {
1001
+ type: StreamEventType.CHUNK,
1002
+ value: {
1003
+ functionCalls: [{ name: 'test_tool', args: {} }],
1004
+ },
1005
+ },
1006
+ ]);
1007
+ const stream2 = createMockStream([
1008
+ {
1009
+ type: StreamEventType.CHUNK,
1010
+ value: { candidates: [] },
1011
+ },
1012
+ ]);
1013
+ mockChat.sendMessageStream
1014
+ .mockResolvedValueOnce(stream1)
1015
+ .mockResolvedValueOnce(stream2);
1016
+ await localSession.prompt({
1017
+ sessionId: 'session-2',
1018
+ prompt: [{ type: 'text', text: 'Call tool' }],
1019
+ });
1020
+ expect(mockConnection.requestPermission).toHaveBeenCalledWith(expect.objectContaining({
1021
+ options: expect.arrayContaining([
1022
+ expect.objectContaining({
1023
+ optionId: ToolConfirmationOutcome.ProceedAlwaysAndSave,
1024
+ name: 'Allow for this file in all future sessions',
1025
+ }),
1026
+ ]),
1027
+ }));
1028
+ });
791
1029
  it('should use filePath for ACP diff content in permission request', async () => {
792
1030
  const confirmationDetails = {
793
1031
  type: 'edit',
@@ -897,6 +1135,48 @@ describe('Session', () => {
897
1135
  }),
898
1136
  }));
899
1137
  });
1138
+ it('should call updatePolicy when tool permission triggers always allow', async () => {
1139
+ const confirmationDetails = {
1140
+ type: 'info',
1141
+ onConfirm: vi.fn(),
1142
+ };
1143
+ mockTool.build.mockReturnValue({
1144
+ getDescription: () => 'Test Tool',
1145
+ toolLocations: () => [],
1146
+ shouldConfirmExecute: vi.fn().mockResolvedValue(confirmationDetails),
1147
+ execute: vi.fn().mockResolvedValue({ llmContent: 'Tool Result' }),
1148
+ });
1149
+ mockConnection.requestPermission.mockResolvedValue({
1150
+ outcome: {
1151
+ outcome: 'selected',
1152
+ optionId: ToolConfirmationOutcome.ProceedAlways,
1153
+ },
1154
+ });
1155
+ const stream1 = createMockStream([
1156
+ {
1157
+ type: StreamEventType.CHUNK,
1158
+ value: {
1159
+ functionCalls: [{ name: 'test_tool', args: {} }],
1160
+ },
1161
+ },
1162
+ ]);
1163
+ const stream2 = createMockStream([
1164
+ {
1165
+ type: StreamEventType.CHUNK,
1166
+ value: { candidates: [] },
1167
+ },
1168
+ ]);
1169
+ mockChat.sendMessageStream
1170
+ .mockResolvedValueOnce(stream1)
1171
+ .mockResolvedValueOnce(stream2);
1172
+ const { updatePolicy } = await import('@google/gemini-cli-core');
1173
+ await session.prompt({
1174
+ sessionId: 'session-1',
1175
+ prompt: [{ type: 'text', text: 'Call tool' }],
1176
+ });
1177
+ expect(confirmationDetails.onConfirm).toHaveBeenCalled();
1178
+ expect(updatePolicy).toHaveBeenCalled();
1179
+ });
900
1180
  it('should use filePath for ACP diff content in tool result', async () => {
901
1181
  mockTool.build.mockReturnValue({
902
1182
  getDescription: () => 'Test Tool',
@@ -1076,7 +1356,6 @@ describe('Session', () => {
1076
1356
  fs.stat.mockResolvedValue({
1077
1357
  isDirectory: () => false,
1078
1358
  });
1079
- isWithinRoot.mockReturnValue(true);
1080
1359
  const stream = createMockStream([
1081
1360
  {
1082
1361
  type: StreamEventType.CHUNK,
@@ -1120,7 +1399,6 @@ describe('Session', () => {
1120
1399
  fs.stat.mockResolvedValue({
1121
1400
  isDirectory: () => false,
1122
1401
  });
1123
- isWithinRoot.mockReturnValue(true);
1124
1402
  const MockReadManyFilesTool = ReadManyFilesTool;
1125
1403
  MockReadManyFilesTool.mockImplementationOnce(() => ({
1126
1404
  name: 'read_many_files',
@@ -1165,6 +1443,129 @@ describe('Session', () => {
1165
1443
  }),
1166
1444
  }));
1167
1445
  });
1446
+ it('should handle @path validation error and bubble it to user', async () => {
1447
+ mockConfig.getTargetDir.mockReturnValue('/workspace');
1448
+ path.resolve.mockReturnValue('/tmp/disallowed.txt');
1449
+ mockConfig.validatePathAccess.mockReturnValue('Path is outside workspace');
1450
+ // Force fs.stat to fail to skip direct reading and triggers the warning
1451
+ fs.stat.mockRejectedValue(new Error('File not found'));
1452
+ const stream = createMockStream([
1453
+ {
1454
+ type: StreamEventType.CHUNK,
1455
+ value: { candidates: [] },
1456
+ },
1457
+ ]);
1458
+ mockChat.sendMessageStream.mockResolvedValue(stream);
1459
+ await session.prompt({
1460
+ sessionId: 'session-1',
1461
+ prompt: [
1462
+ {
1463
+ type: 'resource_link',
1464
+ uri: 'file://disallowed.txt',
1465
+ mimeType: 'text/plain',
1466
+ name: 'disallowed.txt',
1467
+ },
1468
+ ],
1469
+ });
1470
+ // Verify warning sent via sendUpdate
1471
+ expect(mockConnection.sessionUpdate).toHaveBeenCalledWith(expect.objectContaining({
1472
+ update: expect.objectContaining({
1473
+ sessionUpdate: 'agent_thought_chunk',
1474
+ content: expect.objectContaining({
1475
+ text: expect.stringContaining('Warning: skipping access to `disallowed.txt`. Reason: Path is outside workspace'),
1476
+ }),
1477
+ }),
1478
+ }));
1479
+ });
1480
+ it('should read absolute file directly if outside workspace', async () => {
1481
+ mockConfig.getTargetDir.mockReturnValue('/workspace');
1482
+ const testFilePath = '/tmp/custom.txt';
1483
+ path.resolve.mockReturnValue(testFilePath);
1484
+ mockConfig.validatePathAccess.mockReturnValue('Path is outside workspace');
1485
+ mockConnection.requestPermission.mockResolvedValue({
1486
+ outcome: {
1487
+ outcome: 'selected',
1488
+ optionId: ToolConfirmationOutcome.ProceedOnce,
1489
+ },
1490
+ });
1491
+ const mockStats = {
1492
+ isFile: () => true,
1493
+ isDirectory: () => false,
1494
+ };
1495
+ fs.stat.mockResolvedValue(mockStats);
1496
+ processSingleFileContent.mockResolvedValue({
1497
+ llmContent: 'Absolute File Content',
1498
+ });
1499
+ const stream = createMockStream([
1500
+ {
1501
+ type: StreamEventType.CHUNK,
1502
+ value: { candidates: [] },
1503
+ },
1504
+ ]);
1505
+ mockChat.sendMessageStream.mockResolvedValue(stream);
1506
+ await session.prompt({
1507
+ sessionId: 'session-1',
1508
+ prompt: [
1509
+ {
1510
+ type: 'resource_link',
1511
+ uri: `file://${testFilePath}`,
1512
+ mimeType: 'text/plain',
1513
+ name: 'custom.txt',
1514
+ },
1515
+ ],
1516
+ });
1517
+ expect(processSingleFileContent).toHaveBeenCalledWith(testFilePath, expect.anything(), expect.anything());
1518
+ // Verify content appended to sendMessageStream parts
1519
+ expect(mockChat.sendMessageStream).toHaveBeenCalledWith(expect.anything(), expect.arrayContaining([
1520
+ expect.objectContaining({
1521
+ text: 'Absolute File Content',
1522
+ }),
1523
+ ]), expect.anything(), expect.any(AbortSignal), expect.anything());
1524
+ });
1525
+ it('should read escaping relative file directly if outside workspace', async () => {
1526
+ mockConfig.getTargetDir.mockReturnValue('/workspace');
1527
+ const testFilePath = '../../custom.txt';
1528
+ path.resolve.mockReturnValue('/custom.txt');
1529
+ mockConfig.validatePathAccess.mockReturnValue('Path is outside workspace');
1530
+ mockConnection.requestPermission.mockResolvedValue({
1531
+ outcome: {
1532
+ outcome: 'selected',
1533
+ optionId: ToolConfirmationOutcome.ProceedOnce,
1534
+ },
1535
+ });
1536
+ const mockStats = {
1537
+ isFile: () => true,
1538
+ isDirectory: () => false,
1539
+ };
1540
+ fs.stat.mockResolvedValue(mockStats);
1541
+ processSingleFileContent.mockResolvedValue({
1542
+ llmContent: 'Escaping Relative File Content',
1543
+ });
1544
+ const stream = createMockStream([
1545
+ {
1546
+ type: StreamEventType.CHUNK,
1547
+ value: { candidates: [] },
1548
+ },
1549
+ ]);
1550
+ mockChat.sendMessageStream.mockResolvedValue(stream);
1551
+ await session.prompt({
1552
+ sessionId: 'session-1',
1553
+ prompt: [
1554
+ {
1555
+ type: 'resource_link',
1556
+ uri: `file://${testFilePath}`,
1557
+ mimeType: 'text/plain',
1558
+ name: 'custom.txt',
1559
+ },
1560
+ ],
1561
+ });
1562
+ expect(processSingleFileContent).toHaveBeenCalledWith('/custom.txt', expect.any(String), expect.anything());
1563
+ expect(mockChat.sendMessageStream).toHaveBeenCalledWith(expect.anything(), expect.arrayContaining([
1564
+ expect.objectContaining({
1565
+ text: 'Escaping Relative File Content',
1566
+ }),
1567
+ ]), expect.anything(), expect.any(AbortSignal), expect.anything());
1568
+ });
1168
1569
  it('should handle cancellation during prompt', async () => {
1169
1570
  let streamController;
1170
1571
  const stream = new ReadableStream({
@@ -1332,7 +1733,6 @@ describe('Session', () => {
1332
1733
  fs.stat.mockResolvedValue({
1333
1734
  isDirectory: () => true,
1334
1735
  });
1335
- isWithinRoot.mockReturnValue(true);
1336
1736
  const stream = createMockStream([
1337
1737
  {
1338
1738
  type: StreamEventType.CHUNK,