@machina.ai/cell-cli 1.41.1-rc2 → 1.45.1-rc2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +17 -17
- package/dist/index.js.map +1 -1
- package/dist/package.json +4 -4
- package/dist/src/acp/README.md +81 -0
- package/dist/src/acp/{commandHandler.d.ts → acpCommandHandler.d.ts} +1 -1
- package/dist/src/acp/{commandHandler.js → acpCommandHandler.js} +2 -2
- package/dist/src/acp/acpCommandHandler.js.map +1 -0
- package/dist/src/acp/{commandHandler.test.js → acpCommandHandler.test.js} +4 -5
- package/dist/src/acp/acpCommandHandler.test.js.map +1 -0
- package/dist/src/acp/acpErrors.d.ts +1 -1
- package/dist/src/acp/acpErrors.js +1 -1
- package/dist/src/acp/acpErrors.test.d.ts +1 -1
- package/dist/src/acp/acpErrors.test.js +1 -1
- package/dist/src/acp/{fileSystemService.d.ts → acpFileSystemService.d.ts} +1 -1
- package/dist/src/acp/{fileSystemService.js → acpFileSystemService.js} +7 -4
- package/dist/src/acp/acpFileSystemService.js.map +1 -0
- package/dist/src/acp/{fileSystemService.test.js → acpFileSystemService.test.js} +3 -3
- package/dist/src/acp/acpFileSystemService.test.js.map +1 -0
- package/dist/src/acp/acpResume.test.d.ts +1 -1
- package/dist/src/acp/acpResume.test.js +12 -7
- package/dist/src/acp/acpResume.test.js.map +1 -1
- package/dist/src/acp/acpRpcDispatcher.d.ts +28 -0
- package/dist/src/acp/acpRpcDispatcher.js +177 -0
- package/dist/src/acp/acpRpcDispatcher.js.map +1 -0
- package/dist/src/acp/acpRpcDispatcher.test.d.ts +6 -0
- package/dist/src/acp/acpRpcDispatcher.test.js +238 -0
- package/dist/src/acp/acpRpcDispatcher.test.js.map +1 -0
- package/dist/src/acp/acpSession.d.ts +36 -0
- package/dist/src/acp/{acpClient.js → acpSession.js} +333 -781
- package/dist/src/acp/acpSession.js.map +1 -0
- package/dist/src/acp/acpSession.test.d.ts +6 -0
- package/dist/src/acp/acpSession.test.js +739 -0
- package/dist/src/acp/acpSession.test.js.map +1 -0
- package/dist/src/acp/acpSessionManager.d.ts +30 -0
- package/dist/src/acp/acpSessionManager.js +206 -0
- package/dist/src/acp/acpSessionManager.js.map +1 -0
- package/dist/src/acp/acpSessionManager.test.d.ts +6 -0
- package/dist/src/acp/acpSessionManager.test.js +283 -0
- package/dist/src/acp/acpSessionManager.test.js.map +1 -0
- package/dist/src/acp/acpStdioTransport.d.ts +9 -0
- package/dist/src/acp/acpStdioTransport.js +23 -0
- package/dist/src/acp/acpStdioTransport.js.map +1 -0
- package/dist/src/acp/acpUtils.d.ts +56 -0
- package/dist/src/acp/acpUtils.js +288 -0
- package/dist/src/acp/acpUtils.js.map +1 -0
- package/dist/src/acp/commands/commandRegistry.d.ts +1 -1
- package/dist/src/acp/commands/commandRegistry.js +1 -1
- package/dist/src/acp/commands/extensions.d.ts +1 -1
- package/dist/src/acp/commands/extensions.js +1 -1
- package/dist/src/acp/commands/extensions.test.d.ts +6 -0
- package/dist/src/acp/commands/extensions.test.js +70 -0
- package/dist/src/acp/commands/extensions.test.js.map +1 -0
- package/dist/src/acp/commands/init.d.ts +1 -1
- package/dist/src/acp/commands/init.js +1 -1
- package/dist/src/acp/commands/memory.d.ts +3 -8
- package/dist/src/acp/commands/memory.js +18 -47
- package/dist/src/acp/commands/memory.js.map +1 -1
- package/dist/src/acp/commands/restore.d.ts +1 -1
- package/dist/src/acp/commands/restore.js +1 -1
- package/dist/src/acp/commands/restore.test.js +7 -13
- package/dist/src/acp/commands/restore.test.js.map +1 -1
- package/dist/src/acp/commands/types.d.ts +1 -1
- package/dist/src/acp/commands/types.js +1 -1
- package/dist/src/commands/extensions/configure.test.js +6 -2
- package/dist/src/commands/extensions/configure.test.js.map +1 -1
- package/dist/src/commands/extensions/utils.d.ts +1 -1
- package/dist/src/commands/extensions/utils.js +1 -2
- package/dist/src/commands/extensions/utils.js.map +1 -1
- package/dist/src/commands/mcp/list.js +19 -5
- package/dist/src/commands/mcp/list.js.map +1 -1
- package/dist/src/commands/mcp/list.test.js +285 -100
- package/dist/src/commands/mcp/list.test.js.map +1 -1
- package/dist/src/config/auth.d.ts +1 -1
- package/dist/src/config/auth.js +4 -3
- package/dist/src/config/auth.js.map +1 -1
- package/dist/src/config/auth.test.js +11 -4
- package/dist/src/config/auth.test.js.map +1 -1
- package/dist/src/config/config.d.ts +4 -0
- package/dist/src/config/config.js +65 -47
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +25 -106
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/extension-manager-agents.test.js +2 -0
- package/dist/src/config/extension-manager-agents.test.js.map +1 -1
- package/dist/src/config/extension-manager-hydration.test.js +2 -0
- package/dist/src/config/extension-manager-hydration.test.js.map +1 -1
- package/dist/src/config/extension-manager-scope.test.js +4 -2
- package/dist/src/config/extension-manager-scope.test.js.map +1 -1
- package/dist/src/config/extension-manager-themes.spec.js +2 -0
- package/dist/src/config/extension-manager-themes.spec.js.map +1 -1
- package/dist/src/config/extension-manager.d.ts +2 -2
- package/dist/src/config/extension-manager.js +2 -1
- package/dist/src/config/extension-manager.js.map +1 -1
- package/dist/src/config/extensionRegistryClient.js +0 -1
- package/dist/src/config/extensionRegistryClient.js.map +1 -1
- package/dist/src/config/extensions/consent.d.ts +1 -1
- package/dist/src/config/extensions/consent.js +5 -4
- package/dist/src/config/extensions/consent.js.map +1 -1
- package/dist/src/config/extensions/consent.test.js +22 -0
- package/dist/src/config/extensions/consent.test.js.map +1 -1
- package/dist/src/config/extensions/extensionEnablement.js +4 -2
- package/dist/src/config/extensions/extensionEnablement.js.map +1 -1
- package/dist/src/config/extensions/extensionSettings.d.ts +3 -3
- package/dist/src/config/extensions/extensionSettings.js +7 -3
- package/dist/src/config/extensions/extensionSettings.js.map +1 -1
- package/dist/src/config/extensions/variables.js +1 -3
- package/dist/src/config/extensions/variables.js.map +1 -1
- package/dist/src/config/footerItems.d.ts +4 -0
- package/dist/src/config/footerItems.js +6 -0
- package/dist/src/config/footerItems.js.map +1 -1
- package/dist/src/config/footerItems.test.js +1 -0
- package/dist/src/config/footerItems.test.js.map +1 -1
- package/dist/src/config/mcp/mcpServerEnablement.js +1 -1
- package/dist/src/config/mcp/mcpServerEnablement.js.map +1 -1
- package/dist/src/config/mutual-exclusivity.test.js +33 -0
- package/dist/src/config/mutual-exclusivity.test.js.map +1 -0
- package/dist/src/config/settings-env-isolation.test.d.ts +6 -0
- package/dist/src/config/settings-env-isolation.test.js +188 -0
- package/dist/src/config/settings-env-isolation.test.js.map +1 -0
- package/dist/src/config/settings.d.ts +15 -1
- package/dist/src/config/settings.js +85 -10
- package/dist/src/config/settings.js.map +1 -1
- package/dist/src/config/settings.test.js +167 -0
- package/dist/src/config/settings.test.js.map +1 -1
- package/dist/src/config/settingsSchema.d.ts +56 -25
- package/dist/src/config/settingsSchema.js +66 -27
- package/dist/src/config/settingsSchema.js.map +1 -1
- package/dist/src/config/settingsSchema.test.js +8 -0
- package/dist/src/config/settingsSchema.test.js.map +1 -1
- package/dist/src/config/skipExtensions.test.d.ts +6 -0
- package/dist/src/config/skipExtensions.test.js +49 -0
- package/dist/src/config/skipExtensions.test.js.map +1 -0
- package/dist/src/config/workspace-policy-cli.test.js +0 -5
- package/dist/src/config/workspace-policy-cli.test.js.map +1 -1
- package/dist/src/gemini.d.ts +2 -2
- package/dist/src/gemini.js +108 -30
- package/dist/src/gemini.js.map +1 -1
- package/dist/src/gemini.test.js +147 -16
- package/dist/src/gemini.test.js.map +1 -1
- package/dist/src/gemini_cleanup.test.js +1 -1
- package/dist/src/gemini_cleanup.test.js.map +1 -1
- package/dist/src/generated/git-commit.d.ts +2 -2
- package/dist/src/generated/git-commit.js +2 -2
- package/dist/src/interactiveCli.js +1 -1
- package/dist/src/interactiveCli.js.map +1 -1
- package/dist/src/nonInteractiveCli.d.ts +7 -0
- package/dist/src/nonInteractiveCli.js +56 -6
- package/dist/src/nonInteractiveCli.js.map +1 -1
- package/dist/src/nonInteractiveCli.test.js +253 -18
- package/dist/src/nonInteractiveCli.test.js.map +1 -1
- package/dist/src/nonInteractiveCliAgentSession.d.ts +7 -0
- package/dist/src/nonInteractiveCliAgentSession.js +22 -3
- package/dist/src/nonInteractiveCliAgentSession.js.map +1 -1
- package/dist/src/nonInteractiveCliAgentSession.test.js +200 -20
- package/dist/src/nonInteractiveCliAgentSession.test.js.map +1 -1
- package/dist/src/output-redirection.test.d.ts +6 -0
- package/dist/src/output-redirection.test.js +77 -0
- package/dist/src/output-redirection.test.js.map +1 -0
- package/dist/src/patches/http-proxy-agent.d.ts +6 -0
- package/dist/src/patches/http-proxy-agent.js +8 -0
- package/dist/src/patches/http-proxy-agent.js.map +1 -0
- package/dist/src/patches/https-proxy-agent.d.ts +6 -0
- package/dist/src/patches/https-proxy-agent.js +8 -0
- package/dist/src/patches/https-proxy-agent.js.map +1 -0
- package/dist/src/services/BuiltinCommandLoader.js +5 -1
- package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
- package/dist/src/services/BuiltinCommandLoader.test.js +6 -1
- package/dist/src/services/BuiltinCommandLoader.test.js.map +1 -1
- package/dist/src/services/FileCommandLoader.d.ts +21 -0
- package/dist/src/services/FileCommandLoader.js +58 -6
- package/dist/src/services/FileCommandLoader.js.map +1 -1
- package/dist/src/services/FileCommandLoader.test.js +27 -1
- package/dist/src/services/FileCommandLoader.test.js.map +1 -1
- package/dist/src/test-utils/mockCommandContext.js +6 -1
- package/dist/src/test-utils/mockCommandContext.js.map +1 -1
- package/dist/src/test-utils/mockConfig.js +0 -3
- package/dist/src/test-utils/mockConfig.js.map +1 -1
- package/dist/src/test-utils/render.js +1 -0
- package/dist/src/test-utils/render.js.map +1 -1
- package/dist/src/test-utils/settings.d.ts +1 -0
- package/dist/src/test-utils/settings.js.map +1 -1
- package/dist/src/ui/AppContainer.js +60 -73
- package/dist/src/ui/AppContainer.js.map +1 -1
- package/dist/src/ui/AppContainer.test.js +101 -1
- package/dist/src/ui/AppContainer.test.js.map +1 -1
- package/dist/src/ui/auth/AuthDialog.js +6 -3
- package/dist/src/ui/auth/AuthDialog.js.map +1 -1
- package/dist/src/ui/auth/AuthDialog.test.js +33 -10
- package/dist/src/ui/auth/AuthDialog.test.js.map +1 -1
- package/dist/src/ui/auth/LoginRestartDialog.d.ts +13 -0
- package/dist/src/ui/auth/{LoginWithGoogleRestartDialog.js → LoginRestartDialog.js} +7 -6
- package/dist/src/ui/auth/LoginRestartDialog.js.map +1 -0
- package/dist/src/ui/auth/LoginRestartDialog.test.d.ts +6 -0
- package/dist/src/ui/auth/{LoginWithGoogleRestartDialog.test.js → LoginRestartDialog.test.js} +13 -8
- package/dist/src/ui/auth/LoginRestartDialog.test.js.map +1 -0
- package/dist/src/ui/auth/useAuth.d.ts +1 -1
- package/dist/src/ui/auth/useAuth.js +2 -2
- package/dist/src/ui/auth/useAuth.js.map +1 -1
- package/dist/src/ui/auth/useAuth.test.js +10 -10
- package/dist/src/ui/auth/useAuth.test.js.map +1 -1
- package/dist/src/ui/commands/agentsCommand.js +19 -2
- package/dist/src/ui/commands/agentsCommand.js.map +1 -1
- package/dist/src/ui/commands/agentsCommand.test.js +34 -3
- package/dist/src/ui/commands/agentsCommand.test.js.map +1 -1
- package/dist/src/ui/commands/bugCommand.js +36 -0
- package/dist/src/ui/commands/bugCommand.js.map +1 -1
- package/dist/src/ui/commands/bugCommand.test.js +106 -1
- package/dist/src/ui/commands/bugCommand.test.js.map +1 -1
- package/dist/src/ui/commands/bugMemoryCommand.d.ts +7 -0
- package/dist/src/ui/commands/bugMemoryCommand.js +62 -0
- package/dist/src/ui/commands/bugMemoryCommand.js.map +1 -0
- package/dist/src/ui/commands/bugMemoryCommand.test.js +100 -0
- package/dist/src/ui/commands/bugMemoryCommand.test.js.map +1 -0
- package/dist/src/ui/commands/commandsCommand.js +52 -4
- package/dist/src/ui/commands/commandsCommand.js.map +1 -1
- package/dist/src/ui/commands/commandsCommand.test.js +75 -2
- package/dist/src/ui/commands/commandsCommand.test.js.map +1 -1
- package/dist/src/ui/commands/compressCommand.js +28 -26
- package/dist/src/ui/commands/compressCommand.js.map +1 -1
- package/dist/src/ui/commands/compressCommand.test.js +5 -0
- package/dist/src/ui/commands/compressCommand.test.js.map +1 -1
- package/dist/src/ui/commands/directoryCommand.js +2 -2
- package/dist/src/ui/commands/directoryCommand.js.map +1 -1
- package/dist/src/ui/commands/directoryCommand.test.js +1 -0
- package/dist/src/ui/commands/directoryCommand.test.js.map +1 -1
- package/dist/src/ui/commands/exportSessionCommand.d.ts +7 -0
- package/dist/src/ui/commands/exportSessionCommand.js +74 -0
- package/dist/src/ui/commands/exportSessionCommand.js.map +1 -0
- package/dist/src/ui/commands/exportSessionCommand.test.js +100 -0
- package/dist/src/ui/commands/exportSessionCommand.test.js.map +1 -0
- package/dist/src/ui/commands/extensionsCommand.js +1 -0
- package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
- package/dist/src/ui/commands/extensionsCommand.test.js +4 -0
- package/dist/src/ui/commands/extensionsCommand.test.js.map +1 -1
- package/dist/src/ui/commands/memoryCommand.d.ts +2 -1
- package/dist/src/ui/commands/memoryCommand.js +110 -117
- package/dist/src/ui/commands/memoryCommand.js.map +1 -1
- package/dist/src/ui/commands/memoryCommand.test.js +18 -71
- package/dist/src/ui/commands/memoryCommand.test.js.map +1 -1
- package/dist/src/ui/commands/quitCommand.js +3 -1
- package/dist/src/ui/commands/quitCommand.js.map +1 -1
- package/dist/src/ui/commands/quitCommand.test.js +46 -1
- package/dist/src/ui/commands/quitCommand.test.js.map +1 -1
- package/dist/src/ui/commands/rewindCommand.js.map +1 -1
- package/dist/src/ui/commands/skillsCommand.js +1 -1
- package/dist/src/ui/commands/skillsCommand.js.map +1 -1
- package/dist/src/ui/commands/skillsCommand.test.js +19 -0
- package/dist/src/ui/commands/skillsCommand.test.js.map +1 -1
- package/dist/src/ui/commands/types.d.ts +3 -1
- package/dist/src/ui/commands/types.js.map +1 -1
- package/dist/src/ui/components/AsciiArt.d.ts +6 -6
- package/dist/src/ui/components/AsciiArt.js +6 -6
- package/dist/src/ui/components/AskUserDialog.js +3 -1
- package/dist/src/ui/components/AskUserDialog.js.map +1 -1
- package/dist/src/ui/components/AskUserDialog.test.js +43 -0
- package/dist/src/ui/components/AskUserDialog.test.js.map +1 -1
- package/dist/src/ui/components/Composer.js +1 -1
- package/dist/src/ui/components/Composer.js.map +1 -1
- package/dist/src/ui/components/DialogManager.js +4 -0
- package/dist/src/ui/components/DialogManager.js.map +1 -1
- package/dist/src/ui/components/EditorSettingsDialog.js +3 -6
- package/dist/src/ui/components/EditorSettingsDialog.js.map +1 -1
- package/dist/src/ui/components/Footer.js +6 -0
- package/dist/src/ui/components/Footer.js.map +1 -1
- package/dist/src/ui/components/FooterConfigDialog.js +1 -0
- package/dist/src/ui/components/FooterConfigDialog.js.map +1 -1
- package/dist/src/ui/components/FooterConfigDialog.test.js +1 -1
- package/dist/src/ui/components/FooterConfigDialog.test.js.map +1 -1
- package/dist/src/ui/components/HistoryItemDisplay.js +3 -1
- package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
- package/dist/src/ui/components/HistoryItemDisplay.test.js +15 -0
- package/dist/src/ui/components/HistoryItemDisplay.test.js.map +1 -1
- package/dist/src/ui/components/{SkillInboxDialog.d.ts → InboxDialog.d.ts} +3 -2
- package/dist/src/ui/components/InboxDialog.js +756 -0
- package/dist/src/ui/components/InboxDialog.js.map +1 -0
- package/dist/src/ui/components/InboxDialog.test.d.ts +6 -0
- package/dist/src/ui/components/InboxDialog.test.js +824 -0
- package/dist/src/ui/components/InboxDialog.test.js.map +1 -0
- package/dist/src/ui/components/InputPrompt.d.ts +3 -0
- package/dist/src/ui/components/InputPrompt.js +35 -17
- package/dist/src/ui/components/InputPrompt.js.map +1 -1
- package/dist/src/ui/components/InputPrompt.test.js +95 -46
- package/dist/src/ui/components/InputPrompt.test.js.map +1 -1
- package/dist/src/ui/components/ListeningIndicator.d.ts +10 -0
- package/dist/src/ui/components/ListeningIndicator.js +30 -0
- package/dist/src/ui/components/ListeningIndicator.js.map +1 -0
- package/dist/src/ui/components/MainContent.test.js +23 -3
- package/dist/src/ui/components/MainContent.test.js.map +1 -1
- package/dist/src/ui/components/ModelDialog.js +32 -37
- package/dist/src/ui/components/ModelDialog.js.map +1 -1
- package/dist/src/ui/components/ModelDialog.test.js +30 -27
- package/dist/src/ui/components/ModelDialog.test.js.map +1 -1
- package/dist/src/ui/components/ModelStatsDisplay.js +1 -1
- package/dist/src/ui/components/ModelStatsDisplay.js.map +1 -1
- package/dist/src/ui/components/ModelStatsDisplay.test.js +41 -0
- package/dist/src/ui/components/ModelStatsDisplay.test.js.map +1 -1
- package/dist/src/ui/components/SessionBrowser.js +7 -0
- package/dist/src/ui/components/SessionBrowser.js.map +1 -1
- package/dist/src/ui/components/SessionSummaryDisplay.js +9 -4
- package/dist/src/ui/components/SessionSummaryDisplay.js.map +1 -1
- package/dist/src/ui/components/SessionSummaryDisplay.test.js +12 -23
- package/dist/src/ui/components/SessionSummaryDisplay.test.js.map +1 -1
- package/dist/src/ui/components/SettingsDialog.js +37 -17
- package/dist/src/ui/components/SettingsDialog.js.map +1 -1
- package/dist/src/ui/components/SettingsDialog.test.js +83 -1
- package/dist/src/ui/components/SettingsDialog.test.js.map +1 -1
- package/dist/src/ui/components/StatsDisplay.js +2 -2
- package/dist/src/ui/components/StatsDisplay.js.map +1 -1
- package/dist/src/ui/components/StatsDisplay.test.js +24 -0
- package/dist/src/ui/components/StatsDisplay.test.js.map +1 -1
- package/dist/src/ui/components/ThemeDialog.constants.d.ts +26 -0
- package/dist/src/ui/components/ThemeDialog.constants.js +27 -0
- package/dist/src/ui/components/ThemeDialog.constants.js.map +1 -0
- package/dist/src/ui/components/ThemeDialog.js +5 -15
- package/dist/src/ui/components/ThemeDialog.js.map +1 -1
- package/dist/src/ui/components/ToolConfirmationQueue.test.js +1 -1
- package/dist/src/ui/components/ToolConfirmationQueue.test.js.map +1 -1
- package/dist/src/ui/components/VoiceModelDialog.js +7 -2
- package/dist/src/ui/components/VoiceModelDialog.js.map +1 -1
- package/dist/src/ui/components/VoiceModelDialog.test.d.ts +6 -0
- package/dist/src/ui/components/VoiceModelDialog.test.js +68 -0
- package/dist/src/ui/components/VoiceModelDialog.test.js.map +1 -0
- package/dist/src/ui/components/messages/ExportSessionMessage.d.ts +11 -0
- package/dist/src/ui/components/messages/ExportSessionMessage.js +15 -0
- package/dist/src/ui/components/messages/ExportSessionMessage.js.map +1 -0
- package/dist/src/ui/components/messages/ExportSessionMessage.test.d.ts +6 -0
- package/dist/src/ui/components/messages/ExportSessionMessage.test.js +31 -0
- package/dist/src/ui/components/messages/ExportSessionMessage.test.js.map +1 -0
- package/dist/src/ui/components/messages/ShellToolMessage.js +6 -2
- package/dist/src/ui/components/messages/ShellToolMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ShellToolMessage.test.js +33 -0
- package/dist/src/ui/components/messages/ShellToolMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/SubagentGroupDisplay.js +13 -13
- package/dist/src/ui/components/messages/SubagentGroupDisplay.js.map +1 -1
- package/dist/src/ui/components/messages/SubagentGroupDisplay.test.js +5 -5
- package/dist/src/ui/components/messages/SubagentGroupDisplay.test.js.map +1 -1
- package/dist/src/ui/components/messages/SubagentHistoryMessage.test.js +4 -3
- package/dist/src/ui/components/messages/SubagentHistoryMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/SubagentProgressDisplay.d.ts +1 -1
- package/dist/src/ui/components/messages/SubagentProgressDisplay.js +7 -6
- package/dist/src/ui/components/messages/SubagentProgressDisplay.js.map +1 -1
- package/dist/src/ui/components/messages/SubagentProgressDisplay.test.js +10 -9
- package/dist/src/ui/components/messages/SubagentProgressDisplay.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js +3 -9
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js +60 -0
- package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupDisplay.d.ts +13 -0
- package/dist/src/ui/components/messages/ToolGroupDisplay.js +78 -0
- package/dist/src/ui/components/messages/ToolGroupDisplay.js.map +1 -0
- package/dist/src/ui/components/messages/ToolGroupDisplay.test.d.ts +6 -0
- package/dist/src/ui/components/messages/ToolGroupDisplay.test.js +210 -0
- package/dist/src/ui/components/messages/ToolGroupDisplay.test.js.map +1 -0
- package/dist/src/ui/components/messages/ToolGroupMessage.js +4 -2
- package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js +28 -0
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessageRegression.test.js +3 -3
- package/dist/src/ui/components/messages/ToolGroupMessageRegression.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessage.js +6 -2
- package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolShared.d.ts +1 -0
- package/dist/src/ui/components/messages/ToolShared.js +5 -3
- package/dist/src/ui/components/messages/ToolShared.js.map +1 -1
- package/dist/src/ui/components/messages/ToolShared.test.js +18 -1
- package/dist/src/ui/components/messages/ToolShared.test.js.map +1 -1
- package/dist/src/ui/components/shared/BaseSettingsDialog.d.ts +6 -1
- package/dist/src/ui/components/shared/BaseSettingsDialog.js +8 -8
- package/dist/src/ui/components/shared/BaseSettingsDialog.js.map +1 -1
- package/dist/src/ui/components/shared/performance.test.js +9 -0
- package/dist/src/ui/components/shared/performance.test.js.map +1 -1
- package/dist/src/ui/components/shared/text-buffer.js +22 -5
- package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
- package/dist/src/ui/components/shared/text-buffer.test.js +211 -0
- package/dist/src/ui/components/shared/text-buffer.test.js.map +1 -1
- package/dist/src/ui/constants/tips.js +0 -1
- package/dist/src/ui/constants/tips.js.map +1 -1
- package/dist/src/ui/contexts/UIActionsContext.d.ts +1 -0
- package/dist/src/ui/contexts/UIActionsContext.js.map +1 -1
- package/dist/src/ui/contexts/UIStateContext.d.ts +2 -0
- package/dist/src/ui/contexts/UIStateContext.js.map +1 -1
- package/dist/src/ui/hooks/atCommandProcessor.js +78 -69
- package/dist/src/ui/hooks/atCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/atCommandProcessor.test.js +128 -18
- package/dist/src/ui/hooks/atCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/slashCommandProcessor.js +13 -0
- package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/slashCommandProcessor.test.js +85 -0
- package/dist/src/ui/hooks/slashCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/useAgentStream.d.ts +2 -2
- package/dist/src/ui/hooks/useAgentStream.js +63 -30
- package/dist/src/ui/hooks/useAgentStream.js.map +1 -1
- package/dist/src/ui/hooks/useAgentStream.test.js +1 -1
- package/dist/src/ui/hooks/useAgentStream.test.js.map +1 -1
- package/dist/src/ui/hooks/useAtCompletion.js +0 -2
- package/dist/src/ui/hooks/useAtCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.d.ts +2 -2
- package/dist/src/ui/hooks/useGeminiStream.js +48 -29
- package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.test.js +44 -82
- package/dist/src/ui/hooks/useGeminiStream.test.js.map +1 -1
- package/dist/src/ui/hooks/useGitBranchName.js +29 -16
- package/dist/src/ui/hooks/useGitBranchName.js.map +1 -1
- package/dist/src/ui/hooks/useGitBranchName.test.js +102 -51
- package/dist/src/ui/hooks/useGitBranchName.test.js.map +1 -1
- package/dist/src/ui/hooks/useIncludeDirsTrust.js +2 -2
- package/dist/src/ui/hooks/useIncludeDirsTrust.js.map +1 -1
- package/dist/src/ui/hooks/useIncludeDirsTrust.test.js +2 -0
- package/dist/src/ui/hooks/useIncludeDirsTrust.test.js.map +1 -1
- package/dist/src/ui/hooks/useMessageQueue.d.ts +2 -1
- package/dist/src/ui/hooks/useMessageQueue.js +3 -1
- package/dist/src/ui/hooks/useMessageQueue.js.map +1 -1
- package/dist/src/ui/hooks/useMessageQueue.test.js +38 -0
- package/dist/src/ui/hooks/useMessageQueue.test.js.map +1 -1
- package/dist/src/ui/hooks/useSessionBrowser.d.ts +3 -3
- package/dist/src/ui/hooks/useSessionBrowser.js.map +1 -1
- package/dist/src/ui/hooks/useSessionBrowser.test.js +44 -38
- package/dist/src/ui/hooks/useSessionBrowser.test.js.map +1 -1
- package/dist/src/ui/hooks/useSessionResume.d.ts +3 -3
- package/dist/src/ui/hooks/useSessionResume.js.map +1 -1
- package/dist/src/ui/hooks/useSessionResume.test.js +6 -4
- package/dist/src/ui/hooks/useSessionResume.test.js.map +1 -1
- package/dist/src/ui/hooks/useSuspend.d.ts +1 -3
- package/dist/src/ui/hooks/useSuspend.js +3 -17
- package/dist/src/ui/hooks/useSuspend.js.map +1 -1
- package/dist/src/ui/hooks/useSuspend.test.js +0 -14
- package/dist/src/ui/hooks/useSuspend.test.js.map +1 -1
- package/dist/src/ui/hooks/useToolScheduler.test.js +6 -6
- package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
- package/dist/src/ui/hooks/useVoiceMode.js +25 -19
- package/dist/src/ui/hooks/useVoiceMode.js.map +1 -1
- package/dist/src/ui/hooks/vim-passthrough.test.js +10 -0
- package/dist/src/ui/hooks/vim-passthrough.test.js.map +1 -1
- package/dist/src/ui/hooks/vim.js +8 -0
- package/dist/src/ui/hooks/vim.js.map +1 -1
- package/dist/src/ui/hooks/vim.test.js +61 -0
- package/dist/src/ui/hooks/vim.test.js.map +1 -1
- package/dist/src/ui/key/keyBindings.d.ts +2 -0
- package/dist/src/ui/key/keyBindings.js +26 -9
- package/dist/src/ui/key/keyBindings.js.map +1 -1
- package/dist/src/ui/key/keyBindings.test.js +24 -0
- package/dist/src/ui/key/keyBindings.test.js.map +1 -1
- package/dist/src/ui/key/keyMatchers.test.js +26 -5
- package/dist/src/ui/key/keyMatchers.test.js.map +1 -1
- package/dist/src/ui/themes/theme-manager.js +0 -2
- package/dist/src/ui/themes/theme-manager.js.map +1 -1
- package/dist/src/ui/types.d.ts +23 -2
- package/dist/src/ui/types.js +3 -2
- package/dist/src/ui/types.js.map +1 -1
- package/dist/src/ui/utils/TableRenderer.js +6 -6
- package/dist/src/ui/utils/TableRenderer.js.map +1 -1
- package/dist/src/ui/utils/TableRenderer.test.js +10 -0
- package/dist/src/ui/utils/TableRenderer.test.js.map +1 -1
- package/dist/src/ui/utils/directoryUtils.test.js +0 -5
- package/dist/src/ui/utils/directoryUtils.test.js.map +1 -1
- package/dist/src/ui/utils/editorUtils.d.ts +2 -1
- package/dist/src/ui/utils/editorUtils.js +75 -28
- package/dist/src/ui/utils/editorUtils.js.map +1 -1
- package/dist/src/ui/utils/latexToUnicode.d.ts +21 -0
- package/dist/src/ui/utils/latexToUnicode.js +538 -0
- package/dist/src/ui/utils/latexToUnicode.js.map +1 -0
- package/dist/src/ui/utils/latexToUnicode.test.d.ts +6 -0
- package/dist/src/ui/utils/latexToUnicode.test.js +222 -0
- package/dist/src/ui/utils/latexToUnicode.test.js.map +1 -0
- package/dist/src/ui/utils/markdownParsingUtils.d.ts +1 -5
- package/dist/src/ui/utils/markdownParsingUtils.js +36 -1
- package/dist/src/ui/utils/markdownParsingUtils.js.map +1 -1
- package/dist/src/ui/utils/markdownParsingUtils.test.js +35 -0
- package/dist/src/ui/utils/markdownParsingUtils.test.js.map +1 -1
- package/dist/src/ui/utils/memorySnapshot.d.ts +19 -0
- package/dist/src/ui/utils/memorySnapshot.js +28 -0
- package/dist/src/ui/utils/memorySnapshot.js.map +1 -0
- package/dist/src/ui/utils/memorySnapshot.test.d.ts +6 -0
- package/dist/src/ui/utils/memorySnapshot.test.js +62 -0
- package/dist/src/ui/utils/memorySnapshot.test.js.map +1 -0
- package/dist/src/ui/utils/updateCheck.js +11 -2
- package/dist/src/ui/utils/updateCheck.js.map +1 -1
- package/dist/src/ui/utils/updateCheck.test.js +73 -0
- package/dist/src/ui/utils/updateCheck.test.js.map +1 -1
- package/dist/src/utils/commands.d.ts +1 -1
- package/dist/src/utils/commands.js +1 -1
- package/dist/src/utils/commands.test.js +14 -14
- package/dist/src/utils/commands.test.js.map +1 -1
- package/dist/src/utils/envVarResolver.js +10 -7
- package/dist/src/utils/envVarResolver.js.map +1 -1
- package/dist/src/utils/gitUtils.js +1 -2
- package/dist/src/utils/gitUtils.js.map +1 -1
- package/dist/src/utils/handleAutoUpdate.d.ts +1 -1
- package/dist/src/utils/handleAutoUpdate.js +15 -3
- package/dist/src/utils/handleAutoUpdate.js.map +1 -1
- package/dist/src/utils/handleAutoUpdate.test.js +45 -16
- package/dist/src/utils/handleAutoUpdate.test.js.map +1 -1
- package/dist/src/utils/installationInfo.d.ts +1 -0
- package/dist/src/utils/installationInfo.js +16 -1
- package/dist/src/utils/installationInfo.js.map +1 -1
- package/dist/src/utils/installationInfo.test.js +16 -0
- package/dist/src/utils/installationInfo.test.js.map +1 -1
- package/dist/src/utils/jsonoutput.js +0 -2
- package/dist/src/utils/jsonoutput.js.map +1 -1
- package/dist/src/utils/processUtils.d.ts +28 -0
- package/dist/src/utils/processUtils.js +71 -0
- package/dist/src/utils/processUtils.js.map +1 -1
- package/dist/src/utils/processUtils.test.js +122 -1
- package/dist/src/utils/processUtils.test.js.map +1 -1
- package/dist/src/utils/readStdin.js +22 -4
- package/dist/src/utils/readStdin.js.map +1 -1
- package/dist/src/utils/readStdin.test.js +32 -0
- package/dist/src/utils/readStdin.test.js.map +1 -1
- package/dist/src/utils/relaunch.js +6 -13
- package/dist/src/utils/relaunch.js.map +1 -1
- package/dist/src/utils/relaunch.test.js +82 -86
- package/dist/src/utils/relaunch.test.js.map +1 -1
- package/dist/src/utils/sandbox.js +34 -24
- package/dist/src/utils/sandbox.js.map +1 -1
- package/dist/src/utils/sandbox.test.js +108 -9
- package/dist/src/utils/sandbox.test.js.map +1 -1
- package/dist/src/utils/sandboxUtils.js +12 -7
- package/dist/src/utils/sandboxUtils.js.map +1 -1
- package/dist/src/utils/sandboxUtils.test.js +68 -0
- package/dist/src/utils/sandboxUtils.test.js.map +1 -1
- package/dist/src/utils/sessionCleanup.js +49 -14
- package/dist/src/utils/sessionCleanup.js.map +1 -1
- package/dist/src/utils/sessionCleanup.test.js +63 -0
- package/dist/src/utils/sessionCleanup.test.js.map +1 -1
- package/dist/src/utils/sessionUtils.js +22 -7
- package/dist/src/utils/sessionUtils.js.map +1 -1
- package/dist/src/utils/sessionUtils.test.js +99 -0
- package/dist/src/utils/sessionUtils.test.js.map +1 -1
- package/dist/src/utils/sessions.js +2 -4
- package/dist/src/utils/sessions.js.map +1 -1
- package/dist/src/utils/sessions.test.js +9 -12
- package/dist/src/utils/sessions.test.js.map +1 -1
- package/dist/src/utils/userStartupWarnings.js +4 -3
- package/dist/src/utils/userStartupWarnings.js.map +1 -1
- package/dist/src/utils/userStartupWarnings.test.js +40 -3
- package/dist/src/utils/userStartupWarnings.test.js.map +1 -1
- package/dist/src/validateNonInterActiveAuth.js +1 -1
- package/dist/src/validateNonInterActiveAuth.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -4
- package/dist/src/acp/acpClient.d.ts +0 -56
- package/dist/src/acp/acpClient.js.map +0 -1
- package/dist/src/acp/acpClient.test.js +0 -1816
- package/dist/src/acp/acpClient.test.js.map +0 -1
- package/dist/src/acp/commandHandler.js.map +0 -1
- package/dist/src/acp/commandHandler.test.js.map +0 -1
- package/dist/src/acp/fileSystemService.js.map +0 -1
- package/dist/src/acp/fileSystemService.test.js.map +0 -1
- package/dist/src/ui/auth/LoginWithGoogleRestartDialog.d.ts +0 -12
- package/dist/src/ui/auth/LoginWithGoogleRestartDialog.js.map +0 -1
- package/dist/src/ui/auth/LoginWithGoogleRestartDialog.test.js.map +0 -1
- package/dist/src/ui/components/SkillInboxDialog.js +0 -420
- package/dist/src/ui/components/SkillInboxDialog.js.map +0 -1
- package/dist/src/ui/components/SkillInboxDialog.test.js +0 -467
- package/dist/src/ui/components/SkillInboxDialog.test.js.map +0 -1
- /package/dist/src/acp/{commandHandler.test.d.ts → acpCommandHandler.test.d.ts} +0 -0
- /package/dist/src/{ui/components/SkillInboxDialog.test.d.ts → acp/acpFileSystemService.test.d.ts} +0 -0
- /package/dist/src/{acp/acpClient.test.d.ts → config/mutual-exclusivity.test.d.ts} +0 -0
- /package/dist/src/{acp/fileSystemService.test.d.ts → ui/commands/bugMemoryCommand.test.d.ts} +0 -0
- /package/dist/src/ui/{auth/LoginWithGoogleRestartDialog.test.d.ts → commands/exportSessionCommand.test.d.ts} +0 -0
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* Copyright 2025 Google LLC
|
|
4
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
5
5
|
*/
|
|
6
|
-
import { ToolErrorType, GeminiEventType, OutputFormat, uiTelemetryService, FatalInputError, CoreEvent, CoreToolCallStatus, } from '@google/gemini-cli-core';
|
|
6
|
+
import { ToolErrorType, GeminiEventType, OutputFormat, uiTelemetryService, FatalInputError, CoreEvent, CoreToolCallStatus, JsonStreamEventType, } from '@google/gemini-cli-core';
|
|
7
7
|
import { runNonInteractive } from './nonInteractiveCliAgentSession.js';
|
|
8
8
|
import { describe, it, expect, beforeEach, afterEach, vi, } from 'vitest';
|
|
9
9
|
// Mock core modules
|
|
@@ -197,7 +197,7 @@ describe('runNonInteractive', () => {
|
|
|
197
197
|
input: 'Test input',
|
|
198
198
|
prompt_id: 'prompt-id-1',
|
|
199
199
|
});
|
|
200
|
-
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Test input' }], expect.any(AbortSignal), 'prompt-id-1', undefined,
|
|
200
|
+
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Test input' }], expect.any(AbortSignal), 'prompt-id-1', undefined, 'Test input');
|
|
201
201
|
expect(getWrittenOutput()).toBe('Hello World\n');
|
|
202
202
|
// Note: Telemetry shutdown is now handled in runExitCleanup() in cleanup.ts
|
|
203
203
|
// so we no longer expect shutdownTelemetry to be called directly here
|
|
@@ -325,7 +325,7 @@ describe('runNonInteractive', () => {
|
|
|
325
325
|
});
|
|
326
326
|
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledTimes(2);
|
|
327
327
|
expect(mockSchedulerSchedule).toHaveBeenCalledWith([expect.objectContaining({ name: 'testTool' })], expect.any(AbortSignal));
|
|
328
|
-
expect(mockGeminiClient.sendMessageStream).toHaveBeenNthCalledWith(2, [{ text: 'Tool response' }], expect.any(AbortSignal), 'prompt-id-2', undefined,
|
|
328
|
+
expect(mockGeminiClient.sendMessageStream).toHaveBeenNthCalledWith(2, [{ text: 'Tool response' }], expect.any(AbortSignal), 'prompt-id-2', undefined, undefined);
|
|
329
329
|
expect(getWrittenOutput()).toBe('Final answer\n');
|
|
330
330
|
});
|
|
331
331
|
it('should write a single newline between sequential text outputs from the model', async () => {
|
|
@@ -464,7 +464,7 @@ describe('runNonInteractive', () => {
|
|
|
464
464
|
},
|
|
465
465
|
},
|
|
466
466
|
},
|
|
467
|
-
], expect.any(AbortSignal), 'prompt-id-3', undefined,
|
|
467
|
+
], expect.any(AbortSignal), 'prompt-id-3', undefined, undefined);
|
|
468
468
|
expect(getWrittenOutput()).toBe('Sorry, let me try again.\n');
|
|
469
469
|
});
|
|
470
470
|
it('should exit with error if sendMessageStream throws initially', async () => {
|
|
@@ -576,7 +576,7 @@ describe('runNonInteractive', () => {
|
|
|
576
576
|
prompt_id: 'prompt-id-7',
|
|
577
577
|
});
|
|
578
578
|
// 5. Assert that sendMessageStream was called with the PROCESSED parts, not the raw input
|
|
579
|
-
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith(processedParts, expect.any(AbortSignal), 'prompt-id-7', undefined,
|
|
579
|
+
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith(processedParts, expect.any(AbortSignal), 'prompt-id-7', undefined, rawInput);
|
|
580
580
|
// 6. Assert the final output is correct
|
|
581
581
|
expect(getWrittenOutput()).toBe('Summary complete.\n');
|
|
582
582
|
});
|
|
@@ -590,14 +590,14 @@ describe('runNonInteractive', () => {
|
|
|
590
590
|
];
|
|
591
591
|
mockGeminiClient.sendMessageStream.mockReturnValue(createStreamFromEvents(events));
|
|
592
592
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
593
|
-
vi.
|
|
593
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
594
594
|
await runNonInteractive({
|
|
595
595
|
config: mockConfig,
|
|
596
596
|
settings: mockSettings,
|
|
597
597
|
input: 'Test input',
|
|
598
598
|
prompt_id: 'prompt-id-1',
|
|
599
599
|
});
|
|
600
|
-
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Test input' }], expect.any(AbortSignal), 'prompt-id-1', undefined,
|
|
600
|
+
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Test input' }], expect.any(AbortSignal), 'prompt-id-1', undefined, 'Test input');
|
|
601
601
|
expect(processStdoutSpy).toHaveBeenCalledWith(JSON.stringify({
|
|
602
602
|
session_id: 'test-session-id',
|
|
603
603
|
response: 'Hello World',
|
|
@@ -658,7 +658,7 @@ describe('runNonInteractive', () => {
|
|
|
658
658
|
.mockReturnValueOnce(createStreamFromEvents(firstCallEvents))
|
|
659
659
|
.mockReturnValueOnce(createStreamFromEvents(secondCallEvents));
|
|
660
660
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
661
|
-
vi.
|
|
661
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
662
662
|
await runNonInteractive({
|
|
663
663
|
config: mockConfig,
|
|
664
664
|
settings: mockSettings,
|
|
@@ -717,7 +717,7 @@ describe('runNonInteractive', () => {
|
|
|
717
717
|
},
|
|
718
718
|
]));
|
|
719
719
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
720
|
-
vi.
|
|
720
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
721
721
|
await runNonInteractive({
|
|
722
722
|
config: mockConfig,
|
|
723
723
|
settings: mockSettings,
|
|
@@ -740,14 +740,14 @@ describe('runNonInteractive', () => {
|
|
|
740
740
|
];
|
|
741
741
|
mockGeminiClient.sendMessageStream.mockReturnValue(createStreamFromEvents(events));
|
|
742
742
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
743
|
-
vi.
|
|
743
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
744
744
|
await runNonInteractive({
|
|
745
745
|
config: mockConfig,
|
|
746
746
|
settings: mockSettings,
|
|
747
747
|
input: 'Empty response test',
|
|
748
748
|
prompt_id: 'prompt-id-empty',
|
|
749
749
|
});
|
|
750
|
-
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Empty response test' }], expect.any(AbortSignal), 'prompt-id-empty', undefined,
|
|
750
|
+
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Empty response test' }], expect.any(AbortSignal), 'prompt-id-empty', undefined, 'Empty response test');
|
|
751
751
|
// This should output JSON with empty response but include stats
|
|
752
752
|
expect(processStdoutSpy).toHaveBeenCalledWith(JSON.stringify({
|
|
753
753
|
session_id: 'test-session-id',
|
|
@@ -842,7 +842,7 @@ describe('runNonInteractive', () => {
|
|
|
842
842
|
prompt_id: 'prompt-id-slash',
|
|
843
843
|
});
|
|
844
844
|
// Ensure the prompt sent to the model is from the command, not the raw input
|
|
845
|
-
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Prompt from command' }], expect.any(AbortSignal), 'prompt-id-slash', undefined,
|
|
845
|
+
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Prompt from command' }], expect.any(AbortSignal), 'prompt-id-slash', undefined, '/testcommand');
|
|
846
846
|
expect(getWrittenOutput()).toBe('Response from command\n');
|
|
847
847
|
});
|
|
848
848
|
it('should handle slash commands', async () => {
|
|
@@ -864,7 +864,7 @@ describe('runNonInteractive', () => {
|
|
|
864
864
|
prompt_id: 'prompt-id-slash',
|
|
865
865
|
});
|
|
866
866
|
expect(handleSlashCommandSpy).toHaveBeenCalledWith('/help', expect.any(AbortController), mockConfig, mockSettings);
|
|
867
|
-
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Slash command output' }], expect.any(AbortSignal), 'prompt-id-slash', undefined,
|
|
867
|
+
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: 'Slash command output' }], expect.any(AbortSignal), 'prompt-id-slash', undefined, '/help');
|
|
868
868
|
expect(getWrittenOutput()).toBe('Response to slash command\n');
|
|
869
869
|
handleSlashCommandSpy.mockRestore();
|
|
870
870
|
});
|
|
@@ -1029,7 +1029,7 @@ describe('runNonInteractive', () => {
|
|
|
1029
1029
|
prompt_id: 'prompt-id-unknown',
|
|
1030
1030
|
});
|
|
1031
1031
|
// Ensure the raw input is sent to the model
|
|
1032
|
-
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: '/unknowncommand' }], expect.any(AbortSignal), 'prompt-id-unknown', undefined,
|
|
1032
|
+
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledWith([{ text: '/unknowncommand' }], expect.any(AbortSignal), 'prompt-id-unknown', undefined, '/unknowncommand');
|
|
1033
1033
|
expect(getWrittenOutput()).toBe('Response to unknown\n');
|
|
1034
1034
|
});
|
|
1035
1035
|
it('should throw for unhandled command result types', async () => {
|
|
@@ -1266,7 +1266,7 @@ describe('runNonInteractive', () => {
|
|
|
1266
1266
|
});
|
|
1267
1267
|
it('should emit appropriate events for streaming JSON output', async () => {
|
|
1268
1268
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.STREAM_JSON);
|
|
1269
|
-
vi.
|
|
1269
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1270
1270
|
const toolCallEvent = {
|
|
1271
1271
|
type: GeminiEventType.ToolCallRequest,
|
|
1272
1272
|
value: {
|
|
@@ -1393,7 +1393,7 @@ describe('runNonInteractive', () => {
|
|
|
1393
1393
|
},
|
|
1394
1394
|
])('should emit appropriate error event in streaming JSON mode: $name', async ({ events, input, promptId }) => {
|
|
1395
1395
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.STREAM_JSON);
|
|
1396
|
-
vi.
|
|
1396
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1397
1397
|
const streamEvents = [
|
|
1398
1398
|
...events,
|
|
1399
1399
|
{
|
|
@@ -1419,6 +1419,40 @@ describe('runNonInteractive', () => {
|
|
|
1419
1419
|
.replace(/"duration_ms":\d+/g, '"duration_ms":<DURATION>');
|
|
1420
1420
|
expect(sanitizedOutput).toMatchSnapshot();
|
|
1421
1421
|
});
|
|
1422
|
+
it.each([
|
|
1423
|
+
{
|
|
1424
|
+
name: 'loop detected',
|
|
1425
|
+
events: [
|
|
1426
|
+
{ type: GeminiEventType.LoopDetected },
|
|
1427
|
+
],
|
|
1428
|
+
expectedWarning: 'Loop detected, stopping execution',
|
|
1429
|
+
},
|
|
1430
|
+
])('should include warning in JSON mode for: $name', async ({ events, expectedWarning }) => {
|
|
1431
|
+
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
1432
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1433
|
+
const streamEvents = [
|
|
1434
|
+
...events,
|
|
1435
|
+
{
|
|
1436
|
+
type: GeminiEventType.Finished,
|
|
1437
|
+
value: { reason: undefined, usageMetadata: { totalTokenCount: 0 } },
|
|
1438
|
+
},
|
|
1439
|
+
];
|
|
1440
|
+
mockGeminiClient.sendMessageStream.mockReturnValue(createStreamFromEvents(streamEvents));
|
|
1441
|
+
try {
|
|
1442
|
+
await runNonInteractive({
|
|
1443
|
+
config: mockConfig,
|
|
1444
|
+
settings: mockSettings,
|
|
1445
|
+
input: 'test',
|
|
1446
|
+
prompt_id: 'test',
|
|
1447
|
+
});
|
|
1448
|
+
}
|
|
1449
|
+
catch {
|
|
1450
|
+
// Expected exit for max turns
|
|
1451
|
+
}
|
|
1452
|
+
const output = JSON.parse(getWrittenOutput());
|
|
1453
|
+
expect(output.warnings).toBeDefined();
|
|
1454
|
+
expect(output.warnings[0]).toContain(expectedWarning);
|
|
1455
|
+
});
|
|
1422
1456
|
it('should log error when tool recording fails', async () => {
|
|
1423
1457
|
const toolCallEvent = {
|
|
1424
1458
|
type: GeminiEventType.ToolCallRequest,
|
|
@@ -1536,7 +1570,7 @@ describe('runNonInteractive', () => {
|
|
|
1536
1570
|
});
|
|
1537
1571
|
it('should write JSON output when a tool call returns STOP_EXECUTION error', async () => {
|
|
1538
1572
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
1539
|
-
vi.
|
|
1573
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1540
1574
|
const toolCallEvent = {
|
|
1541
1575
|
type: GeminiEventType.ToolCallRequest,
|
|
1542
1576
|
value: {
|
|
@@ -1581,7 +1615,7 @@ describe('runNonInteractive', () => {
|
|
|
1581
1615
|
});
|
|
1582
1616
|
it('should emit result event when a tool call returns STOP_EXECUTION error in streaming JSON mode', async () => {
|
|
1583
1617
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.STREAM_JSON);
|
|
1584
|
-
vi.
|
|
1618
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1585
1619
|
const toolCallEvent = {
|
|
1586
1620
|
type: GeminiEventType.ToolCallRequest,
|
|
1587
1621
|
value: {
|
|
@@ -1637,6 +1671,50 @@ describe('runNonInteractive', () => {
|
|
|
1637
1671
|
expect(processStderrSpy).toHaveBeenCalledWith('Agent execution stopped: Stopped by hook\n');
|
|
1638
1672
|
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledTimes(1);
|
|
1639
1673
|
});
|
|
1674
|
+
it('should write JSON output when AgentExecutionStopped event occurs', async () => {
|
|
1675
|
+
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
1676
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1677
|
+
const events = [
|
|
1678
|
+
{ type: GeminiEventType.Content, value: 'Partial content' },
|
|
1679
|
+
{
|
|
1680
|
+
type: GeminiEventType.AgentExecutionStopped,
|
|
1681
|
+
value: { reason: 'Stopped by hook' },
|
|
1682
|
+
},
|
|
1683
|
+
];
|
|
1684
|
+
mockGeminiClient.sendMessageStream.mockReturnValue(createStreamFromEvents(events));
|
|
1685
|
+
await runNonInteractive({
|
|
1686
|
+
config: mockConfig,
|
|
1687
|
+
settings: mockSettings,
|
|
1688
|
+
input: 'test stop',
|
|
1689
|
+
prompt_id: 'prompt-id-stop-json',
|
|
1690
|
+
});
|
|
1691
|
+
expect(processStdoutSpy).toHaveBeenCalledWith(JSON.stringify({
|
|
1692
|
+
session_id: 'test-session-id',
|
|
1693
|
+
response: 'Partial content',
|
|
1694
|
+
stats: MOCK_SESSION_METRICS,
|
|
1695
|
+
}, null, 2));
|
|
1696
|
+
});
|
|
1697
|
+
it('should emit result event when AgentExecutionStopped event occurs in streaming JSON mode', async () => {
|
|
1698
|
+
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.STREAM_JSON);
|
|
1699
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1700
|
+
const events = [
|
|
1701
|
+
{ type: GeminiEventType.Content, value: 'Partial content' },
|
|
1702
|
+
{
|
|
1703
|
+
type: GeminiEventType.AgentExecutionStopped,
|
|
1704
|
+
value: { reason: 'Stopped by hook' },
|
|
1705
|
+
},
|
|
1706
|
+
];
|
|
1707
|
+
mockGeminiClient.sendMessageStream.mockReturnValue(createStreamFromEvents(events));
|
|
1708
|
+
await runNonInteractive({
|
|
1709
|
+
config: mockConfig,
|
|
1710
|
+
settings: mockSettings,
|
|
1711
|
+
input: 'test stop',
|
|
1712
|
+
prompt_id: 'prompt-id-stop-stream',
|
|
1713
|
+
});
|
|
1714
|
+
const output = getWrittenOutput();
|
|
1715
|
+
expect(output).toContain('"type":"result"');
|
|
1716
|
+
expect(output).toContain('"status":"success"');
|
|
1717
|
+
});
|
|
1640
1718
|
it('should handle AgentExecutionBlocked event', async () => {
|
|
1641
1719
|
const allEvents = [
|
|
1642
1720
|
{
|
|
@@ -1661,6 +1739,108 @@ describe('runNonInteractive', () => {
|
|
|
1661
1739
|
expect(getWrittenOutput()).toBe('Final answer\n');
|
|
1662
1740
|
expect(mockGeminiClient.sendMessageStream).toHaveBeenCalledTimes(1);
|
|
1663
1741
|
});
|
|
1742
|
+
it('should emit ERROR event in STREAM_JSON mode when AgentExecutionBlocked occurs', async () => {
|
|
1743
|
+
const allEvents = [
|
|
1744
|
+
{
|
|
1745
|
+
type: GeminiEventType.AgentExecutionBlocked,
|
|
1746
|
+
value: { reason: 'Blocked by hook' },
|
|
1747
|
+
},
|
|
1748
|
+
{ type: GeminiEventType.Content, value: 'Final answer' },
|
|
1749
|
+
{
|
|
1750
|
+
type: GeminiEventType.Finished,
|
|
1751
|
+
value: { reason: undefined, usageMetadata: { totalTokenCount: 10 } },
|
|
1752
|
+
},
|
|
1753
|
+
];
|
|
1754
|
+
mockGeminiClient.sendMessageStream.mockReturnValue(createStreamFromEvents(allEvents));
|
|
1755
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1756
|
+
// Setup stream-json format
|
|
1757
|
+
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.STREAM_JSON);
|
|
1758
|
+
await runNonInteractive({
|
|
1759
|
+
config: mockConfig,
|
|
1760
|
+
settings: mockSettings,
|
|
1761
|
+
input: 'test block',
|
|
1762
|
+
prompt_id: 'prompt-id-block',
|
|
1763
|
+
});
|
|
1764
|
+
const calls = processStdoutSpy.mock.calls.map((call) => JSON.parse(call[0]));
|
|
1765
|
+
const errorEvent = calls.find((c) => c.type === JsonStreamEventType.ERROR);
|
|
1766
|
+
expect(errorEvent).toBeDefined();
|
|
1767
|
+
expect(errorEvent.message).toContain('Agent execution blocked: Blocked by hook');
|
|
1768
|
+
expect(errorEvent.severity).toBe('warning');
|
|
1769
|
+
});
|
|
1770
|
+
it('should include warning in JSON mode when AgentExecutionBlocked occurs', async () => {
|
|
1771
|
+
const allEvents = [
|
|
1772
|
+
{
|
|
1773
|
+
type: GeminiEventType.AgentExecutionBlocked,
|
|
1774
|
+
value: { reason: 'Blocked by hook' },
|
|
1775
|
+
},
|
|
1776
|
+
{ type: GeminiEventType.Content, value: 'Final answer' },
|
|
1777
|
+
{
|
|
1778
|
+
type: GeminiEventType.Finished,
|
|
1779
|
+
value: { reason: undefined, usageMetadata: { totalTokenCount: 10 } },
|
|
1780
|
+
},
|
|
1781
|
+
];
|
|
1782
|
+
mockGeminiClient.sendMessageStream.mockReturnValue(createStreamFromEvents(allEvents));
|
|
1783
|
+
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
1784
|
+
await runNonInteractive({
|
|
1785
|
+
config: mockConfig,
|
|
1786
|
+
settings: mockSettings,
|
|
1787
|
+
input: 'test block',
|
|
1788
|
+
prompt_id: 'prompt-id-block',
|
|
1789
|
+
});
|
|
1790
|
+
const output = JSON.parse(getWrittenOutput());
|
|
1791
|
+
expect(output.warnings).toBeDefined();
|
|
1792
|
+
expect(output.warnings).toContain('Agent execution blocked: Blocked by hook');
|
|
1793
|
+
});
|
|
1794
|
+
it('should handle multiple AgentExecutionBlocked events and collect all warnings', async () => {
|
|
1795
|
+
const allEvents = [
|
|
1796
|
+
{
|
|
1797
|
+
type: GeminiEventType.AgentExecutionBlocked,
|
|
1798
|
+
value: { reason: 'Block 1', systemMessage: 'Reason 1' },
|
|
1799
|
+
},
|
|
1800
|
+
{
|
|
1801
|
+
type: GeminiEventType.AgentExecutionBlocked,
|
|
1802
|
+
value: { reason: 'Block 2', systemMessage: 'Reason 2' },
|
|
1803
|
+
},
|
|
1804
|
+
{ type: GeminiEventType.Content, value: 'Final answer' },
|
|
1805
|
+
{
|
|
1806
|
+
type: GeminiEventType.Finished,
|
|
1807
|
+
value: { reason: undefined, usageMetadata: { totalTokenCount: 10 } },
|
|
1808
|
+
},
|
|
1809
|
+
];
|
|
1810
|
+
mockGeminiClient.sendMessageStream.mockImplementation(() => createStreamFromEvents(allEvents));
|
|
1811
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1812
|
+
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
1813
|
+
await runNonInteractive({
|
|
1814
|
+
config: mockConfig,
|
|
1815
|
+
settings: mockSettings,
|
|
1816
|
+
input: 'test',
|
|
1817
|
+
prompt_id: 'test',
|
|
1818
|
+
});
|
|
1819
|
+
const output = JSON.parse(getWrittenOutput());
|
|
1820
|
+
expect(output.warnings).toHaveLength(2);
|
|
1821
|
+
expect(output.warnings).toContain('Agent execution blocked: Reason 1');
|
|
1822
|
+
expect(output.warnings).toContain('Agent execution blocked: Reason 2');
|
|
1823
|
+
});
|
|
1824
|
+
it('should not include warnings field in JSON output if no blocks occur', async () => {
|
|
1825
|
+
const allEvents = [
|
|
1826
|
+
{ type: GeminiEventType.Content, value: 'Clean answer' },
|
|
1827
|
+
{
|
|
1828
|
+
type: GeminiEventType.Finished,
|
|
1829
|
+
value: { reason: undefined, usageMetadata: { totalTokenCount: 10 } },
|
|
1830
|
+
},
|
|
1831
|
+
];
|
|
1832
|
+
mockGeminiClient.sendMessageStream.mockImplementation(() => createStreamFromEvents(allEvents));
|
|
1833
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1834
|
+
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.JSON);
|
|
1835
|
+
await runNonInteractive({
|
|
1836
|
+
config: mockConfig,
|
|
1837
|
+
settings: mockSettings,
|
|
1838
|
+
input: 'test',
|
|
1839
|
+
prompt_id: 'test',
|
|
1840
|
+
});
|
|
1841
|
+
const output = JSON.parse(getWrittenOutput());
|
|
1842
|
+
expect(output.warnings).toBeUndefined();
|
|
1843
|
+
});
|
|
1664
1844
|
});
|
|
1665
1845
|
describe('Output Sanitization', () => {
|
|
1666
1846
|
const ANSI_SEQUENCE = '\u001B[31mRed Text\u001B[0m';
|
|
@@ -1765,7 +1945,7 @@ describe('runNonInteractive', () => {
|
|
|
1765
1945
|
});
|
|
1766
1946
|
it('should emit warning event for loop_detected in streaming JSON mode', async () => {
|
|
1767
1947
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.STREAM_JSON);
|
|
1768
|
-
vi.
|
|
1948
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1769
1949
|
const streamEvents = [
|
|
1770
1950
|
{ type: GeminiEventType.LoopDetected },
|
|
1771
1951
|
{ type: GeminiEventType.Content, value: 'Continuing after loop' },
|
|
@@ -1821,7 +2001,7 @@ describe('runNonInteractive', () => {
|
|
|
1821
2001
|
];
|
|
1822
2002
|
mockGeminiClient.sendMessageStream.mockReturnValue(createStreamFromEvents(events));
|
|
1823
2003
|
vi.mocked(mockConfig.getOutputFormat).mockReturnValue(OutputFormat.STREAM_JSON);
|
|
1824
|
-
vi.
|
|
2004
|
+
vi.spyOn(uiTelemetryService, 'getMetrics').mockReturnValue(MOCK_SESSION_METRICS);
|
|
1825
2005
|
await runNonInteractive({
|
|
1826
2006
|
config: mockConfig,
|
|
1827
2007
|
settings: mockSettings,
|