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