@machina.ai/cell-cli 1.16.0-rc2 → 1.19.4-rc1

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 (695) hide show
  1. package/dist/index.d.ts +1 -1
  2. package/dist/index.js +8 -7
  3. package/dist/index.js.map +1 -1
  4. package/dist/package.json +10 -9
  5. package/dist/src/commands/extensions/disable.js +2 -0
  6. package/dist/src/commands/extensions/disable.js.map +1 -1
  7. package/dist/src/commands/extensions/disable.test.d.ts +6 -0
  8. package/dist/src/commands/extensions/disable.test.js +169 -0
  9. package/dist/src/commands/extensions/disable.test.js.map +1 -0
  10. package/dist/src/commands/extensions/enable.js +2 -0
  11. package/dist/src/commands/extensions/enable.js.map +1 -1
  12. package/dist/src/commands/extensions/enable.test.d.ts +6 -0
  13. package/dist/src/commands/extensions/enable.test.js +150 -0
  14. package/dist/src/commands/extensions/enable.test.js.map +1 -0
  15. package/dist/src/commands/extensions/examples/mcp-server/example.test.d.ts +6 -0
  16. package/dist/src/commands/extensions/examples/mcp-server/example.test.js +111 -0
  17. package/dist/src/commands/extensions/examples/mcp-server/example.test.js.map +1 -0
  18. package/dist/src/commands/extensions/examples/mcp-server/example.test.ts +143 -0
  19. package/dist/src/commands/extensions/examples/mcp-server/package.json +1 -1
  20. package/dist/src/commands/extensions/install.js +2 -0
  21. package/dist/src/commands/extensions/install.js.map +1 -1
  22. package/dist/src/commands/extensions/install.test.js +3 -0
  23. package/dist/src/commands/extensions/install.test.js.map +1 -1
  24. package/dist/src/commands/extensions/link.js +2 -0
  25. package/dist/src/commands/extensions/link.js.map +1 -1
  26. package/dist/src/commands/extensions/link.test.d.ts +6 -0
  27. package/dist/src/commands/extensions/link.test.js +131 -0
  28. package/dist/src/commands/extensions/link.test.js.map +1 -0
  29. package/dist/src/commands/extensions/list.js +2 -0
  30. package/dist/src/commands/extensions/list.js.map +1 -1
  31. package/dist/src/commands/extensions/list.test.d.ts +6 -0
  32. package/dist/src/commands/extensions/list.test.js +112 -0
  33. package/dist/src/commands/extensions/list.test.js.map +1 -0
  34. package/dist/src/commands/extensions/new.js +2 -0
  35. package/dist/src/commands/extensions/new.js.map +1 -1
  36. package/dist/src/commands/extensions/new.test.js +3 -0
  37. package/dist/src/commands/extensions/new.test.js.map +1 -1
  38. package/dist/src/commands/extensions/uninstall.d.ts +1 -1
  39. package/dist/src/commands/extensions/uninstall.js +26 -9
  40. package/dist/src/commands/extensions/uninstall.js.map +1 -1
  41. package/dist/src/commands/extensions/uninstall.test.js +190 -9
  42. package/dist/src/commands/extensions/uninstall.test.js.map +1 -1
  43. package/dist/src/commands/extensions/update.js +2 -0
  44. package/dist/src/commands/extensions/update.js.map +1 -1
  45. package/dist/src/commands/extensions/update.test.d.ts +6 -0
  46. package/dist/src/commands/extensions/update.test.js +170 -0
  47. package/dist/src/commands/extensions/update.test.js.map +1 -0
  48. package/dist/src/commands/extensions/validate.js +2 -0
  49. package/dist/src/commands/extensions/validate.js.map +1 -1
  50. package/dist/src/commands/extensions/validate.test.js +3 -0
  51. package/dist/src/commands/extensions/validate.test.js.map +1 -1
  52. package/dist/src/commands/extensions.js +2 -0
  53. package/dist/src/commands/extensions.js.map +1 -1
  54. package/dist/src/commands/extensions.test.d.ts +6 -0
  55. package/dist/src/commands/extensions.test.js +67 -0
  56. package/dist/src/commands/extensions.test.js.map +1 -0
  57. package/dist/src/commands/mcp/add.js +2 -0
  58. package/dist/src/commands/mcp/add.js.map +1 -1
  59. package/dist/src/commands/mcp/add.test.js +11 -3
  60. package/dist/src/commands/mcp/add.test.js.map +1 -1
  61. package/dist/src/commands/mcp/list.js +2 -0
  62. package/dist/src/commands/mcp/list.js.map +1 -1
  63. package/dist/src/commands/mcp/list.test.js +4 -6
  64. package/dist/src/commands/mcp/list.test.js.map +1 -1
  65. package/dist/src/commands/mcp/remove.js +2 -0
  66. package/dist/src/commands/mcp/remove.js.map +1 -1
  67. package/dist/src/commands/mcp/remove.test.js +26 -12
  68. package/dist/src/commands/mcp/remove.test.js.map +1 -1
  69. package/dist/src/commands/mcp.js +2 -0
  70. package/dist/src/commands/mcp.js.map +1 -1
  71. package/dist/src/commands/mcp.test.js +1 -0
  72. package/dist/src/commands/mcp.test.js.map +1 -1
  73. package/dist/src/commands/utils.d.ts +6 -0
  74. package/dist/src/commands/utils.js +11 -0
  75. package/dist/src/commands/utils.js.map +1 -0
  76. package/dist/src/commands/utils.test.d.ts +6 -0
  77. package/dist/src/commands/utils.test.js +35 -0
  78. package/dist/src/commands/utils.test.js.map +1 -0
  79. package/dist/src/config/auth.js +4 -0
  80. package/dist/src/config/auth.js.map +1 -1
  81. package/dist/src/config/auth.test.js +1 -2
  82. package/dist/src/config/auth.test.js.map +1 -1
  83. package/dist/src/config/config.d.ts +2 -1
  84. package/dist/src/config/config.integration.test.js +81 -198
  85. package/dist/src/config/config.integration.test.js.map +1 -1
  86. package/dist/src/config/config.js +38 -31
  87. package/dist/src/config/config.js.map +1 -1
  88. package/dist/src/config/config.test.js +235 -294
  89. package/dist/src/config/config.test.js.map +1 -1
  90. package/dist/src/config/extension.test.js +30 -48
  91. package/dist/src/config/extension.test.js.map +1 -1
  92. package/dist/src/config/extensions/consent.test.d.ts +6 -0
  93. package/dist/src/config/extensions/consent.test.js +152 -0
  94. package/dist/src/config/extensions/consent.test.js.map +1 -0
  95. package/dist/src/config/extensions/extensionEnablement.test.js +82 -15
  96. package/dist/src/config/extensions/extensionEnablement.test.js.map +1 -1
  97. package/dist/src/config/extensions/extensionSettings.test.js +105 -1
  98. package/dist/src/config/extensions/extensionSettings.test.js.map +1 -1
  99. package/dist/src/config/extensions/github.d.ts +1 -0
  100. package/dist/src/config/extensions/github.js +21 -5
  101. package/dist/src/config/extensions/github.js.map +1 -1
  102. package/dist/src/config/extensions/github.test.js +201 -318
  103. package/dist/src/config/extensions/github.test.js.map +1 -1
  104. package/dist/src/config/extensions/storage.test.d.ts +6 -0
  105. package/dist/src/config/extensions/storage.test.js +64 -0
  106. package/dist/src/config/extensions/storage.test.js.map +1 -0
  107. package/dist/src/config/extensions/update.test.js +154 -263
  108. package/dist/src/config/extensions/update.test.js.map +1 -1
  109. package/dist/src/config/extensions/variables.test.js +87 -1
  110. package/dist/src/config/extensions/variables.test.js.map +1 -1
  111. package/dist/src/config/keyBindings.d.ts +1 -1
  112. package/dist/src/config/keyBindings.js +4 -4
  113. package/dist/src/config/keyBindings.js.map +1 -1
  114. package/dist/src/config/sandboxConfig.d.ts +1 -1
  115. package/dist/src/config/sandboxConfig.js.map +1 -1
  116. package/dist/src/config/sandboxConfig.test.d.ts +6 -0
  117. package/dist/src/config/sandboxConfig.test.js +178 -0
  118. package/dist/src/config/sandboxConfig.test.js.map +1 -0
  119. package/dist/src/config/settingPaths.test.d.ts +6 -0
  120. package/dist/src/config/settingPaths.test.js +22 -0
  121. package/dist/src/config/settingPaths.test.js.map +1 -0
  122. package/dist/src/config/settings.js +12 -1
  123. package/dist/src/config/settings.js.map +1 -1
  124. package/dist/src/config/settings.test.js +228 -227
  125. package/dist/src/config/settings.test.js.map +1 -1
  126. package/dist/src/config/settingsSchema.d.ts +25 -7
  127. package/dist/src/config/settingsSchema.js +26 -8
  128. package/dist/src/config/settingsSchema.js.map +1 -1
  129. package/dist/src/config/settingsSchema.test.js +11 -6
  130. package/dist/src/config/settingsSchema.test.js.map +1 -1
  131. package/dist/src/config/trustedFolders.d.ts +1 -1
  132. package/dist/src/config/trustedFolders.js +24 -17
  133. package/dist/src/config/trustedFolders.js.map +1 -1
  134. package/dist/src/core/auth.test.d.ts +6 -0
  135. package/dist/src/core/auth.test.js +43 -0
  136. package/dist/src/core/auth.test.js.map +1 -0
  137. package/dist/src/core/initializer.test.d.ts +6 -0
  138. package/dist/src/core/initializer.test.js +101 -0
  139. package/dist/src/core/initializer.test.js.map +1 -0
  140. package/dist/src/core/theme.test.d.ts +6 -0
  141. package/dist/src/core/theme.test.js +46 -0
  142. package/dist/src/core/theme.test.js.map +1 -0
  143. package/dist/src/gemini.d.ts +3 -1
  144. package/dist/src/gemini.js +80 -17
  145. package/dist/src/gemini.js.map +1 -1
  146. package/dist/src/gemini.test.js +681 -16
  147. package/dist/src/gemini.test.js.map +1 -1
  148. package/dist/src/gemini_cleanup.test.d.ts +6 -0
  149. package/dist/src/gemini_cleanup.test.js +201 -0
  150. package/dist/src/gemini_cleanup.test.js.map +1 -0
  151. package/dist/src/generated/git-commit.d.ts +2 -2
  152. package/dist/src/generated/git-commit.js +2 -2
  153. package/dist/src/nonInteractiveCli.js +4 -1
  154. package/dist/src/nonInteractiveCli.js.map +1 -1
  155. package/dist/src/nonInteractiveCli.test.js +338 -2
  156. package/dist/src/nonInteractiveCli.test.js.map +1 -1
  157. package/dist/src/services/BuiltinCommandLoader.js +3 -1
  158. package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
  159. package/dist/src/services/BuiltinCommandLoader.test.js +1 -22
  160. package/dist/src/services/BuiltinCommandLoader.test.js.map +1 -1
  161. package/dist/src/services/CommandService.test.js +3 -2
  162. package/dist/src/services/CommandService.test.js.map +1 -1
  163. package/dist/src/services/McpPromptLoader.js +5 -3
  164. package/dist/src/services/McpPromptLoader.js.map +1 -1
  165. package/dist/src/services/McpPromptLoader.test.js +29 -1
  166. package/dist/src/services/McpPromptLoader.test.js.map +1 -1
  167. package/dist/src/test-utils/mockCommandContext.js +1 -1
  168. package/dist/src/test-utils/render.d.ts +26 -2
  169. package/dist/src/test-utils/render.js +80 -3
  170. package/dist/src/test-utils/render.js.map +1 -1
  171. package/dist/src/ui/App.test.js +28 -14
  172. package/dist/src/ui/App.test.js.map +1 -1
  173. package/dist/src/ui/AppContainer.js +142 -48
  174. package/dist/src/ui/AppContainer.js.map +1 -1
  175. package/dist/src/ui/AppContainer.test.js +181 -103
  176. package/dist/src/ui/AppContainer.test.js.map +1 -1
  177. package/dist/src/ui/IdeIntegrationNudge.test.d.ts +6 -0
  178. package/dist/src/ui/IdeIntegrationNudge.test.js +147 -0
  179. package/dist/src/ui/IdeIntegrationNudge.test.js.map +1 -0
  180. package/dist/src/ui/auth/ApiAuthDialog.test.js +12 -17
  181. package/dist/src/ui/auth/ApiAuthDialog.test.js.map +1 -1
  182. package/dist/src/ui/auth/AuthDialog.js +17 -10
  183. package/dist/src/ui/auth/AuthDialog.js.map +1 -1
  184. package/dist/src/ui/auth/AuthDialog.test.js +55 -21
  185. package/dist/src/ui/auth/AuthDialog.test.js.map +1 -1
  186. package/dist/src/ui/auth/AuthInProgress.test.d.ts +6 -0
  187. package/dist/src/ui/auth/AuthInProgress.test.js +71 -0
  188. package/dist/src/ui/auth/AuthInProgress.test.js.map +1 -0
  189. package/dist/src/ui/auth/useAuth.d.ts +2 -0
  190. package/dist/src/ui/auth/useAuth.js +6 -1
  191. package/dist/src/ui/auth/useAuth.js.map +1 -1
  192. package/dist/src/ui/auth/useAuth.test.d.ts +6 -0
  193. package/dist/src/ui/auth/useAuth.test.js +178 -0
  194. package/dist/src/ui/auth/useAuth.test.js.map +1 -0
  195. package/dist/src/ui/commands/aboutCommand.js +8 -1
  196. package/dist/src/ui/commands/aboutCommand.js.map +1 -1
  197. package/dist/src/ui/commands/aboutCommand.test.js +4 -0
  198. package/dist/src/ui/commands/aboutCommand.test.js.map +1 -1
  199. package/dist/src/ui/commands/clearCommand.js +12 -0
  200. package/dist/src/ui/commands/clearCommand.js.map +1 -1
  201. package/dist/src/ui/commands/clearCommand.test.js +5 -0
  202. package/dist/src/ui/commands/clearCommand.test.js.map +1 -1
  203. package/dist/src/ui/commands/directoryCommand.d.ts +0 -1
  204. package/dist/src/ui/commands/directoryCommand.js +104 -43
  205. package/dist/src/ui/commands/directoryCommand.js.map +1 -1
  206. package/dist/src/ui/commands/directoryCommand.test.js +91 -2
  207. package/dist/src/ui/commands/directoryCommand.test.js.map +1 -1
  208. package/dist/src/ui/commands/extensionsCommand.js +28 -6
  209. package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
  210. package/dist/src/ui/commands/extensionsCommand.test.js +32 -0
  211. package/dist/src/ui/commands/extensionsCommand.test.js.map +1 -1
  212. package/dist/src/ui/commands/memoryCommand.js +1 -0
  213. package/dist/src/ui/commands/memoryCommand.js.map +1 -1
  214. package/dist/src/ui/commands/memoryCommand.test.js +3 -0
  215. package/dist/src/ui/commands/memoryCommand.test.js.map +1 -1
  216. package/dist/src/ui/commands/permissionsCommand.js +62 -5
  217. package/dist/src/ui/commands/permissionsCommand.js.map +1 -1
  218. package/dist/src/ui/commands/permissionsCommand.test.js +60 -4
  219. package/dist/src/ui/commands/permissionsCommand.test.js.map +1 -1
  220. package/dist/src/ui/commands/resumeCommand.d.ts +7 -0
  221. package/dist/src/ui/commands/resumeCommand.js +16 -0
  222. package/dist/src/ui/commands/resumeCommand.js.map +1 -0
  223. package/dist/src/ui/commands/setupGithubCommand.d.ts +1 -0
  224. package/dist/src/ui/commands/setupGithubCommand.js +82 -45
  225. package/dist/src/ui/commands/setupGithubCommand.js.map +1 -1
  226. package/dist/src/ui/commands/setupGithubCommand.test.js +35 -5
  227. package/dist/src/ui/commands/setupGithubCommand.test.js.map +1 -1
  228. package/dist/src/ui/commands/statsCommand.js +27 -16
  229. package/dist/src/ui/commands/statsCommand.js.map +1 -1
  230. package/dist/src/ui/commands/types.d.ts +8 -2
  231. package/dist/src/ui/commands/types.js.map +1 -1
  232. package/dist/src/ui/components/AboutBox.d.ts +1 -0
  233. package/dist/src/ui/components/AboutBox.js +1 -1
  234. package/dist/src/ui/components/AboutBox.js.map +1 -1
  235. package/dist/src/ui/components/AboutBox.test.d.ts +6 -0
  236. package/dist/src/ui/components/AboutBox.test.js +53 -0
  237. package/dist/src/ui/components/AboutBox.test.js.map +1 -0
  238. package/dist/src/ui/components/AlternateBufferQuittingDisplay.test.js +62 -11
  239. package/dist/src/ui/components/AlternateBufferQuittingDisplay.test.js.map +1 -1
  240. package/dist/src/ui/components/AnsiOutput.test.js +18 -23
  241. package/dist/src/ui/components/AnsiOutput.test.js.map +1 -1
  242. package/dist/src/ui/components/AppHeader.js +3 -22
  243. package/dist/src/ui/components/AppHeader.js.map +1 -1
  244. package/dist/src/ui/components/AppHeader.test.js +10 -4
  245. package/dist/src/ui/components/AppHeader.test.js.map +1 -1
  246. package/dist/src/ui/components/AsciiArt.d.ts +6 -6
  247. package/dist/src/ui/components/AsciiArt.js +6 -6
  248. package/dist/src/ui/components/AutoAcceptIndicator.test.d.ts +6 -0
  249. package/dist/src/ui/components/AutoAcceptIndicator.test.js +31 -0
  250. package/dist/src/ui/components/AutoAcceptIndicator.test.js.map +1 -0
  251. package/dist/src/ui/components/Banner.d.ts +4 -2
  252. package/dist/src/ui/components/Banner.js +18 -4
  253. package/dist/src/ui/components/Banner.js.map +1 -1
  254. package/dist/src/ui/components/Banner.test.d.ts +6 -0
  255. package/dist/src/ui/components/Banner.test.js +24 -0
  256. package/dist/src/ui/components/Banner.test.js.map +1 -0
  257. package/dist/src/ui/components/ConfigInitDisplay.test.d.ts +6 -0
  258. package/dist/src/ui/components/ConfigInitDisplay.test.js +103 -0
  259. package/dist/src/ui/components/ConfigInitDisplay.test.js.map +1 -0
  260. package/dist/src/ui/components/ConsoleSummaryDisplay.test.d.ts +6 -0
  261. package/dist/src/ui/components/ConsoleSummaryDisplay.test.js +26 -0
  262. package/dist/src/ui/components/ConsoleSummaryDisplay.test.js.map +1 -0
  263. package/dist/src/ui/components/ContextUsageDisplay.test.d.ts +6 -0
  264. package/dist/src/ui/components/ContextUsageDisplay.test.js +39 -0
  265. package/dist/src/ui/components/ContextUsageDisplay.test.js.map +1 -0
  266. package/dist/src/ui/components/CopyModeWarning.test.d.ts +6 -0
  267. package/dist/src/ui/components/CopyModeWarning.test.js +33 -0
  268. package/dist/src/ui/components/CopyModeWarning.test.js.map +1 -0
  269. package/dist/src/ui/components/DebugProfiler.d.ts +1 -0
  270. package/dist/src/ui/components/DebugProfiler.js +24 -35
  271. package/dist/src/ui/components/DebugProfiler.js.map +1 -1
  272. package/dist/src/ui/components/DebugProfiler.test.js +47 -1
  273. package/dist/src/ui/components/DebugProfiler.test.js.map +1 -1
  274. package/dist/src/ui/components/DetailedMessagesDisplay.test.d.ts +6 -0
  275. package/dist/src/ui/components/DetailedMessagesDisplay.test.js +49 -0
  276. package/dist/src/ui/components/DetailedMessagesDisplay.test.js.map +1 -0
  277. package/dist/src/ui/components/DialogManager.js +11 -2
  278. package/dist/src/ui/components/DialogManager.js.map +1 -1
  279. package/dist/src/ui/components/DialogManager.test.d.ts +6 -0
  280. package/dist/src/ui/components/DialogManager.test.js +167 -0
  281. package/dist/src/ui/components/DialogManager.test.js.map +1 -0
  282. package/dist/src/ui/components/EditorSettingsDialog.test.d.ts +6 -0
  283. package/dist/src/ui/components/EditorSettingsDialog.test.js +111 -0
  284. package/dist/src/ui/components/EditorSettingsDialog.test.js.map +1 -0
  285. package/dist/src/ui/components/ExitWarning.test.d.ts +6 -0
  286. package/dist/src/ui/components/ExitWarning.test.js +54 -0
  287. package/dist/src/ui/components/ExitWarning.test.js.map +1 -0
  288. package/dist/src/ui/components/GeminiRespondingSpinner.test.d.ts +6 -0
  289. package/dist/src/ui/components/GeminiRespondingSpinner.test.js +58 -0
  290. package/dist/src/ui/components/GeminiRespondingSpinner.test.js.map +1 -0
  291. package/dist/src/ui/components/GradientRegression.test.js +22 -1
  292. package/dist/src/ui/components/GradientRegression.test.js.map +1 -1
  293. package/dist/src/ui/components/Header.test.js +27 -2
  294. package/dist/src/ui/components/Header.test.js.map +1 -1
  295. package/dist/src/ui/components/HistoryItemDisplay.js +2 -1
  296. package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
  297. package/dist/src/ui/components/InputPrompt.js +30 -36
  298. package/dist/src/ui/components/InputPrompt.js.map +1 -1
  299. package/dist/src/ui/components/InputPrompt.test.js +110 -24
  300. package/dist/src/ui/components/InputPrompt.test.js.map +1 -1
  301. package/dist/src/ui/components/LoadingIndicator.js +6 -1
  302. package/dist/src/ui/components/LoadingIndicator.js.map +1 -1
  303. package/dist/src/ui/components/MainContent.test.d.ts +6 -0
  304. package/dist/src/ui/components/MainContent.test.js +73 -0
  305. package/dist/src/ui/components/MainContent.test.js.map +1 -0
  306. package/dist/src/ui/components/MemoryUsageDisplay.test.d.ts +6 -0
  307. package/dist/src/ui/components/MemoryUsageDisplay.test.js +49 -0
  308. package/dist/src/ui/components/MemoryUsageDisplay.test.js.map +1 -0
  309. package/dist/src/ui/components/ModelDialog.js +2 -2
  310. package/dist/src/ui/components/ModelDialog.js.map +1 -1
  311. package/dist/src/ui/components/ModelDialog.test.js +1 -1
  312. package/dist/src/ui/components/ModelDialog.test.js.map +1 -1
  313. package/dist/src/ui/components/MultiFolderTrustDialog.d.ts +23 -0
  314. package/dist/src/ui/components/MultiFolderTrustDialog.js +90 -0
  315. package/dist/src/ui/components/MultiFolderTrustDialog.js.map +1 -0
  316. package/dist/src/ui/components/MultiFolderTrustDialog.test.d.ts +6 -0
  317. package/dist/src/ui/components/MultiFolderTrustDialog.test.js +161 -0
  318. package/dist/src/ui/components/MultiFolderTrustDialog.test.js.map +1 -0
  319. package/dist/src/ui/components/Notifications.js +5 -3
  320. package/dist/src/ui/components/Notifications.js.map +1 -1
  321. package/dist/src/ui/components/Notifications.test.d.ts +6 -0
  322. package/dist/src/ui/components/Notifications.test.js +153 -0
  323. package/dist/src/ui/components/Notifications.test.js.map +1 -0
  324. package/dist/src/ui/components/PermissionsModifyTrustDialog.d.ts +5 -2
  325. package/dist/src/ui/components/PermissionsModifyTrustDialog.js +12 -7
  326. package/dist/src/ui/components/PermissionsModifyTrustDialog.js.map +1 -1
  327. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js +2 -2
  328. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js.map +1 -1
  329. package/dist/src/ui/components/ProQuotaDialog.js +2 -2
  330. package/dist/src/ui/components/ProQuotaDialog.js.map +1 -1
  331. package/dist/src/ui/components/QuittingDisplay.test.d.ts +6 -0
  332. package/dist/src/ui/components/QuittingDisplay.test.js +49 -0
  333. package/dist/src/ui/components/QuittingDisplay.test.js.map +1 -0
  334. package/dist/src/ui/components/RawMarkdownIndicator.test.d.ts +6 -0
  335. package/dist/src/ui/components/RawMarkdownIndicator.test.js +34 -0
  336. package/dist/src/ui/components/RawMarkdownIndicator.test.js.map +1 -0
  337. package/dist/src/ui/components/SessionBrowser.d.ts +98 -0
  338. package/dist/src/ui/components/SessionBrowser.js +457 -0
  339. package/dist/src/ui/components/SessionBrowser.js.map +1 -0
  340. package/dist/src/ui/components/SessionBrowser.test.d.ts +6 -0
  341. package/dist/src/ui/components/SessionBrowser.test.js +250 -0
  342. package/dist/src/ui/components/SessionBrowser.test.js.map +1 -0
  343. package/dist/src/ui/components/SettingsDialog.d.ts +3 -1
  344. package/dist/src/ui/components/SettingsDialog.js +4 -1
  345. package/dist/src/ui/components/SettingsDialog.js.map +1 -1
  346. package/dist/src/ui/components/ShellInputPrompt.test.d.ts +6 -0
  347. package/dist/src/ui/components/ShellInputPrompt.test.js +82 -0
  348. package/dist/src/ui/components/ShellInputPrompt.test.js.map +1 -0
  349. package/dist/src/ui/components/ShellModeIndicator.test.d.ts +6 -0
  350. package/dist/src/ui/components/ShellModeIndicator.test.js +17 -0
  351. package/dist/src/ui/components/ShellModeIndicator.test.js.map +1 -0
  352. package/dist/src/ui/components/ShowMoreLines.test.d.ts +6 -0
  353. package/dist/src/ui/components/ShowMoreLines.test.js +40 -0
  354. package/dist/src/ui/components/ShowMoreLines.test.js.map +1 -0
  355. package/dist/src/ui/components/SuggestionsDisplay.test.d.ts +6 -0
  356. package/dist/src/ui/components/SuggestionsDisplay.test.js +56 -0
  357. package/dist/src/ui/components/SuggestionsDisplay.test.js.map +1 -0
  358. package/dist/src/ui/components/ThemeDialog.js +6 -2
  359. package/dist/src/ui/components/ThemeDialog.js.map +1 -1
  360. package/dist/src/ui/components/ThemeDialog.test.js +20 -6
  361. package/dist/src/ui/components/ThemeDialog.test.js.map +1 -1
  362. package/dist/src/ui/components/ThemedGradient.js +2 -1
  363. package/dist/src/ui/components/ThemedGradient.js.map +1 -1
  364. package/dist/src/ui/components/ThemedGradient.test.d.ts +6 -0
  365. package/dist/src/ui/components/ThemedGradient.test.js +30 -0
  366. package/dist/src/ui/components/ThemedGradient.test.js.map +1 -0
  367. package/dist/src/ui/components/Tips.test.d.ts +6 -0
  368. package/dist/src/ui/components/Tips.test.js +23 -0
  369. package/dist/src/ui/components/Tips.test.js.map +1 -0
  370. package/dist/src/ui/components/UpdateNotification.test.d.ts +6 -0
  371. package/dist/src/ui/components/UpdateNotification.test.js +16 -0
  372. package/dist/src/ui/components/UpdateNotification.test.js.map +1 -0
  373. package/dist/src/ui/components/messages/ErrorMessage.test.d.ts +6 -0
  374. package/dist/src/ui/components/messages/ErrorMessage.test.js +23 -0
  375. package/dist/src/ui/components/messages/ErrorMessage.test.js.map +1 -0
  376. package/dist/src/ui/components/messages/InfoMessage.test.d.ts +6 -0
  377. package/dist/src/ui/components/messages/InfoMessage.test.js +28 -0
  378. package/dist/src/ui/components/messages/InfoMessage.test.js.map +1 -0
  379. package/dist/src/ui/components/messages/ModelMessage.d.ts +11 -0
  380. package/dist/src/ui/components/messages/ModelMessage.js +5 -0
  381. package/dist/src/ui/components/messages/ModelMessage.js.map +1 -0
  382. package/dist/src/ui/components/messages/ShellToolMessage.d.ts +14 -0
  383. package/dist/src/ui/components/messages/ShellToolMessage.js +76 -0
  384. package/dist/src/ui/components/messages/ShellToolMessage.js.map +1 -0
  385. package/dist/src/ui/components/messages/ShellToolMessage.test.d.ts +6 -0
  386. package/dist/src/ui/components/messages/ShellToolMessage.test.js +123 -0
  387. package/dist/src/ui/components/messages/ShellToolMessage.test.js.map +1 -0
  388. package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js +5 -6
  389. package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js.map +1 -1
  390. package/dist/src/ui/components/messages/ToolGroupMessage.js +19 -1
  391. package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
  392. package/dist/src/ui/components/messages/ToolMessage.d.ts +6 -4
  393. package/dist/src/ui/components/messages/ToolMessage.js +15 -102
  394. package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
  395. package/dist/src/ui/components/messages/ToolMessage.test.js +26 -26
  396. package/dist/src/ui/components/messages/ToolMessage.test.js.map +1 -1
  397. package/dist/src/ui/components/messages/ToolResultDisplay.d.ts +13 -0
  398. package/dist/src/ui/components/messages/ToolResultDisplay.js +54 -0
  399. package/dist/src/ui/components/messages/ToolResultDisplay.js.map +1 -0
  400. package/dist/src/ui/components/messages/ToolResultDisplay.test.d.ts +6 -0
  401. package/dist/src/ui/components/messages/ToolResultDisplay.test.js +96 -0
  402. package/dist/src/ui/components/messages/ToolResultDisplay.test.js.map +1 -0
  403. package/dist/src/ui/components/messages/ToolShared.d.ts +23 -0
  404. package/dist/src/ui/components/messages/ToolShared.js +40 -0
  405. package/dist/src/ui/components/messages/ToolShared.js.map +1 -0
  406. package/dist/src/ui/components/messages/UserMessage.test.d.ts +6 -0
  407. package/dist/src/ui/components/messages/UserMessage.test.js +32 -0
  408. package/dist/src/ui/components/messages/UserMessage.test.js.map +1 -0
  409. package/dist/src/ui/components/messages/WarningMessage.test.d.ts +6 -0
  410. package/dist/src/ui/components/messages/WarningMessage.test.js +23 -0
  411. package/dist/src/ui/components/messages/WarningMessage.test.js.map +1 -0
  412. package/dist/src/ui/components/shared/text-buffer.d.ts +1 -0
  413. package/dist/src/ui/components/shared/text-buffer.js +27 -5
  414. package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
  415. package/dist/src/ui/components/shared/text-buffer.test.js +20 -0
  416. package/dist/src/ui/components/shared/text-buffer.test.js.map +1 -1
  417. package/dist/src/ui/constants/tips.d.ts +6 -0
  418. package/dist/src/ui/constants/tips.js +168 -0
  419. package/dist/src/ui/constants/tips.js.map +1 -0
  420. package/dist/src/ui/constants/wittyPhrases.d.ts +6 -0
  421. package/dist/src/ui/constants/wittyPhrases.js +137 -0
  422. package/dist/src/ui/constants/wittyPhrases.js.map +1 -0
  423. package/dist/src/ui/constants.d.ts +1 -0
  424. package/dist/src/ui/constants.js +1 -0
  425. package/dist/src/ui/constants.js.map +1 -1
  426. package/dist/src/ui/contexts/KeypressContext.js +21 -11
  427. package/dist/src/ui/contexts/KeypressContext.js.map +1 -1
  428. package/dist/src/ui/contexts/KeypressContext.test.js +29 -10
  429. package/dist/src/ui/contexts/KeypressContext.test.js.map +1 -1
  430. package/dist/src/ui/contexts/UIActionsContext.d.ts +8 -0
  431. package/dist/src/ui/contexts/UIActionsContext.js +1 -0
  432. package/dist/src/ui/contexts/UIActionsContext.js.map +1 -1
  433. package/dist/src/ui/contexts/UIStateContext.d.ts +5 -0
  434. package/dist/src/ui/contexts/UIStateContext.js.map +1 -1
  435. package/dist/src/ui/hooks/shellCommandProcessor.d.ts +1 -0
  436. package/dist/src/ui/hooks/shellCommandProcessor.js +11 -5
  437. package/dist/src/ui/hooks/shellCommandProcessor.js.map +1 -1
  438. package/dist/src/ui/hooks/shellCommandProcessor.test.js +4 -3
  439. package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +1 -1
  440. package/dist/src/ui/hooks/slashCommandProcessor.d.ts +6 -3
  441. package/dist/src/ui/hooks/slashCommandProcessor.js +17 -5
  442. package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
  443. package/dist/src/ui/hooks/slashCommandProcessor.test.js +2 -0
  444. package/dist/src/ui/hooks/slashCommandProcessor.test.js.map +1 -1
  445. package/dist/src/ui/hooks/useAlternateBuffer.js +1 -1
  446. package/dist/src/ui/hooks/useAlternateBuffer.js.map +1 -1
  447. package/dist/src/ui/hooks/useBanner.d.ts +14 -0
  448. package/dist/src/ui/hooks/useBanner.js +48 -0
  449. package/dist/src/ui/hooks/useBanner.js.map +1 -0
  450. package/dist/src/ui/hooks/useBanner.test.d.ts +6 -0
  451. package/dist/src/ui/hooks/useBanner.test.js +92 -0
  452. package/dist/src/ui/hooks/useBanner.test.js.map +1 -0
  453. package/dist/src/ui/hooks/useBracketedPaste.js +3 -4
  454. package/dist/src/ui/hooks/useBracketedPaste.js.map +1 -1
  455. package/dist/src/ui/hooks/useCommandCompletion.test.js +5 -5
  456. package/dist/src/ui/hooks/useCommandCompletion.test.js.map +1 -1
  457. package/dist/src/ui/hooks/useConsoleMessages.d.ts +0 -1
  458. package/dist/src/ui/hooks/useConsoleMessages.js +26 -1
  459. package/dist/src/ui/hooks/useConsoleMessages.js.map +1 -1
  460. package/dist/src/ui/hooks/useConsoleMessages.test.js +37 -5
  461. package/dist/src/ui/hooks/useConsoleMessages.test.js.map +1 -1
  462. package/dist/src/ui/hooks/useEditorSettings.d.ts +2 -2
  463. package/dist/src/ui/hooks/useEditorSettings.js.map +1 -1
  464. package/dist/src/ui/hooks/useEditorSettings.test.js.map +1 -1
  465. package/dist/src/ui/hooks/useFolderTrust.js +11 -1
  466. package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
  467. package/dist/src/ui/hooks/useFolderTrust.test.js +22 -0
  468. package/dist/src/ui/hooks/useFolderTrust.test.js.map +1 -1
  469. package/dist/src/ui/hooks/useGeminiStream.d.ts +2 -1
  470. package/dist/src/ui/hooks/useGeminiStream.js +69 -12
  471. package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
  472. package/dist/src/ui/hooks/useGeminiStream.test.js +21 -22
  473. package/dist/src/ui/hooks/useGeminiStream.test.js.map +1 -1
  474. package/dist/src/ui/hooks/useHistoryManager.d.ts +5 -2
  475. package/dist/src/ui/hooks/useHistoryManager.js +39 -3
  476. package/dist/src/ui/hooks/useHistoryManager.js.map +1 -1
  477. package/dist/src/ui/hooks/useInactivityTimer.d.ts +14 -0
  478. package/dist/src/ui/hooks/useInactivityTimer.js +30 -0
  479. package/dist/src/ui/hooks/useInactivityTimer.js.map +1 -0
  480. package/dist/src/ui/hooks/useIncludeDirsTrust.d.ts +8 -0
  481. package/dist/src/ui/hooks/useIncludeDirsTrust.js +119 -0
  482. package/dist/src/ui/hooks/useIncludeDirsTrust.js.map +1 -0
  483. package/dist/src/ui/hooks/useIncludeDirsTrust.test.d.ts +6 -0
  484. package/dist/src/ui/hooks/useIncludeDirsTrust.test.js +151 -0
  485. package/dist/src/ui/hooks/useIncludeDirsTrust.test.js.map +1 -0
  486. package/dist/src/ui/hooks/useInputHistoryStore.test.js +4 -1
  487. package/dist/src/ui/hooks/useInputHistoryStore.test.js.map +1 -1
  488. package/dist/src/ui/hooks/useKittyKeyboardProtocol.d.ts +0 -1
  489. package/dist/src/ui/hooks/useKittyKeyboardProtocol.js +1 -2
  490. package/dist/src/ui/hooks/useKittyKeyboardProtocol.js.map +1 -1
  491. package/dist/src/ui/hooks/useLoadingIndicator.d.ts +1 -1
  492. package/dist/src/ui/hooks/useLoadingIndicator.js +2 -2
  493. package/dist/src/ui/hooks/useLoadingIndicator.js.map +1 -1
  494. package/dist/src/ui/hooks/useLoadingIndicator.test.js +21 -9
  495. package/dist/src/ui/hooks/useLoadingIndicator.test.js.map +1 -1
  496. package/dist/src/ui/hooks/useMouseClick.d.ts +12 -0
  497. package/dist/src/ui/hooks/useMouseClick.js +28 -0
  498. package/dist/src/ui/hooks/useMouseClick.js.map +1 -0
  499. package/dist/src/ui/hooks/useMouseClick.test.d.ts +6 -0
  500. package/dist/src/ui/hooks/useMouseClick.test.js +59 -0
  501. package/dist/src/ui/hooks/useMouseClick.test.js.map +1 -0
  502. package/dist/src/ui/hooks/usePermissionsModifyTrust.d.ts +2 -2
  503. package/dist/src/ui/hooks/usePermissionsModifyTrust.js +44 -7
  504. package/dist/src/ui/hooks/usePermissionsModifyTrust.js.map +1 -1
  505. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.js +191 -89
  506. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.js.map +1 -1
  507. package/dist/src/ui/hooks/usePhraseCycler.d.ts +4 -3
  508. package/dist/src/ui/hooks/usePhraseCycler.js +54 -305
  509. package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
  510. package/dist/src/ui/hooks/usePhraseCycler.test.js +109 -30
  511. package/dist/src/ui/hooks/usePhraseCycler.test.js.map +1 -1
  512. package/dist/src/ui/hooks/useQuotaAndFallback.js +9 -3
  513. package/dist/src/ui/hooks/useQuotaAndFallback.js.map +1 -1
  514. package/dist/src/ui/hooks/useQuotaAndFallback.test.js +25 -3
  515. package/dist/src/ui/hooks/useQuotaAndFallback.test.js.map +1 -1
  516. package/dist/src/ui/hooks/useReactToolScheduler.d.ts +3 -2
  517. package/dist/src/ui/hooks/useReactToolScheduler.js +4 -8
  518. package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
  519. package/dist/src/ui/hooks/useReactToolScheduler.test.js +1 -8
  520. package/dist/src/ui/hooks/useReactToolScheduler.test.js.map +1 -1
  521. package/dist/src/ui/hooks/useReverseSearchCompletion.test.js +18 -12
  522. package/dist/src/ui/hooks/useReverseSearchCompletion.test.js.map +1 -1
  523. package/dist/src/ui/hooks/useSessionBrowser.d.ts +18 -1
  524. package/dist/src/ui/hooks/useSessionBrowser.js +76 -4
  525. package/dist/src/ui/hooks/useSessionBrowser.js.map +1 -1
  526. package/dist/src/ui/hooks/useSessionBrowser.test.js +154 -489
  527. package/dist/src/ui/hooks/useSessionBrowser.test.js.map +1 -1
  528. package/dist/src/ui/hooks/useSessionResume.js +1 -1
  529. package/dist/src/ui/hooks/useSessionResume.js.map +1 -1
  530. package/dist/src/ui/hooks/useSessionResume.test.js +4 -4
  531. package/dist/src/ui/hooks/useSessionResume.test.js.map +1 -1
  532. package/dist/src/ui/hooks/useSlashCompletion.test.js +5 -5
  533. package/dist/src/ui/hooks/useSlashCompletion.test.js.map +1 -1
  534. package/dist/src/ui/hooks/useThemeCommand.d.ts +2 -2
  535. package/dist/src/ui/hooks/useThemeCommand.js.map +1 -1
  536. package/dist/src/ui/hooks/useToolScheduler.test.js +8 -4
  537. package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
  538. package/dist/src/ui/keyMatchers.test.js +2 -2
  539. package/dist/src/ui/keyMatchers.test.js.map +1 -1
  540. package/dist/src/ui/layouts/DefaultAppLayout.js +1 -1
  541. package/dist/src/ui/layouts/DefaultAppLayout.js.map +1 -1
  542. package/dist/src/ui/noninteractive/nonInteractiveUi.js +1 -0
  543. package/dist/src/ui/noninteractive/nonInteractiveUi.js.map +1 -1
  544. package/dist/src/ui/privacy/CloudFreePrivacyNotice.test.d.ts +6 -0
  545. package/dist/src/ui/privacy/CloudFreePrivacyNotice.test.js +121 -0
  546. package/dist/src/ui/privacy/CloudFreePrivacyNotice.test.js.map +1 -0
  547. package/dist/src/ui/privacy/CloudPaidPrivacyNotice.test.d.ts +6 -0
  548. package/dist/src/ui/privacy/CloudPaidPrivacyNotice.test.js +34 -0
  549. package/dist/src/ui/privacy/CloudPaidPrivacyNotice.test.js.map +1 -0
  550. package/dist/src/ui/privacy/GeminiPrivacyNotice.test.d.ts +6 -0
  551. package/dist/src/ui/privacy/GeminiPrivacyNotice.test.js +34 -0
  552. package/dist/src/ui/privacy/GeminiPrivacyNotice.test.js.map +1 -0
  553. package/dist/src/ui/privacy/PrivacyNotice.test.d.ts +6 -0
  554. package/dist/src/ui/privacy/PrivacyNotice.test.js +62 -0
  555. package/dist/src/ui/privacy/PrivacyNotice.test.js.map +1 -0
  556. package/dist/src/ui/state/extensions.test.js +208 -51
  557. package/dist/src/ui/state/extensions.test.js.map +1 -1
  558. package/dist/src/ui/themes/holiday.d.ts +7 -0
  559. package/dist/src/ui/themes/holiday.js +162 -0
  560. package/dist/src/ui/themes/holiday.js.map +1 -0
  561. package/dist/src/ui/themes/theme-manager.js +2 -0
  562. package/dist/src/ui/themes/theme-manager.js.map +1 -1
  563. package/dist/src/ui/themes/theme-manager.test.js +2 -1
  564. package/dist/src/ui/themes/theme-manager.test.js.map +1 -1
  565. package/dist/src/ui/types.d.ts +7 -1
  566. package/dist/src/ui/types.js +1 -1
  567. package/dist/src/ui/types.js.map +1 -1
  568. package/dist/src/ui/utils/ConsolePatcher.js +6 -9
  569. package/dist/src/ui/utils/ConsolePatcher.js.map +1 -1
  570. package/dist/src/ui/utils/bracketedPaste.d.ts +7 -0
  571. package/dist/src/ui/utils/bracketedPaste.js +15 -0
  572. package/dist/src/ui/utils/bracketedPaste.js.map +1 -0
  573. package/dist/src/ui/utils/commandUtils.js +3 -86
  574. package/dist/src/ui/utils/commandUtils.js.map +1 -1
  575. package/dist/src/ui/utils/commandUtils.test.js +21 -273
  576. package/dist/src/ui/utils/commandUtils.test.js.map +1 -1
  577. package/dist/src/ui/utils/directoryUtils.d.ts +6 -0
  578. package/dist/src/ui/utils/directoryUtils.js +21 -0
  579. package/dist/src/ui/utils/directoryUtils.js.map +1 -0
  580. package/dist/src/ui/utils/directoryUtils.test.d.ts +6 -0
  581. package/dist/src/ui/utils/directoryUtils.test.js +52 -0
  582. package/dist/src/ui/utils/directoryUtils.test.js.map +1 -0
  583. package/dist/src/ui/utils/kittyProtocolDetector.d.ts +6 -2
  584. package/dist/src/ui/utils/kittyProtocolDetector.js +47 -43
  585. package/dist/src/ui/utils/kittyProtocolDetector.js.map +1 -1
  586. package/dist/src/ui/utils/kittyProtocolDetector.test.d.ts +6 -0
  587. package/dist/src/ui/utils/kittyProtocolDetector.test.js +113 -0
  588. package/dist/src/ui/utils/kittyProtocolDetector.test.js.map +1 -0
  589. package/dist/src/ui/utils/mouse.d.ts +2 -2
  590. package/dist/src/ui/utils/mouse.js +2 -11
  591. package/dist/src/ui/utils/mouse.js.map +1 -1
  592. package/dist/src/ui/utils/terminalSetup.js +39 -38
  593. package/dist/src/ui/utils/terminalSetup.js.map +1 -1
  594. package/dist/src/ui/utils/terminalSetup.test.d.ts +6 -0
  595. package/dist/src/ui/utils/terminalSetup.test.js +132 -0
  596. package/dist/src/ui/utils/terminalSetup.test.js.map +1 -0
  597. package/dist/src/ui/utils/ui-sizing.test.d.ts +6 -0
  598. package/dist/src/ui/utils/ui-sizing.test.js +56 -0
  599. package/dist/src/ui/utils/ui-sizing.test.js.map +1 -0
  600. package/dist/src/utils/checks.test.d.ts +6 -0
  601. package/dist/src/utils/checks.test.js +29 -0
  602. package/dist/src/utils/checks.test.js.map +1 -0
  603. package/dist/src/utils/cleanup.d.ts +2 -0
  604. package/dist/src/utils/cleanup.js +16 -0
  605. package/dist/src/utils/cleanup.js.map +1 -1
  606. package/dist/src/utils/cleanup.test.js +69 -16
  607. package/dist/src/utils/cleanup.test.js.map +1 -1
  608. package/dist/src/utils/dialogScopeUtils.test.d.ts +6 -0
  609. package/dist/src/utils/dialogScopeUtils.test.js +81 -0
  610. package/dist/src/utils/dialogScopeUtils.test.js.map +1 -0
  611. package/dist/src/utils/errors.js +10 -0
  612. package/dist/src/utils/errors.js.map +1 -1
  613. package/dist/src/utils/errors.test.js +62 -0
  614. package/dist/src/utils/errors.test.js.map +1 -1
  615. package/dist/src/utils/events.d.ts +0 -2
  616. package/dist/src/utils/events.js +0 -1
  617. package/dist/src/utils/events.js.map +1 -1
  618. package/dist/src/utils/events.test.d.ts +6 -0
  619. package/dist/src/utils/events.test.js +24 -0
  620. package/dist/src/utils/events.test.js.map +1 -0
  621. package/dist/src/utils/handleAutoUpdate.test.js +103 -24
  622. package/dist/src/utils/handleAutoUpdate.test.js.map +1 -1
  623. package/dist/src/utils/installationInfo.test.js +8 -9
  624. package/dist/src/utils/installationInfo.test.js.map +1 -1
  625. package/dist/src/utils/math.test.d.ts +6 -0
  626. package/dist/src/utils/math.test.js +23 -0
  627. package/dist/src/utils/math.test.js.map +1 -0
  628. package/dist/src/utils/persistentState.d.ts +1 -1
  629. package/dist/src/utils/persistentState.test.d.ts +6 -0
  630. package/dist/src/utils/persistentState.test.js +68 -0
  631. package/dist/src/utils/persistentState.test.js.map +1 -0
  632. package/dist/src/utils/readStdin.js +1 -0
  633. package/dist/src/utils/readStdin.js.map +1 -1
  634. package/dist/src/utils/readStdin.test.js +25 -0
  635. package/dist/src/utils/readStdin.test.js.map +1 -1
  636. package/dist/src/utils/resolvePath.test.d.ts +6 -0
  637. package/dist/src/utils/resolvePath.test.js +31 -0
  638. package/dist/src/utils/resolvePath.test.js.map +1 -0
  639. package/dist/src/utils/sandbox.js +6 -137
  640. package/dist/src/utils/sandbox.js.map +1 -1
  641. package/dist/src/utils/sandbox.test.d.ts +6 -0
  642. package/dist/src/utils/sandbox.test.js +302 -0
  643. package/dist/src/utils/sandbox.test.js.map +1 -0
  644. package/dist/src/utils/sandboxUtils.d.ts +14 -0
  645. package/dist/src/utils/sandboxUtils.js +120 -0
  646. package/dist/src/utils/sandboxUtils.js.map +1 -0
  647. package/dist/src/utils/sandboxUtils.test.d.ts +6 -0
  648. package/dist/src/utils/sandboxUtils.test.js +119 -0
  649. package/dist/src/utils/sandboxUtils.test.js.map +1 -0
  650. package/dist/src/utils/sessionCleanup.test.js +42 -2
  651. package/dist/src/utils/sessionCleanup.test.js.map +1 -1
  652. package/dist/src/utils/sessionUtils.d.ts +54 -4
  653. package/dist/src/utils/sessionUtils.js +106 -26
  654. package/dist/src/utils/sessionUtils.js.map +1 -1
  655. package/dist/src/utils/sessionUtils.test.js +46 -3
  656. package/dist/src/utils/sessionUtils.test.js.map +1 -1
  657. package/dist/src/utils/sessions.js +4 -1
  658. package/dist/src/utils/sessions.js.map +1 -1
  659. package/dist/src/utils/sessions.test.d.ts +6 -0
  660. package/dist/src/utils/sessions.test.js +558 -0
  661. package/dist/src/utils/sessions.test.js.map +1 -0
  662. package/dist/src/utils/updateEventEmitter.test.d.ts +6 -0
  663. package/dist/src/utils/updateEventEmitter.test.js +18 -0
  664. package/dist/src/utils/updateEventEmitter.test.js.map +1 -0
  665. package/dist/src/utils/version.test.d.ts +6 -0
  666. package/dist/src/utils/version.test.js +39 -0
  667. package/dist/src/utils/version.test.js.map +1 -0
  668. package/dist/src/validateNonInterActiveAuth.js +2 -0
  669. package/dist/src/validateNonInterActiveAuth.js.map +1 -1
  670. package/dist/src/zed-integration/acp.d.ts +2 -24
  671. package/dist/src/zed-integration/acp.js +2 -156
  672. package/dist/src/zed-integration/acp.js.map +1 -1
  673. package/dist/src/zed-integration/acp.test.d.ts +6 -0
  674. package/dist/src/zed-integration/acp.test.js +227 -0
  675. package/dist/src/zed-integration/acp.test.js.map +1 -0
  676. package/dist/src/zed-integration/connection.d.ts +28 -0
  677. package/dist/src/zed-integration/connection.js +163 -0
  678. package/dist/src/zed-integration/connection.js.map +1 -0
  679. package/dist/src/zed-integration/connection.test.d.ts +6 -0
  680. package/dist/src/zed-integration/connection.test.js +175 -0
  681. package/dist/src/zed-integration/connection.test.js.map +1 -0
  682. package/dist/src/zed-integration/fileSystemService.test.d.ts +6 -0
  683. package/dist/src/zed-integration/fileSystemService.test.js +98 -0
  684. package/dist/src/zed-integration/fileSystemService.test.js.map +1 -0
  685. package/dist/src/zed-integration/schema.d.ts +69 -13
  686. package/dist/src/zed-integration/schema.js +6 -5
  687. package/dist/src/zed-integration/schema.js.map +1 -1
  688. package/dist/src/zed-integration/zedIntegration.d.ts +31 -8
  689. package/dist/src/zed-integration/zedIntegration.js +14 -23
  690. package/dist/src/zed-integration/zedIntegration.js.map +1 -1
  691. package/dist/src/zed-integration/zedIntegration.test.d.ts +6 -0
  692. package/dist/src/zed-integration/zedIntegration.test.js +619 -0
  693. package/dist/src/zed-integration/zedIntegration.test.js.map +1 -0
  694. package/dist/tsconfig.tsbuildinfo +1 -1
  695. package/package.json +10 -9
@@ -4,10 +4,12 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  import { describe, it, expect, vi, beforeEach, afterEach, } from 'vitest';
7
- import { main, setupUnhandledRejectionHandler, validateDnsResolutionOrder, startInteractiveUI, } from './gemini.js';
7
+ import { main, setupUnhandledRejectionHandler, validateDnsResolutionOrder, startInteractiveUI, getNodeMemoryArgs, } from './gemini.js';
8
+ import os from 'node:os';
9
+ import v8 from 'node:v8';
8
10
  import {} from './config/settings.js';
9
11
  import { appEvents, AppEvent } from './utils/events.js';
10
- import {} from '@google/gemini-cli-core';
12
+ import { debugLogger, } from '@google/gemini-cli-core';
11
13
  import { act } from 'react';
12
14
  import {} from './core/initializer.js';
13
15
  const performance = vi.hoisted(() => ({
@@ -19,15 +21,47 @@ vi.mock('@google/gemini-cli-core', async (importOriginal) => {
19
21
  return {
20
22
  ...actual,
21
23
  recordSlowRender: vi.fn(),
24
+ writeToStdout: vi.fn((...args) => process.stdout.write(...args)),
25
+ patchStdio: vi.fn(() => () => { }),
26
+ createInkStdio: vi.fn(() => ({
27
+ stdout: {
28
+ write: vi.fn((...args) => process.stdout.write(...args)),
29
+ columns: 80,
30
+ rows: 24,
31
+ on: vi.fn(),
32
+ removeListener: vi.fn(),
33
+ },
34
+ stderr: {
35
+ write: vi.fn(),
36
+ },
37
+ })),
38
+ enableMouseEvents: vi.fn(),
39
+ disableMouseEvents: vi.fn(),
40
+ enterAlternateScreen: vi.fn(),
41
+ disableLineWrapping: vi.fn(),
22
42
  };
23
43
  });
24
44
  vi.mock('ink', async (importOriginal) => {
25
45
  const actual = await importOriginal();
26
46
  return {
27
47
  ...actual,
28
- // Mock here so we can spyOn the render function. ink uses ESM which doesn't
29
- // allow us to spyOn it directly.
30
- render: vi.fn((_node, options) => actual.render(_node, options)),
48
+ render: vi.fn((_node, options) => {
49
+ if (options.alternateBuffer) {
50
+ options.stdout.write('\x1b[?7l');
51
+ }
52
+ // Simulate rendering time for recordSlowRender test
53
+ const start = performance.now();
54
+ const end = performance.now();
55
+ if (options.onRender) {
56
+ options.onRender({ renderTime: end - start });
57
+ }
58
+ return {
59
+ unmount: vi.fn(),
60
+ rerender: vi.fn(),
61
+ cleanup: vi.fn(),
62
+ waitUntilExit: vi.fn(),
63
+ };
64
+ }),
31
65
  };
32
66
  });
33
67
  // Custom error to identify mock process.exit calls
@@ -94,10 +128,17 @@ vi.mock('./utils/sandbox.js', () => ({
94
128
  }));
95
129
  vi.mock('./utils/relaunch.js', () => ({
96
130
  relaunchAppInChildProcess: vi.fn(),
131
+ relaunchOnExitCode: vi.fn(),
97
132
  }));
98
133
  vi.mock('./config/sandboxConfig.js', () => ({
99
134
  loadSandboxConfig: vi.fn(),
100
135
  }));
136
+ vi.mock('./ui/utils/mouse.js', () => ({
137
+ enableMouseEvents: vi.fn(),
138
+ disableMouseEvents: vi.fn(),
139
+ parseMouseEvent: vi.fn(),
140
+ isIncompleteMouseSequence: vi.fn(),
141
+ }));
101
142
  describe('gemini.tsx main function', () => {
102
143
  let originalEnvGeminiSandbox;
103
144
  let originalEnvSandbox;
@@ -218,6 +259,7 @@ describe('gemini.tsx main function', () => {
218
259
  throw new MockProcessExitError(code);
219
260
  });
220
261
  const appEventsMock = vi.mocked(appEvents);
262
+ const debugLoggerErrorSpy = vi.spyOn(debugLogger, 'error');
221
263
  const rejectionError = new Error('Test unhandled rejection');
222
264
  setupUnhandledRejectionHandler();
223
265
  // Simulate an unhandled rejection.
@@ -227,8 +269,8 @@ describe('gemini.tsx main function', () => {
227
269
  // We need to wait for the rejection handler to be called.
228
270
  await new Promise(process.nextTick);
229
271
  expect(appEventsMock.emit).toHaveBeenCalledWith(AppEvent.OpenDebugConsole);
230
- expect(appEventsMock.emit).toHaveBeenCalledWith(AppEvent.LogError, expect.stringContaining('Unhandled Promise Rejection'));
231
- expect(appEventsMock.emit).toHaveBeenCalledWith(AppEvent.LogError, expect.stringContaining('Please file a bug report using the /bug tool.'));
272
+ expect(debugLoggerErrorSpy).toHaveBeenCalledWith(expect.stringContaining('Unhandled Promise Rejection'));
273
+ expect(debugLoggerErrorSpy).toHaveBeenCalledWith(expect.stringContaining('Please file a bug report using the /bug tool.'));
232
274
  // Simulate a second rejection
233
275
  const secondRejectionError = new Error('Second test unhandled rejection');
234
276
  process.emit('unhandledRejection', secondRejectionError, Promise.resolve());
@@ -240,6 +282,71 @@ describe('gemini.tsx main function', () => {
240
282
  processExitSpy.mockRestore();
241
283
  });
242
284
  });
285
+ describe('setWindowTitle', () => {
286
+ it('should set window title when hideWindowTitle is false', async () => {
287
+ // setWindowTitle is not exported, but we can test its effect if we had a way to call it.
288
+ // Since we can't easily call it directly without exporting it, we skip direct testing
289
+ // and rely on startInteractiveUI tests which call it.
290
+ });
291
+ });
292
+ describe('initializeOutputListenersAndFlush', () => {
293
+ afterEach(() => {
294
+ vi.restoreAllMocks();
295
+ });
296
+ it('should flush backlogs and setup listeners if no listeners exist', async () => {
297
+ const { coreEvents } = await import('@google/gemini-cli-core');
298
+ const { initializeOutputListenersAndFlush } = await import('./gemini.js');
299
+ // Mock listenerCount to return 0
300
+ vi.spyOn(coreEvents, 'listenerCount').mockReturnValue(0);
301
+ const drainSpy = vi.spyOn(coreEvents, 'drainBacklogs');
302
+ initializeOutputListenersAndFlush();
303
+ expect(drainSpy).toHaveBeenCalled();
304
+ // We can't easily check if listeners were added without access to the internal state of coreEvents,
305
+ // but we can verify that drainBacklogs was called.
306
+ });
307
+ });
308
+ describe('getNodeMemoryArgs', () => {
309
+ let osTotalMemSpy;
310
+ let v8GetHeapStatisticsSpy;
311
+ beforeEach(() => {
312
+ osTotalMemSpy = vi.spyOn(os, 'totalmem');
313
+ v8GetHeapStatisticsSpy = vi.spyOn(v8, 'getHeapStatistics');
314
+ delete process.env['CELL_CLI_NO_RELAUNCH'];
315
+ });
316
+ afterEach(() => {
317
+ vi.restoreAllMocks();
318
+ });
319
+ it('should return empty array if CELL_CLI_NO_RELAUNCH is set', () => {
320
+ process.env['CELL_CLI_NO_RELAUNCH'] = 'true';
321
+ expect(getNodeMemoryArgs(false)).toEqual([]);
322
+ });
323
+ it('should return empty array if current heap limit is sufficient', () => {
324
+ osTotalMemSpy.mockReturnValue(16 * 1024 * 1024 * 1024); // 16GB
325
+ v8GetHeapStatisticsSpy.mockReturnValue({
326
+ heap_size_limit: 8 * 1024 * 1024 * 1024, // 8GB
327
+ });
328
+ // Target is 50% of 16GB = 8GB. Current is 8GB. No relaunch needed.
329
+ expect(getNodeMemoryArgs(false)).toEqual([]);
330
+ });
331
+ it('should return memory args if current heap limit is insufficient', () => {
332
+ osTotalMemSpy.mockReturnValue(16 * 1024 * 1024 * 1024); // 16GB
333
+ v8GetHeapStatisticsSpy.mockReturnValue({
334
+ heap_size_limit: 4 * 1024 * 1024 * 1024, // 4GB
335
+ });
336
+ // Target is 50% of 16GB = 8GB. Current is 4GB. Relaunch needed.
337
+ expect(getNodeMemoryArgs(false)).toEqual(['--max-old-space-size=8192']);
338
+ });
339
+ it('should log debug info when isDebugMode is true', () => {
340
+ const debugSpy = vi.spyOn(debugLogger, 'debug');
341
+ osTotalMemSpy.mockReturnValue(16 * 1024 * 1024 * 1024);
342
+ v8GetHeapStatisticsSpy.mockReturnValue({
343
+ heap_size_limit: 4 * 1024 * 1024 * 1024,
344
+ });
345
+ getNodeMemoryArgs(true);
346
+ expect(debugSpy).toHaveBeenCalledWith(expect.stringContaining('Current heap size'));
347
+ expect(debugSpy).toHaveBeenCalledWith(expect.stringContaining('Need to relaunch with more memory'));
348
+ });
349
+ });
243
350
  describe('gemini.tsx main function kitty protocol', () => {
244
351
  let originalEnvNoRelaunch;
245
352
  let setRawModeSpy;
@@ -360,30 +467,573 @@ describe('gemini.tsx main function kitty protocol', () => {
360
467
  expect(setRawModeSpy).toHaveBeenCalledWith(true);
361
468
  expect(detectAndEnableKittyProtocol).toHaveBeenCalledTimes(1);
362
469
  });
470
+ it.each([
471
+ { flag: 'listExtensions' },
472
+ { flag: 'listSessions' },
473
+ { flag: 'deleteSession', value: 'session-id' },
474
+ ])('should handle --$flag flag', async ({ flag, value }) => {
475
+ const { loadCliConfig, parseArguments } = await import('./config/config.js');
476
+ const { loadSettings } = await import('./config/settings.js');
477
+ const { listSessions, deleteSession } = await import('./utils/sessions.js');
478
+ const processExitSpy = vi
479
+ .spyOn(process, 'exit')
480
+ .mockImplementation((code) => {
481
+ throw new MockProcessExitError(code);
482
+ });
483
+ vi.mocked(loadSettings).mockReturnValue({
484
+ merged: {
485
+ advanced: {},
486
+ security: { auth: {} },
487
+ ui: {},
488
+ },
489
+ setValue: vi.fn(),
490
+ forScope: () => ({ settings: {}, originalSettings: {}, path: '' }),
491
+ errors: [],
492
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
493
+ vi.mocked(parseArguments).mockResolvedValue({
494
+ promptInteractive: false,
495
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
496
+ const mockConfig = {
497
+ isInteractive: () => false,
498
+ getQuestion: () => '',
499
+ getSandbox: () => false,
500
+ getDebugMode: () => false,
501
+ getListExtensions: () => flag === 'listExtensions',
502
+ getListSessions: () => flag === 'listSessions',
503
+ getDeleteSession: () => (flag === 'deleteSession' ? value : undefined),
504
+ getExtensions: () => [{ name: 'ext1' }],
505
+ getPolicyEngine: vi.fn(),
506
+ getMessageBus: () => ({ subscribe: vi.fn() }),
507
+ initialize: vi.fn(),
508
+ getContentGeneratorConfig: vi.fn(),
509
+ getMcpServers: () => ({}),
510
+ getMcpClientManager: vi.fn(),
511
+ getIdeMode: () => false,
512
+ getExperimentalZedIntegration: () => false,
513
+ getScreenReader: () => false,
514
+ getGeminiMdFileCount: () => 0,
515
+ getProjectRoot: () => '/',
516
+ };
517
+ vi.mocked(loadCliConfig).mockResolvedValue(mockConfig);
518
+ vi.mock('./utils/sessions.js', () => ({
519
+ listSessions: vi.fn(),
520
+ deleteSession: vi.fn(),
521
+ }));
522
+ const debugLoggerLogSpy = vi
523
+ .spyOn(debugLogger, 'log')
524
+ .mockImplementation(() => { });
525
+ try {
526
+ await main();
527
+ }
528
+ catch (e) {
529
+ if (!(e instanceof MockProcessExitError))
530
+ throw e;
531
+ }
532
+ if (flag === 'listExtensions') {
533
+ expect(debugLoggerLogSpy).toHaveBeenCalledWith(expect.stringContaining('ext1'));
534
+ }
535
+ else if (flag === 'listSessions') {
536
+ expect(listSessions).toHaveBeenCalledWith(mockConfig);
537
+ }
538
+ else if (flag === 'deleteSession') {
539
+ expect(deleteSession).toHaveBeenCalledWith(mockConfig, value);
540
+ }
541
+ expect(processExitSpy).toHaveBeenCalledWith(0);
542
+ processExitSpy.mockRestore();
543
+ });
544
+ it('should handle sandbox activation', async () => {
545
+ const { loadCliConfig, parseArguments } = await import('./config/config.js');
546
+ const { loadSandboxConfig } = await import('./config/sandboxConfig.js');
547
+ const { start_sandbox } = await import('./utils/sandbox.js');
548
+ const { relaunchOnExitCode } = await import('./utils/relaunch.js');
549
+ const { loadSettings } = await import('./config/settings.js');
550
+ const processExitSpy = vi
551
+ .spyOn(process, 'exit')
552
+ .mockImplementation((code) => {
553
+ throw new MockProcessExitError(code);
554
+ });
555
+ vi.mocked(parseArguments).mockResolvedValue({
556
+ promptInteractive: false,
557
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
558
+ vi.mocked(loadSettings).mockReturnValue({
559
+ merged: {
560
+ advanced: {},
561
+ security: { auth: {} },
562
+ ui: {},
563
+ },
564
+ setValue: vi.fn(),
565
+ forScope: () => ({ settings: {}, originalSettings: {}, path: '' }),
566
+ errors: [],
567
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
568
+ const mockConfig = {
569
+ isInteractive: () => false,
570
+ getQuestion: () => '',
571
+ getSandbox: () => true,
572
+ getDebugMode: () => false,
573
+ getListExtensions: () => false,
574
+ getListSessions: () => false,
575
+ getDeleteSession: () => undefined,
576
+ getExtensions: () => [],
577
+ getPolicyEngine: vi.fn(),
578
+ getMessageBus: () => ({ subscribe: vi.fn() }),
579
+ initialize: vi.fn(),
580
+ getContentGeneratorConfig: vi.fn(),
581
+ getMcpServers: () => ({}),
582
+ getMcpClientManager: vi.fn(),
583
+ getIdeMode: () => false,
584
+ getExperimentalZedIntegration: () => false,
585
+ getScreenReader: () => false,
586
+ getGeminiMdFileCount: () => 0,
587
+ getProjectRoot: () => '/',
588
+ refreshAuth: vi.fn(),
589
+ };
590
+ vi.mocked(loadCliConfig).mockResolvedValue(mockConfig);
591
+ vi.mocked(loadSandboxConfig).mockResolvedValue({}); // eslint-disable-line @typescript-eslint/no-explicit-any
592
+ vi.mocked(relaunchOnExitCode).mockImplementation(async (fn) => {
593
+ await fn();
594
+ });
595
+ try {
596
+ await main();
597
+ }
598
+ catch (e) {
599
+ if (!(e instanceof MockProcessExitError))
600
+ throw e;
601
+ }
602
+ expect(start_sandbox).toHaveBeenCalled();
603
+ expect(processExitSpy).toHaveBeenCalledWith(0);
604
+ processExitSpy.mockRestore();
605
+ });
606
+ it('should exit with error when --prompt-interactive is used with piped input', async () => {
607
+ const { loadCliConfig, parseArguments } = await import('./config/config.js');
608
+ const { loadSettings } = await import('./config/settings.js');
609
+ const core = await import('@google/gemini-cli-core');
610
+ const processExitSpy = vi
611
+ .spyOn(process, 'exit')
612
+ .mockImplementation((code) => {
613
+ throw new MockProcessExitError(code);
614
+ });
615
+ const writeToStderrSpy = vi
616
+ .spyOn(core, 'writeToStderr')
617
+ .mockImplementation(() => true);
618
+ vi.mocked(loadSettings).mockReturnValue({
619
+ merged: { advanced: {}, security: { auth: {} }, ui: {} },
620
+ setValue: vi.fn(),
621
+ forScope: () => ({ settings: {}, originalSettings: {}, path: '' }),
622
+ errors: [],
623
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
624
+ vi.mocked(parseArguments).mockResolvedValue({
625
+ promptInteractive: true,
626
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
627
+ vi.mocked(loadCliConfig).mockResolvedValue({
628
+ isInteractive: () => false,
629
+ getQuestion: () => '',
630
+ getSandbox: () => false,
631
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
632
+ // Mock stdin to be non-TTY
633
+ Object.defineProperty(process.stdin, 'isTTY', {
634
+ value: false,
635
+ configurable: true,
636
+ });
637
+ try {
638
+ await main();
639
+ }
640
+ catch (e) {
641
+ if (!(e instanceof MockProcessExitError))
642
+ throw e;
643
+ }
644
+ expect(writeToStderrSpy).toHaveBeenCalledWith(expect.stringContaining('Error: The --prompt-interactive flag cannot be used'));
645
+ expect(processExitSpy).toHaveBeenCalledWith(1);
646
+ processExitSpy.mockRestore();
647
+ writeToStderrSpy.mockRestore();
648
+ Object.defineProperty(process.stdin, 'isTTY', {
649
+ value: true,
650
+ configurable: true,
651
+ }); // Restore TTY
652
+ });
653
+ it('should log warning when theme is not found', async () => {
654
+ const { loadCliConfig, parseArguments } = await import('./config/config.js');
655
+ const { loadSettings } = await import('./config/settings.js');
656
+ const { themeManager } = await import('./ui/themes/theme-manager.js');
657
+ const debugLoggerWarnSpy = vi
658
+ .spyOn(debugLogger, 'warn')
659
+ .mockImplementation(() => { });
660
+ const processExitSpy = vi
661
+ .spyOn(process, 'exit')
662
+ .mockImplementation((code) => {
663
+ throw new MockProcessExitError(code);
664
+ });
665
+ vi.mocked(loadSettings).mockReturnValue({
666
+ merged: {
667
+ advanced: {},
668
+ security: { auth: {} },
669
+ ui: { theme: 'non-existent-theme' },
670
+ },
671
+ setValue: vi.fn(),
672
+ forScope: () => ({ settings: {}, originalSettings: {}, path: '' }),
673
+ errors: [],
674
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
675
+ vi.mocked(parseArguments).mockResolvedValue({
676
+ promptInteractive: false,
677
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
678
+ vi.mocked(loadCliConfig).mockResolvedValue({
679
+ isInteractive: () => false,
680
+ getQuestion: () => 'test',
681
+ getSandbox: () => false,
682
+ getDebugMode: () => false,
683
+ getPolicyEngine: vi.fn(),
684
+ getMessageBus: () => ({ subscribe: vi.fn() }),
685
+ initialize: vi.fn(),
686
+ getContentGeneratorConfig: vi.fn(),
687
+ getMcpServers: () => ({}),
688
+ getMcpClientManager: vi.fn(),
689
+ getIdeMode: () => false,
690
+ getExperimentalZedIntegration: () => false,
691
+ getScreenReader: () => false,
692
+ getGeminiMdFileCount: () => 0,
693
+ getProjectRoot: () => '/',
694
+ getListExtensions: () => false,
695
+ getListSessions: () => false,
696
+ getDeleteSession: () => undefined,
697
+ getToolRegistry: vi.fn(),
698
+ getExtensions: () => [],
699
+ getModel: () => 'gemini-pro',
700
+ getEmbeddingModel: () => 'embedding-001',
701
+ getApprovalMode: () => 'default',
702
+ getCoreTools: () => [],
703
+ getTelemetryEnabled: () => false,
704
+ getTelemetryLogPromptsEnabled: () => false,
705
+ getFileFilteringRespectGitIgnore: () => true,
706
+ getOutputFormat: () => 'text',
707
+ getUsageStatisticsEnabled: () => false,
708
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
709
+ vi.spyOn(themeManager, 'setActiveTheme').mockReturnValue(false);
710
+ try {
711
+ await main();
712
+ }
713
+ catch (e) {
714
+ if (!(e instanceof MockProcessExitError))
715
+ throw e;
716
+ }
717
+ expect(debugLoggerWarnSpy).toHaveBeenCalledWith(expect.stringContaining('Warning: Theme "non-existent-theme" not found.'));
718
+ processExitSpy.mockRestore();
719
+ });
720
+ it('should handle session selector error', async () => {
721
+ const { loadCliConfig, parseArguments } = await import('./config/config.js');
722
+ const { loadSettings } = await import('./config/settings.js');
723
+ vi.mock('./utils/sessionUtils.js', () => ({
724
+ SessionSelector: class {
725
+ resolveSession = vi
726
+ .fn()
727
+ .mockRejectedValue(new Error('Session not found'));
728
+ },
729
+ }));
730
+ const processExitSpy = vi
731
+ .spyOn(process, 'exit')
732
+ .mockImplementation((code) => {
733
+ throw new MockProcessExitError(code);
734
+ });
735
+ const consoleErrorSpy = vi
736
+ .spyOn(console, 'error')
737
+ .mockImplementation(() => { });
738
+ vi.mocked(loadSettings).mockReturnValue({
739
+ merged: { advanced: {}, security: { auth: {} }, ui: { theme: 'test' } },
740
+ setValue: vi.fn(),
741
+ forScope: () => ({ settings: {}, originalSettings: {}, path: '' }),
742
+ errors: [],
743
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
744
+ vi.mocked(parseArguments).mockResolvedValue({
745
+ promptInteractive: false,
746
+ resume: 'session-id',
747
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
748
+ vi.mocked(loadCliConfig).mockResolvedValue({
749
+ isInteractive: () => true,
750
+ getQuestion: () => '',
751
+ getSandbox: () => false,
752
+ getDebugMode: () => false,
753
+ getPolicyEngine: vi.fn(),
754
+ getMessageBus: () => ({ subscribe: vi.fn() }),
755
+ initialize: vi.fn(),
756
+ getContentGeneratorConfig: vi.fn(),
757
+ getMcpServers: () => ({}),
758
+ getMcpClientManager: vi.fn(),
759
+ getIdeMode: () => false,
760
+ getExperimentalZedIntegration: () => false,
761
+ getScreenReader: () => false,
762
+ getGeminiMdFileCount: () => 0,
763
+ getProjectRoot: () => '/',
764
+ getListExtensions: () => false,
765
+ getListSessions: () => false,
766
+ getDeleteSession: () => undefined,
767
+ getToolRegistry: vi.fn(),
768
+ getExtensions: () => [],
769
+ getModel: () => 'gemini-pro',
770
+ getEmbeddingModel: () => 'embedding-001',
771
+ getApprovalMode: () => 'default',
772
+ getCoreTools: () => [],
773
+ getTelemetryEnabled: () => false,
774
+ getTelemetryLogPromptsEnabled: () => false,
775
+ getFileFilteringRespectGitIgnore: () => true,
776
+ getOutputFormat: () => 'text',
777
+ getUsageStatisticsEnabled: () => false,
778
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
779
+ try {
780
+ await main();
781
+ }
782
+ catch (e) {
783
+ if (!(e instanceof MockProcessExitError))
784
+ throw e;
785
+ }
786
+ expect(consoleErrorSpy).toHaveBeenCalledWith(expect.stringContaining('Error resuming session: Session not found'));
787
+ expect(processExitSpy).toHaveBeenCalledWith(1);
788
+ processExitSpy.mockRestore();
789
+ consoleErrorSpy.mockRestore();
790
+ });
791
+ it.skip('should log error when cleanupExpiredSessions fails', async () => {
792
+ const { loadCliConfig, parseArguments } = await import('./config/config.js');
793
+ const { loadSettings } = await import('./config/settings.js');
794
+ const { cleanupExpiredSessions } = await import('./utils/sessionCleanup.js');
795
+ vi.mocked(cleanupExpiredSessions).mockRejectedValue(new Error('Cleanup failed'));
796
+ const debugLoggerErrorSpy = vi
797
+ .spyOn(debugLogger, 'error')
798
+ .mockImplementation(() => { });
799
+ const processExitSpy = vi
800
+ .spyOn(process, 'exit')
801
+ .mockImplementation((code) => {
802
+ throw new MockProcessExitError(code);
803
+ });
804
+ vi.mocked(loadSettings).mockReturnValue({
805
+ merged: { advanced: {}, security: { auth: {} }, ui: {} },
806
+ setValue: vi.fn(),
807
+ forScope: () => ({ settings: {}, originalSettings: {}, path: '' }),
808
+ errors: [],
809
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
810
+ vi.mocked(parseArguments).mockResolvedValue({
811
+ promptInteractive: false,
812
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
813
+ vi.mocked(loadCliConfig).mockResolvedValue({
814
+ isInteractive: () => false,
815
+ getQuestion: () => 'test',
816
+ getSandbox: () => false,
817
+ getDebugMode: () => false,
818
+ getPolicyEngine: vi.fn(),
819
+ getMessageBus: () => ({ subscribe: vi.fn() }),
820
+ initialize: vi.fn(),
821
+ getContentGeneratorConfig: vi.fn(),
822
+ getMcpServers: () => ({}),
823
+ getMcpClientManager: vi.fn(),
824
+ getIdeMode: () => false,
825
+ getExperimentalZedIntegration: () => false,
826
+ getScreenReader: () => false,
827
+ getGeminiMdFileCount: () => 0,
828
+ getProjectRoot: () => '/',
829
+ getListExtensions: () => false,
830
+ getListSessions: () => false,
831
+ getDeleteSession: () => undefined,
832
+ getToolRegistry: vi.fn(),
833
+ getExtensions: () => [],
834
+ getModel: () => 'gemini-pro',
835
+ getEmbeddingModel: () => 'embedding-001',
836
+ getApprovalMode: () => 'default',
837
+ getCoreTools: () => [],
838
+ getTelemetryEnabled: () => false,
839
+ getTelemetryLogPromptsEnabled: () => false,
840
+ getFileFilteringRespectGitIgnore: () => true,
841
+ getOutputFormat: () => 'text',
842
+ getUsageStatisticsEnabled: () => false,
843
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
844
+ // The mock is already set up at the top of the test
845
+ try {
846
+ await main();
847
+ }
848
+ catch (e) {
849
+ if (!(e instanceof MockProcessExitError))
850
+ throw e;
851
+ }
852
+ expect(debugLoggerErrorSpy).toHaveBeenCalledWith(expect.stringContaining('Failed to cleanup expired sessions: Cleanup failed'));
853
+ expect(processExitSpy).toHaveBeenCalledWith(0); // Should not exit on cleanup failure
854
+ processExitSpy.mockRestore();
855
+ });
856
+ it('should handle refreshAuth failure', async () => {
857
+ const { loadCliConfig, parseArguments } = await import('./config/config.js');
858
+ const { loadSettings } = await import('./config/settings.js');
859
+ const { loadSandboxConfig } = await import('./config/sandboxConfig.js');
860
+ const processExitSpy = vi
861
+ .spyOn(process, 'exit')
862
+ .mockImplementation((code) => {
863
+ throw new MockProcessExitError(code);
864
+ });
865
+ const debugLoggerErrorSpy = vi
866
+ .spyOn(debugLogger, 'error')
867
+ .mockImplementation(() => { });
868
+ vi.mocked(loadSettings).mockReturnValue({
869
+ merged: {
870
+ advanced: {},
871
+ security: { auth: { selectedType: 'google' } },
872
+ ui: {},
873
+ },
874
+ setValue: vi.fn(),
875
+ forScope: () => ({ settings: {}, originalSettings: {}, path: '' }),
876
+ errors: [],
877
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
878
+ vi.mocked(loadSandboxConfig).mockResolvedValue({}); // eslint-disable-line @typescript-eslint/no-explicit-any
879
+ vi.mocked(parseArguments).mockResolvedValue({
880
+ promptInteractive: false,
881
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
882
+ vi.mocked(loadCliConfig).mockResolvedValue({
883
+ isInteractive: () => true,
884
+ getQuestion: () => '',
885
+ getSandbox: () => false,
886
+ getDebugMode: () => false,
887
+ getPolicyEngine: vi.fn(),
888
+ getMessageBus: () => ({ subscribe: vi.fn() }),
889
+ initialize: vi.fn(),
890
+ getContentGeneratorConfig: vi.fn(),
891
+ getMcpServers: () => ({}),
892
+ getMcpClientManager: vi.fn(),
893
+ getIdeMode: () => false,
894
+ getExperimentalZedIntegration: () => false,
895
+ getScreenReader: () => false,
896
+ getGeminiMdFileCount: () => 0,
897
+ getProjectRoot: () => '/',
898
+ getListExtensions: () => false,
899
+ getListSessions: () => false,
900
+ getDeleteSession: () => undefined,
901
+ getToolRegistry: vi.fn(),
902
+ getExtensions: () => [],
903
+ getModel: () => 'gemini-pro',
904
+ getEmbeddingModel: () => 'embedding-001',
905
+ getApprovalMode: () => 'default',
906
+ getCoreTools: () => [],
907
+ getTelemetryEnabled: () => false,
908
+ getTelemetryLogPromptsEnabled: () => false,
909
+ getFileFilteringRespectGitIgnore: () => true,
910
+ getOutputFormat: () => 'text',
911
+ getUsageStatisticsEnabled: () => false,
912
+ refreshAuth: vi.fn().mockRejectedValue(new Error('Auth refresh failed')),
913
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
914
+ try {
915
+ await main();
916
+ }
917
+ catch (e) {
918
+ if (!(e instanceof MockProcessExitError))
919
+ throw e;
920
+ }
921
+ expect(debugLoggerErrorSpy).toHaveBeenCalledWith('Error authenticating:', expect.any(Error));
922
+ expect(processExitSpy).toHaveBeenCalledWith(1);
923
+ processExitSpy.mockRestore();
924
+ });
925
+ it('should read from stdin in non-interactive mode', async () => {
926
+ const { loadCliConfig, parseArguments } = await import('./config/config.js');
927
+ const { loadSettings } = await import('./config/settings.js');
928
+ const { readStdin } = await import('./utils/readStdin.js');
929
+ const processExitSpy = vi
930
+ .spyOn(process, 'exit')
931
+ .mockImplementation((code) => {
932
+ throw new MockProcessExitError(code);
933
+ });
934
+ vi.mocked(loadSettings).mockReturnValue({
935
+ merged: { advanced: {}, security: { auth: {} }, ui: {} },
936
+ setValue: vi.fn(),
937
+ forScope: () => ({ settings: {}, originalSettings: {}, path: '' }),
938
+ errors: [],
939
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
940
+ vi.mocked(parseArguments).mockResolvedValue({
941
+ promptInteractive: false,
942
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
943
+ vi.mocked(loadCliConfig).mockResolvedValue({
944
+ isInteractive: () => false,
945
+ getQuestion: () => 'test-question',
946
+ getSandbox: () => false,
947
+ getDebugMode: () => false,
948
+ getPolicyEngine: vi.fn(),
949
+ getMessageBus: () => ({ subscribe: vi.fn() }),
950
+ initialize: vi.fn(),
951
+ getContentGeneratorConfig: vi.fn(),
952
+ getMcpServers: () => ({}),
953
+ getMcpClientManager: vi.fn(),
954
+ getIdeMode: () => false,
955
+ getExperimentalZedIntegration: () => false,
956
+ getScreenReader: () => false,
957
+ getGeminiMdFileCount: () => 0,
958
+ getProjectRoot: () => '/',
959
+ getListExtensions: () => false,
960
+ getListSessions: () => false,
961
+ getDeleteSession: () => undefined,
962
+ getToolRegistry: vi.fn(),
963
+ getExtensions: () => [],
964
+ getModel: () => 'gemini-pro',
965
+ getEmbeddingModel: () => 'embedding-001',
966
+ getApprovalMode: () => 'default',
967
+ getCoreTools: () => [],
968
+ getTelemetryEnabled: () => false,
969
+ getTelemetryLogPromptsEnabled: () => false,
970
+ getFileFilteringRespectGitIgnore: () => true,
971
+ getOutputFormat: () => 'text',
972
+ getUsageStatisticsEnabled: () => false,
973
+ }); // eslint-disable-line @typescript-eslint/no-explicit-any
974
+ vi.mock('./utils/readStdin.js', () => ({
975
+ readStdin: vi.fn().mockResolvedValue('stdin-data'),
976
+ }));
977
+ const runNonInteractiveSpy = vi.hoisted(() => vi.fn());
978
+ vi.mock('./nonInteractiveCli.js', () => ({
979
+ runNonInteractive: runNonInteractiveSpy,
980
+ }));
981
+ runNonInteractiveSpy.mockClear();
982
+ vi.mock('./validateNonInterActiveAuth.js', () => ({
983
+ validateNonInteractiveAuth: vi.fn().mockResolvedValue({}),
984
+ }));
985
+ // Mock stdin to be non-TTY
986
+ Object.defineProperty(process.stdin, 'isTTY', {
987
+ value: false,
988
+ configurable: true,
989
+ });
990
+ try {
991
+ await main();
992
+ }
993
+ catch (e) {
994
+ if (!(e instanceof MockProcessExitError))
995
+ throw e;
996
+ }
997
+ expect(readStdin).toHaveBeenCalled();
998
+ // In this test setup, runNonInteractive might be called on the mocked module,
999
+ // but we need to ensure we are checking the correct spy instance.
1000
+ // Since vi.mock is hoisted, runNonInteractiveSpy is defined early.
1001
+ expect(runNonInteractiveSpy).toHaveBeenCalled();
1002
+ const callArgs = runNonInteractiveSpy.mock.calls[0][0];
1003
+ expect(callArgs.input).toBe('test-question');
1004
+ expect(processExitSpy).toHaveBeenCalledWith(0);
1005
+ processExitSpy.mockRestore();
1006
+ Object.defineProperty(process.stdin, 'isTTY', {
1007
+ value: true,
1008
+ configurable: true,
1009
+ });
1010
+ });
363
1011
  });
364
1012
  describe('validateDnsResolutionOrder', () => {
365
- let consoleWarnSpy;
1013
+ let debugLoggerWarnSpy;
366
1014
  beforeEach(() => {
367
- consoleWarnSpy = vi.spyOn(console, 'warn').mockImplementation(() => { });
1015
+ debugLoggerWarnSpy = vi
1016
+ .spyOn(debugLogger, 'warn')
1017
+ .mockImplementation(() => { });
368
1018
  });
369
1019
  afterEach(() => {
370
1020
  vi.restoreAllMocks();
371
1021
  });
372
1022
  it('should return "ipv4first" when the input is "ipv4first"', () => {
373
1023
  expect(validateDnsResolutionOrder('ipv4first')).toBe('ipv4first');
374
- expect(consoleWarnSpy).not.toHaveBeenCalled();
1024
+ expect(debugLoggerWarnSpy).not.toHaveBeenCalled();
375
1025
  });
376
1026
  it('should return "verbatim" when the input is "verbatim"', () => {
377
1027
  expect(validateDnsResolutionOrder('verbatim')).toBe('verbatim');
378
- expect(consoleWarnSpy).not.toHaveBeenCalled();
1028
+ expect(debugLoggerWarnSpy).not.toHaveBeenCalled();
379
1029
  });
380
1030
  it('should return the default "ipv4first" when the input is undefined', () => {
381
1031
  expect(validateDnsResolutionOrder(undefined)).toBe('ipv4first');
382
- expect(consoleWarnSpy).not.toHaveBeenCalled();
1032
+ expect(debugLoggerWarnSpy).not.toHaveBeenCalled();
383
1033
  });
384
1034
  it('should return the default "ipv4first" and log a warning for an invalid string', () => {
385
1035
  expect(validateDnsResolutionOrder('invalid-value')).toBe('ipv4first');
386
- expect(consoleWarnSpy).toHaveBeenCalledExactlyOnceWith('Invalid value for dnsResolutionOrder in settings: "invalid-value". Using default "ipv4first".');
1036
+ expect(debugLoggerWarnSpy).toHaveBeenCalledExactlyOnceWith('Invalid value for dnsResolutionOrder in settings: "invalid-value". Using default "ipv4first".');
387
1037
  });
388
1038
  });
389
1039
  describe('startInteractiveUI', () => {
@@ -391,11 +1041,13 @@ describe('startInteractiveUI', () => {
391
1041
  const mockConfig = {
392
1042
  getProjectRoot: () => '/root',
393
1043
  getScreenReader: () => false,
1044
+ getDebugMode: () => false,
394
1045
  };
395
1046
  const mockSettings = {
396
1047
  merged: {
397
1048
  ui: {
398
1049
  hideWindowTitle: false,
1050
+ useAlternateBuffer: true,
399
1051
  },
400
1052
  },
401
1053
  };
@@ -422,6 +1074,7 @@ describe('startInteractiveUI', () => {
422
1074
  cleanupCheckpoints: vi.fn(() => Promise.resolve()),
423
1075
  registerCleanup: vi.fn(),
424
1076
  runExitCleanup: vi.fn(),
1077
+ registerSyncCleanup: vi.fn(),
425
1078
  }));
426
1079
  afterEach(() => {
427
1080
  vi.restoreAllMocks();
@@ -439,16 +1092,28 @@ describe('startInteractiveUI', () => {
439
1092
  expect(renderSpy).toHaveBeenCalledTimes(1);
440
1093
  const [reactElement, options] = renderSpy.mock.calls[0];
441
1094
  // Verify render options
442
- expect(options).toEqual({
1095
+ expect(options).toEqual(expect.objectContaining({
443
1096
  alternateBuffer: true,
444
1097
  exitOnCtrlC: false,
445
1098
  incrementalRendering: true,
446
1099
  isScreenReaderEnabled: false,
447
1100
  onRender: expect.any(Function),
448
- });
1101
+ patchConsole: false,
1102
+ }));
449
1103
  // Verify React element structure is valid (but don't deep dive into JSX internals)
450
1104
  expect(reactElement).toBeDefined();
451
1105
  });
1106
+ it('should enable mouse events when alternate buffer is enabled', async () => {
1107
+ const { enableMouseEvents } = await import('@google/gemini-cli-core');
1108
+ await startTestInteractiveUI(mockConfig, mockSettings, mockStartupWarnings, mockWorkspaceRoot, undefined, mockInitializationResult);
1109
+ expect(enableMouseEvents).toHaveBeenCalled();
1110
+ });
1111
+ it('should patch console', async () => {
1112
+ const { ConsolePatcher } = await import('./ui/utils/ConsolePatcher.js');
1113
+ const patchSpy = vi.spyOn(ConsolePatcher.prototype, 'patch');
1114
+ await startTestInteractiveUI(mockConfig, mockSettings, mockStartupWarnings, mockWorkspaceRoot, undefined, mockInitializationResult);
1115
+ expect(patchSpy).toHaveBeenCalled();
1116
+ });
452
1117
  it('should perform all startup tasks in correct order', async () => {
453
1118
  const { getCliVersion } = await import('./utils/version.js');
454
1119
  const { checkForUpdates } = await import('./ui/utils/updateCheck.js');
@@ -456,7 +1121,7 @@ describe('startInteractiveUI', () => {
456
1121
  await startTestInteractiveUI(mockConfig, mockSettings, mockStartupWarnings, mockWorkspaceRoot, undefined, mockInitializationResult);
457
1122
  // Verify all startup tasks were called
458
1123
  expect(getCliVersion).toHaveBeenCalledTimes(1);
459
- expect(registerCleanup).toHaveBeenCalledTimes(2);
1124
+ expect(registerCleanup).toHaveBeenCalledTimes(3);
460
1125
  // Verify cleanup handler is registered with unmount function
461
1126
  const cleanupFn = vi.mocked(registerCleanup).mock.calls[0][0];
462
1127
  expect(typeof cleanupFn).toBe('function');