@google/gemini-cli-core 0.30.0-preview.6 → 0.31.0-preview.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/docs/CONTRIBUTING.md +6 -7
- package/dist/docs/changelogs/index.md +22 -2
- package/dist/docs/changelogs/latest.md +359 -293
- package/dist/docs/changelogs/preview.md +300 -349
- package/dist/docs/cli/cli-reference.md +23 -23
- package/dist/docs/cli/enterprise.md +7 -7
- package/dist/docs/cli/gemini-md.md +1 -1
- package/dist/docs/cli/model.md +1 -1
- package/dist/docs/cli/plan-mode.md +180 -80
- package/dist/docs/cli/sandbox.md +3 -3
- package/dist/docs/cli/settings.md +59 -51
- package/dist/docs/cli/telemetry.md +4 -1
- package/dist/docs/cli/themes.md +3 -3
- package/dist/docs/cli/trusted-folders.md +31 -0
- package/dist/docs/cli/tutorials/memory-management.md +2 -2
- package/dist/docs/cli/tutorials/session-management.md +1 -1
- package/dist/docs/core/index.md +7 -7
- package/dist/docs/core/subagents.md +155 -39
- package/dist/docs/extensions/reference.md +38 -14
- package/dist/docs/get-started/authentication.md +4 -4
- package/dist/docs/get-started/examples.md +2 -2
- package/dist/docs/get-started/gemini-3.md +17 -3
- package/dist/docs/get-started/index.md +11 -2
- package/dist/docs/hooks/best-practices.md +1 -1
- package/dist/docs/hooks/reference.md +8 -0
- package/dist/docs/ide-integration/index.md +14 -0
- package/dist/docs/index.md +62 -67
- package/dist/docs/redirects.json +19 -0
- package/dist/docs/{cli → reference}/commands.md +67 -11
- package/dist/docs/{get-started → reference}/configuration.md +93 -24
- package/dist/docs/{cli → reference}/keyboard-shortcuts.md +3 -3
- package/dist/docs/{core → reference}/policy-engine.md +63 -27
- package/dist/docs/{faq.md → resources/faq.md} +1 -1
- package/dist/docs/{quota-and-pricing.md → resources/quota-and-pricing.md} +12 -5
- package/dist/docs/{tos-privacy.md → resources/tos-privacy.md} +2 -2
- package/dist/docs/{troubleshooting.md → resources/troubleshooting.md} +1 -1
- package/dist/docs/sidebar.json +203 -166
- package/dist/docs/tools/file-system.md +7 -4
- package/dist/docs/tools/index.md +5 -2
- package/dist/docs/tools/internal-docs.md +5 -5
- package/dist/docs/tools/mcp-server.md +62 -2
- package/dist/docs/tools/planning.md +2 -0
- package/dist/docs/tools/shell.md +3 -3
- package/dist/src/agents/a2a-client-manager.test.js +1 -2
- package/dist/src/agents/a2a-client-manager.test.js.map +1 -1
- package/dist/src/agents/a2aUtils.d.ts +1 -5
- package/dist/src/agents/a2aUtils.js +1 -1
- package/dist/src/agents/a2aUtils.js.map +1 -1
- package/dist/src/agents/acknowledgedAgents.js +1 -0
- package/dist/src/agents/acknowledgedAgents.js.map +1 -1
- package/dist/src/agents/agent-scheduler.js +1 -0
- package/dist/src/agents/agent-scheduler.js.map +1 -1
- package/dist/src/agents/agentLoader.d.ts +0 -1
- package/dist/src/agents/agentLoader.js +22 -21
- package/dist/src/agents/agentLoader.js.map +1 -1
- package/dist/src/agents/agentLoader.test.js +1 -5
- package/dist/src/agents/agentLoader.test.js.map +1 -1
- package/dist/src/agents/auth-provider/api-key-provider.d.ts +30 -0
- package/dist/src/agents/auth-provider/api-key-provider.js +66 -0
- package/dist/src/agents/auth-provider/api-key-provider.js.map +1 -0
- package/dist/src/agents/auth-provider/api-key-provider.test.d.ts +6 -0
- package/dist/src/agents/auth-provider/api-key-provider.test.js +130 -0
- package/dist/src/agents/auth-provider/api-key-provider.test.js.map +1 -0
- package/dist/src/agents/auth-provider/base-provider.d.ts +2 -2
- package/dist/src/agents/auth-provider/base-provider.js.map +1 -1
- package/dist/src/agents/auth-provider/factory.js +6 -3
- package/dist/src/agents/auth-provider/factory.js.map +1 -1
- package/dist/src/agents/auth-provider/factory.test.js +12 -0
- package/dist/src/agents/auth-provider/factory.test.js.map +1 -1
- package/dist/src/agents/auth-provider/types.d.ts +2 -4
- package/dist/src/agents/browser/analyzeScreenshot.d.ts +35 -0
- package/dist/src/agents/browser/analyzeScreenshot.js +183 -0
- package/dist/src/agents/browser/analyzeScreenshot.js.map +1 -0
- package/dist/src/agents/browser/analyzeScreenshot.test.d.ts +6 -0
- package/dist/src/agents/browser/analyzeScreenshot.test.js +161 -0
- package/dist/src/agents/browser/analyzeScreenshot.test.js.map +1 -0
- package/dist/src/agents/browser/browserAgentDefinition.d.ts +50 -0
- package/dist/src/agents/browser/browserAgentDefinition.js +141 -0
- package/dist/src/agents/browser/browserAgentDefinition.js.map +1 -0
- package/dist/src/agents/browser/browserAgentFactory.d.ts +42 -0
- package/dist/src/agents/browser/browserAgentFactory.js +107 -0
- package/dist/src/agents/browser/browserAgentFactory.js.map +1 -0
- package/dist/src/agents/browser/browserAgentFactory.test.d.ts +6 -0
- package/dist/src/agents/browser/browserAgentFactory.test.js +186 -0
- package/dist/src/agents/browser/browserAgentFactory.test.js.map +1 -0
- package/dist/src/agents/browser/browserAgentInvocation.d.ts +44 -0
- package/dist/src/agents/browser/browserAgentInvocation.js +109 -0
- package/dist/src/agents/browser/browserAgentInvocation.js.map +1 -0
- package/dist/src/agents/browser/browserAgentInvocation.test.d.ts +6 -0
- package/dist/src/agents/browser/browserAgentInvocation.test.js +87 -0
- package/dist/src/agents/browser/browserAgentInvocation.test.js.map +1 -0
- package/dist/src/agents/browser/browserManager.d.ts +110 -0
- package/dist/src/agents/browser/browserManager.js +323 -0
- package/dist/src/agents/browser/browserManager.js.map +1 -0
- package/dist/src/agents/browser/browserManager.test.d.ts +6 -0
- package/dist/src/agents/browser/browserManager.test.js +314 -0
- package/dist/src/agents/browser/browserManager.test.js.map +1 -0
- package/dist/src/agents/browser/mcpToolWrapper.d.ts +45 -0
- package/dist/src/agents/browser/mcpToolWrapper.js +356 -0
- package/dist/src/agents/browser/mcpToolWrapper.js.map +1 -0
- package/dist/src/agents/browser/mcpToolWrapper.test.d.ts +6 -0
- package/dist/src/agents/browser/mcpToolWrapper.test.js +126 -0
- package/dist/src/agents/browser/mcpToolWrapper.test.js.map +1 -0
- package/dist/src/agents/browser/mcpToolWrapperConfirmation.test.d.ts +6 -0
- package/dist/src/agents/browser/mcpToolWrapperConfirmation.test.js +57 -0
- package/dist/src/agents/browser/mcpToolWrapperConfirmation.test.js.map +1 -0
- package/dist/src/agents/browser/modelAvailability.d.ts +23 -0
- package/dist/src/agents/browser/modelAvailability.js +23 -0
- package/dist/src/agents/browser/modelAvailability.js.map +1 -0
- package/dist/src/agents/local-executor.js +73 -31
- package/dist/src/agents/local-executor.js.map +1 -1
- package/dist/src/agents/local-executor.test.js +157 -4
- package/dist/src/agents/local-executor.test.js.map +1 -1
- package/dist/src/agents/local-invocation.test.js.map +1 -1
- package/dist/src/agents/registry.js +8 -0
- package/dist/src/agents/registry.js.map +1 -1
- package/dist/src/agents/registry.test.js.map +1 -1
- package/dist/src/agents/remote-invocation.d.ts +2 -1
- package/dist/src/agents/remote-invocation.js +3 -3
- package/dist/src/agents/remote-invocation.js.map +1 -1
- package/dist/src/agents/subagent-tool-wrapper.js +6 -0
- package/dist/src/agents/subagent-tool-wrapper.js.map +1 -1
- package/dist/src/agents/subagent-tool.d.ts +3 -0
- package/dist/src/agents/subagent-tool.js +62 -3
- package/dist/src/agents/subagent-tool.js.map +1 -1
- package/dist/src/agents/subagent-tool.test.js +143 -0
- package/dist/src/agents/subagent-tool.test.js.map +1 -1
- package/dist/src/availability/fallbackIntegration.test.js +4 -1
- package/dist/src/availability/fallbackIntegration.test.js.map +1 -1
- package/dist/src/availability/policyHelpers.js +3 -1
- package/dist/src/availability/policyHelpers.js.map +1 -1
- package/dist/src/availability/policyHelpers.test.js +51 -5
- package/dist/src/availability/policyHelpers.test.js.map +1 -1
- package/dist/src/code_assist/admin/admin_controls.js +1 -0
- package/dist/src/code_assist/admin/admin_controls.js.map +1 -1
- package/dist/src/code_assist/converter.js +8 -2
- package/dist/src/code_assist/converter.js.map +1 -1
- package/dist/src/code_assist/converter.test.js.map +1 -1
- package/dist/src/code_assist/experiments/experiments.js +1 -1
- package/dist/src/code_assist/experiments/experiments.js.map +1 -1
- package/dist/src/code_assist/oauth-credential-storage.js +1 -1
- package/dist/src/code_assist/oauth-credential-storage.js.map +1 -1
- package/dist/src/code_assist/oauth-credential-storage.test.js +5 -0
- package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -1
- package/dist/src/code_assist/oauth2.js +11 -8
- package/dist/src/code_assist/oauth2.js.map +1 -1
- package/dist/src/code_assist/oauth2.test.js +55 -0
- package/dist/src/code_assist/oauth2.test.js.map +1 -1
- package/dist/src/code_assist/server.js +22 -13
- package/dist/src/code_assist/server.js.map +1 -1
- package/dist/src/code_assist/server.test.js +26 -0
- package/dist/src/code_assist/server.test.js.map +1 -1
- package/dist/src/code_assist/telemetry.js +16 -3
- package/dist/src/code_assist/telemetry.js.map +1 -1
- package/dist/src/code_assist/telemetry.test.js +10 -0
- package/dist/src/code_assist/telemetry.test.js.map +1 -1
- package/dist/src/code_assist/types.d.ts +13 -12
- package/dist/src/code_assist/types.js.map +1 -1
- package/dist/src/config/config.d.ts +83 -8
- package/dist/src/config/config.js +127 -23
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +285 -10
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/projectRegistry.js +1 -0
- package/dist/src/config/projectRegistry.js.map +1 -1
- package/dist/src/config/storage.d.ts +17 -1
- package/dist/src/config/storage.js +82 -2
- package/dist/src/config/storage.js.map +1 -1
- package/dist/src/config/storage.test.js +149 -2
- package/dist/src/config/storage.test.js.map +1 -1
- package/dist/src/config/userHintService.d.ts +46 -0
- package/dist/src/config/userHintService.js +81 -0
- package/dist/src/config/userHintService.js.map +1 -0
- package/dist/src/config/userHintService.test.d.ts +6 -0
- package/dist/src/config/userHintService.test.js +62 -0
- package/dist/src/config/userHintService.test.js.map +1 -0
- package/dist/src/confirmation-bus/message-bus.js +15 -3
- package/dist/src/confirmation-bus/message-bus.js.map +1 -1
- package/dist/src/confirmation-bus/message-bus.test.js +15 -0
- package/dist/src/confirmation-bus/message-bus.test.js.map +1 -1
- package/dist/src/confirmation-bus/types.d.ts +7 -0
- package/dist/src/confirmation-bus/types.js.map +1 -1
- package/dist/src/core/baseLlmClient.d.ts +2 -3
- package/dist/src/core/baseLlmClient.js +7 -5
- package/dist/src/core/baseLlmClient.js.map +1 -1
- package/dist/src/core/baseLlmClient.test.js +45 -20
- package/dist/src/core/baseLlmClient.test.js.map +1 -1
- package/dist/src/core/client.js +18 -7
- package/dist/src/core/client.js.map +1 -1
- package/dist/src/core/coreToolHookTriggers.d.ts +2 -3
- package/dist/src/core/coreToolHookTriggers.js +8 -3
- package/dist/src/core/coreToolHookTriggers.js.map +1 -1
- package/dist/src/core/coreToolScheduler.js +2 -1
- package/dist/src/core/coreToolScheduler.js.map +1 -1
- package/dist/src/core/coreToolScheduler.test.js +10 -3
- package/dist/src/core/coreToolScheduler.test.js.map +1 -1
- package/dist/src/core/fakeContentGenerator.js +2 -0
- package/dist/src/core/fakeContentGenerator.js.map +1 -1
- package/dist/src/core/geminiChat.d.ts +1 -1
- package/dist/src/core/geminiChat.js +5 -5
- package/dist/src/core/geminiChat.js.map +1 -1
- package/dist/src/core/geminiChat.test.js +1 -0
- package/dist/src/core/geminiChat.test.js.map +1 -1
- package/dist/src/core/geminiChat_network_retry.test.js +1 -0
- package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
- package/dist/src/core/logger.js +2 -0
- package/dist/src/core/logger.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.d.ts +14 -2
- package/dist/src/core/loggingContentGenerator.js +98 -4
- package/dist/src/core/loggingContentGenerator.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.test.js +275 -1
- package/dist/src/core/loggingContentGenerator.test.js.map +1 -1
- package/dist/src/core/prompts.test.js +55 -27
- package/dist/src/core/prompts.test.js.map +1 -1
- package/dist/src/core/recordingContentGenerator.test.js +5 -0
- package/dist/src/core/recordingContentGenerator.test.js.map +1 -1
- package/dist/src/core/turn.d.ts +4 -2
- package/dist/src/core/turn.js +2 -0
- package/dist/src/core/turn.js.map +1 -1
- package/dist/src/core/turn.test.js +4 -1
- package/dist/src/core/turn.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/hooks/hookAggregator.d.ts +1 -2
- package/dist/src/hooks/hookAggregator.js +1 -2
- package/dist/src/hooks/hookAggregator.js.map +1 -1
- package/dist/src/hooks/hookEventHandler.d.ts +2 -2
- package/dist/src/hooks/hookEventHandler.js +13 -4
- package/dist/src/hooks/hookEventHandler.js.map +1 -1
- package/dist/src/hooks/hookEventHandler.test.js +1 -2
- package/dist/src/hooks/hookEventHandler.test.js.map +1 -1
- package/dist/src/hooks/hookPlanner.d.ts +1 -2
- package/dist/src/hooks/hookPlanner.js.map +1 -1
- package/dist/src/hooks/hookRegistry.d.ts +8 -0
- package/dist/src/hooks/hookRegistry.js +31 -3
- package/dist/src/hooks/hookRegistry.js.map +1 -1
- package/dist/src/hooks/hookRegistry.test.js.map +1 -1
- package/dist/src/hooks/hookRunner.d.ts +5 -2
- package/dist/src/hooks/hookRunner.js +52 -2
- package/dist/src/hooks/hookRunner.js.map +1 -1
- package/dist/src/hooks/hookRunner.test.js.map +1 -1
- package/dist/src/hooks/hookSystem.d.ts +11 -3
- package/dist/src/hooks/hookSystem.js +10 -4
- package/dist/src/hooks/hookSystem.js.map +1 -1
- package/dist/src/hooks/hookSystem.test.js +1 -0
- package/dist/src/hooks/hookSystem.test.js.map +1 -1
- package/dist/src/hooks/runtimeHooks.test.d.ts +6 -0
- package/dist/src/hooks/runtimeHooks.test.js +100 -0
- package/dist/src/hooks/runtimeHooks.test.js.map +1 -0
- package/dist/src/hooks/trustedHooks.js +6 -1
- package/dist/src/hooks/trustedHooks.js.map +1 -1
- package/dist/src/hooks/trustedHooks.test.js +17 -9
- package/dist/src/hooks/trustedHooks.test.js.map +1 -1
- package/dist/src/hooks/types.d.ts +49 -8
- package/dist/src/hooks/types.js +20 -1
- package/dist/src/hooks/types.js.map +1 -1
- package/dist/src/ide/detect-ide.d.ts +0 -1
- package/dist/src/ide/detect-ide.js +1 -1
- package/dist/src/ide/detect-ide.js.map +1 -1
- package/dist/src/ide/ide-client.js +3 -2
- package/dist/src/ide/ide-client.js.map +1 -1
- package/dist/src/ide/ide-connection-utils.js +90 -14
- package/dist/src/ide/ide-connection-utils.js.map +1 -1
- package/dist/src/ide/ide-connection-utils.test.js +78 -0
- package/dist/src/ide/ide-connection-utils.test.js.map +1 -1
- package/dist/src/ide/ide-installer.test.js +1 -2
- package/dist/src/ide/ide-installer.test.js.map +1 -1
- package/dist/src/ide/process-utils.d.ts +7 -0
- package/dist/src/ide/process-utils.js +20 -0
- package/dist/src/ide/process-utils.js.map +1 -1
- package/dist/src/ide/process-utils.test.js +30 -0
- package/dist/src/ide/process-utils.test.js.map +1 -1
- package/dist/src/index.d.ts +6 -1
- package/dist/src/index.js +6 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/mcp/oauth-provider.d.ts +1 -1
- package/dist/src/mcp/oauth-provider.js +8 -7
- package/dist/src/mcp/oauth-provider.js.map +1 -1
- package/dist/src/mcp/oauth-provider.test.js +34 -2
- package/dist/src/mcp/oauth-provider.test.js.map +1 -1
- package/dist/src/mcp/oauth-utils.js +2 -0
- package/dist/src/mcp/oauth-utils.js.map +1 -1
- package/dist/src/mcp/oauth-utils.test.js +12 -0
- package/dist/src/mcp/oauth-utils.test.js.map +1 -1
- package/dist/src/mcp/token-storage/file-token-storage.js +4 -1
- package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -1
- package/dist/src/mcp/token-storage/file-token-storage.test.js +40 -2
- package/dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -1
- package/dist/src/mcp/token-storage/keychain-token-storage.js +2 -0
- package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -1
- package/dist/src/policy/config.d.ts +18 -9
- package/dist/src/policy/config.js +75 -54
- package/dist/src/policy/config.js.map +1 -1
- package/dist/src/policy/config.test.js +26 -26
- package/dist/src/policy/integrity.d.ts +45 -0
- package/dist/src/policy/integrity.js +121 -0
- package/dist/src/policy/integrity.js.map +1 -0
- package/dist/src/policy/integrity.test.d.ts +6 -0
- package/dist/src/policy/integrity.test.js +132 -0
- package/dist/src/policy/integrity.test.js.map +1 -0
- package/dist/src/policy/persistence.test.js +29 -19
- package/dist/src/policy/persistence.test.js.map +1 -1
- package/dist/src/policy/policies/conseca.toml +6 -0
- package/dist/src/policy/policies/plan.toml +28 -12
- package/dist/src/policy/policies/read-only.toml +11 -10
- package/dist/src/policy/policies/write.toml +11 -10
- package/dist/src/policy/policies/yolo.toml +11 -10
- package/dist/src/policy/policy-engine.d.ts +16 -3
- package/dist/src/policy/policy-engine.js +154 -29
- package/dist/src/policy/policy-engine.js.map +1 -1
- package/dist/src/policy/policy-engine.test.js +480 -9
- package/dist/src/policy/policy-engine.test.js.map +1 -1
- package/dist/src/policy/policy-updater.test.js +11 -6
- package/dist/src/policy/policy-updater.test.js.map +1 -1
- package/dist/src/policy/toml-loader.d.ts +13 -2
- package/dist/src/policy/toml-loader.js +55 -34
- package/dist/src/policy/toml-loader.js.map +1 -1
- package/dist/src/policy/toml-loader.test.js +115 -7
- package/dist/src/policy/toml-loader.test.js.map +1 -1
- package/dist/src/policy/types.d.ts +18 -1
- package/dist/src/policy/types.js +1 -0
- package/dist/src/policy/types.js.map +1 -1
- package/dist/src/policy/workspace-policy.test.d.ts +6 -0
- package/dist/src/policy/workspace-policy.test.js +231 -0
- package/dist/src/policy/workspace-policy.test.js.map +1 -0
- package/dist/src/prompts/promptProvider.js +11 -13
- package/dist/src/prompts/promptProvider.js.map +1 -1
- package/dist/src/prompts/promptProvider.test.js +64 -3
- package/dist/src/prompts/promptProvider.test.js.map +1 -1
- package/dist/src/prompts/snippets.js +41 -10
- package/dist/src/prompts/snippets.js.map +1 -1
- package/dist/src/prompts/snippets.legacy.js +1 -0
- package/dist/src/prompts/snippets.legacy.js.map +1 -1
- package/dist/src/routing/modelRouterService.js +3 -1
- package/dist/src/routing/modelRouterService.js.map +1 -1
- package/dist/src/routing/modelRouterService.test.js +12 -6
- package/dist/src/routing/modelRouterService.test.js.map +1 -1
- package/dist/src/routing/strategies/approvalModeStrategy.d.ts +18 -0
- package/dist/src/routing/strategies/approvalModeStrategy.js +58 -0
- package/dist/src/routing/strategies/approvalModeStrategy.js.map +1 -0
- package/dist/src/routing/strategies/approvalModeStrategy.test.d.ts +6 -0
- package/dist/src/routing/strategies/approvalModeStrategy.test.js +110 -0
- package/dist/src/routing/strategies/approvalModeStrategy.test.js.map +1 -0
- package/dist/src/safety/checker-runner.js +1 -0
- package/dist/src/safety/checker-runner.js.map +1 -1
- package/dist/src/safety/conseca/conseca.d.ts +31 -0
- package/dist/src/safety/conseca/conseca.js +105 -0
- package/dist/src/safety/conseca/conseca.js.map +1 -0
- package/dist/src/safety/conseca/conseca.test.d.ts +6 -0
- package/dist/src/safety/conseca/conseca.test.js +226 -0
- package/dist/src/safety/conseca/conseca.test.js.map +1 -0
- package/dist/src/safety/conseca/integration.test.d.ts +6 -0
- package/dist/src/safety/conseca/integration.test.js +19 -0
- package/dist/src/safety/conseca/integration.test.js.map +1 -0
- package/dist/src/safety/conseca/policy-enforcer.d.ts +13 -0
- package/dist/src/safety/conseca/policy-enforcer.js +135 -0
- package/dist/src/safety/conseca/policy-enforcer.js.map +1 -0
- package/dist/src/safety/conseca/policy-enforcer.test.d.ts +6 -0
- package/dist/src/safety/conseca/policy-enforcer.test.js +141 -0
- package/dist/src/safety/conseca/policy-enforcer.test.js.map +1 -0
- package/dist/src/safety/conseca/policy-generator.d.ts +15 -0
- package/dist/src/safety/conseca/policy-generator.js +144 -0
- package/dist/src/safety/conseca/policy-generator.js.map +1 -0
- package/dist/src/safety/conseca/policy-generator.test.d.ts +6 -0
- package/dist/src/safety/conseca/policy-generator.test.js +84 -0
- package/dist/src/safety/conseca/policy-generator.test.js.map +1 -0
- package/dist/src/safety/conseca/types.d.ts +15 -0
- package/dist/src/safety/conseca/types.js +7 -0
- package/dist/src/safety/conseca/types.js.map +1 -0
- package/dist/src/safety/context-builder.d.ts +3 -3
- package/dist/src/safety/context-builder.js +60 -4
- package/dist/src/safety/context-builder.js.map +1 -1
- package/dist/src/safety/context-builder.test.js +98 -18
- package/dist/src/safety/context-builder.test.js.map +1 -1
- package/dist/src/safety/protocol.d.ts +4 -0
- package/dist/src/safety/registry.d.ts +2 -1
- package/dist/src/safety/registry.js +14 -4
- package/dist/src/safety/registry.js.map +1 -1
- package/dist/src/safety/registry.test.js +5 -2
- package/dist/src/safety/registry.test.js.map +1 -1
- package/dist/src/scheduler/confirmation.d.ts +0 -13
- package/dist/src/scheduler/confirmation.js +1 -1
- package/dist/src/scheduler/confirmation.js.map +1 -1
- package/dist/src/scheduler/policy.js +6 -2
- package/dist/src/scheduler/policy.js.map +1 -1
- package/dist/src/scheduler/policy.test.js +4 -3
- package/dist/src/scheduler/policy.test.js.map +1 -1
- package/dist/src/scheduler/scheduler.d.ts +3 -1
- package/dist/src/scheduler/scheduler.js +148 -28
- package/dist/src/scheduler/scheduler.js.map +1 -1
- package/dist/src/scheduler/scheduler.test.js +341 -242
- package/dist/src/scheduler/scheduler.test.js.map +1 -1
- package/dist/src/scheduler/scheduler_parallel.test.d.ts +6 -0
- package/dist/src/scheduler/scheduler_parallel.test.js +309 -0
- package/dist/src/scheduler/scheduler_parallel.test.js.map +1 -0
- package/dist/src/scheduler/state-manager.d.ts +8 -0
- package/dist/src/scheduler/state-manager.js +30 -2
- package/dist/src/scheduler/state-manager.js.map +1 -1
- package/dist/src/scheduler/state-manager.test.js +61 -0
- package/dist/src/scheduler/state-manager.test.js.map +1 -1
- package/dist/src/scheduler/tool-executor.js +15 -7
- package/dist/src/scheduler/tool-executor.js.map +1 -1
- package/dist/src/scheduler/tool-executor.test.js +1 -1
- package/dist/src/scheduler/tool-executor.test.js.map +1 -1
- package/dist/src/scheduler/types.d.ts +23 -0
- package/dist/src/services/FolderTrustDiscoveryService.d.ts +32 -0
- package/dist/src/services/FolderTrustDiscoveryService.js +167 -0
- package/dist/src/services/FolderTrustDiscoveryService.js.map +1 -0
- package/dist/src/services/FolderTrustDiscoveryService.test.d.ts +6 -0
- package/dist/src/services/FolderTrustDiscoveryService.test.js +118 -0
- package/dist/src/services/FolderTrustDiscoveryService.test.js.map +1 -0
- package/dist/src/services/chatCompressionService.d.ts +0 -14
- package/dist/src/services/chatCompressionService.js +29 -7
- package/dist/src/services/chatCompressionService.js.map +1 -1
- package/dist/src/services/chatCompressionService.test.js +3 -1
- package/dist/src/services/chatCompressionService.test.js.map +1 -1
- package/dist/src/services/chatRecordingService.d.ts +7 -1
- package/dist/src/services/chatRecordingService.js +12 -1
- package/dist/src/services/chatRecordingService.js.map +1 -1
- package/dist/src/services/chatRecordingService.test.js +34 -0
- package/dist/src/services/chatRecordingService.test.js.map +1 -1
- package/dist/src/services/loopDetectionService.js +1 -2
- package/dist/src/services/loopDetectionService.js.map +1 -1
- package/dist/src/services/sessionSummaryUtils.js +3 -0
- package/dist/src/services/sessionSummaryUtils.js.map +1 -1
- package/dist/src/services/shellExecutionService.js +6 -0
- package/dist/src/services/shellExecutionService.js.map +1 -1
- package/dist/src/skills/skillLoader.js +2 -2
- package/dist/src/skills/skillLoader.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +3 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +35 -4
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +0 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +19 -5
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +14 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +29 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
- package/dist/src/telemetry/conseca-logger.d.ts +9 -0
- package/dist/src/telemetry/conseca-logger.js +91 -0
- package/dist/src/telemetry/conseca-logger.js.map +1 -0
- package/dist/src/telemetry/conseca-logger.test.d.ts +6 -0
- package/dist/src/telemetry/conseca-logger.test.js +89 -0
- package/dist/src/telemetry/conseca-logger.test.js.map +1 -0
- package/dist/src/telemetry/gcp-exporters.js +1 -2
- package/dist/src/telemetry/gcp-exporters.js.map +1 -1
- package/dist/src/telemetry/index.d.ts +2 -1
- package/dist/src/telemetry/index.js +2 -1
- package/dist/src/telemetry/index.js.map +1 -1
- package/dist/src/telemetry/integration.test.circular.js +3 -0
- package/dist/src/telemetry/integration.test.circular.js.map +1 -1
- package/dist/src/telemetry/loggers.d.ts +1 -2
- package/dist/src/telemetry/loggers.js +3 -13
- package/dist/src/telemetry/loggers.js.map +1 -1
- package/dist/src/telemetry/loggers.test.circular.js +3 -0
- package/dist/src/telemetry/loggers.test.circular.js.map +1 -1
- package/dist/src/telemetry/loggers.test.js +6 -5
- package/dist/src/telemetry/loggers.test.js.map +1 -1
- package/dist/src/telemetry/metrics.d.ts +1 -3
- package/dist/src/telemetry/metrics.js +3 -2
- package/dist/src/telemetry/metrics.js.map +1 -1
- package/dist/src/telemetry/metrics.test.js +7 -3
- package/dist/src/telemetry/metrics.test.js.map +1 -1
- package/dist/src/telemetry/sanitize.test.js +19 -18
- package/dist/src/telemetry/sanitize.test.js.map +1 -1
- package/dist/src/telemetry/semantic.d.ts +7 -9
- package/dist/src/telemetry/semantic.js +8 -8
- package/dist/src/telemetry/semantic.js.map +1 -1
- package/dist/src/telemetry/types.d.ts +42 -4
- package/dist/src/telemetry/types.js +87 -2
- package/dist/src/telemetry/types.js.map +1 -1
- package/dist/src/telemetry/uiTelemetry.d.ts +1 -2
- package/dist/src/telemetry/uiTelemetry.js.map +1 -1
- package/dist/src/telemetry/uiTelemetry.test.js +1 -2
- package/dist/src/telemetry/uiTelemetry.test.js.map +1 -1
- package/dist/src/tools/ask-user.test.js +1 -19
- package/dist/src/tools/ask-user.test.js.map +1 -1
- package/dist/src/tools/confirmation-policy.test.js +14 -17
- package/dist/src/tools/confirmation-policy.test.js.map +1 -1
- package/dist/src/tools/definitions/dynamic-declaration-helpers.js +1 -1
- package/dist/src/tools/definitions/dynamic-declaration-helpers.js.map +1 -1
- package/dist/src/tools/definitions/model-family-sets/default-legacy.js +14 -16
- package/dist/src/tools/definitions/model-family-sets/default-legacy.js.map +1 -1
- package/dist/src/tools/definitions/model-family-sets/gemini-3.js +24 -59
- package/dist/src/tools/definitions/model-family-sets/gemini-3.js.map +1 -1
- package/dist/src/tools/diff-utils.d.ts +9 -0
- package/dist/src/tools/diff-utils.js +66 -0
- package/dist/src/tools/diff-utils.js.map +1 -0
- package/dist/src/tools/diff-utils.test.d.ts +6 -0
- package/dist/src/tools/diff-utils.test.js +53 -0
- package/dist/src/tools/diff-utils.test.js.map +1 -0
- package/dist/src/tools/edit.d.ts +9 -4
- package/dist/src/tools/edit.js +203 -34
- package/dist/src/tools/edit.js.map +1 -1
- package/dist/src/tools/edit.test.js +225 -10
- package/dist/src/tools/edit.test.js.map +1 -1
- package/dist/src/tools/enter-plan-mode.js +1 -1
- package/dist/src/tools/enter-plan-mode.js.map +1 -1
- package/dist/src/tools/enter-plan-mode.test.js +1 -1
- package/dist/src/tools/enter-plan-mode.test.js.map +1 -1
- package/dist/src/tools/exit-plan-mode.js +10 -24
- package/dist/src/tools/exit-plan-mode.js.map +1 -1
- package/dist/src/tools/exit-plan-mode.test.js +1 -1
- package/dist/src/tools/exit-plan-mode.test.js.map +1 -1
- package/dist/src/tools/grep-utils.d.ts +49 -0
- package/dist/src/tools/grep-utils.js +139 -0
- package/dist/src/tools/grep-utils.js.map +1 -0
- package/dist/src/tools/grep.js +4 -44
- package/dist/src/tools/grep.js.map +1 -1
- package/dist/src/tools/grep.test.js +21 -2
- package/dist/src/tools/grep.test.js.map +1 -1
- package/dist/src/tools/ls.js +6 -1
- package/dist/src/tools/ls.js.map +1 -1
- package/dist/src/tools/ls.test.js +2 -2
- package/dist/src/tools/ls.test.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.js +16 -18
- package/dist/src/tools/mcp-client-manager.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.test.js +51 -0
- package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
- package/dist/src/tools/mcp-client.d.ts +22 -1
- package/dist/src/tools/mcp-client.js +95 -36
- package/dist/src/tools/mcp-client.js.map +1 -1
- package/dist/src/tools/mcp-client.test.js +148 -20
- package/dist/src/tools/mcp-client.test.js.map +1 -1
- package/dist/src/tools/mcp-tool.d.ts +15 -5
- package/dist/src/tools/mcp-tool.js +36 -8
- package/dist/src/tools/mcp-tool.js.map +1 -1
- package/dist/src/tools/memoryTool.js +1 -1
- package/dist/src/tools/memoryTool.js.map +1 -1
- package/dist/src/tools/memoryTool.test.js +5 -0
- package/dist/src/tools/memoryTool.test.js.map +1 -1
- package/dist/src/tools/omissionPlaceholderDetector.d.ts +15 -0
- package/dist/src/tools/omissionPlaceholderDetector.js +90 -0
- package/dist/src/tools/omissionPlaceholderDetector.js.map +1 -0
- package/dist/src/tools/omissionPlaceholderDetector.test.d.ts +6 -0
- package/dist/src/tools/omissionPlaceholderDetector.test.js +49 -0
- package/dist/src/tools/omissionPlaceholderDetector.test.js.map +1 -0
- package/dist/src/tools/read-file.d.ts +4 -4
- package/dist/src/tools/read-file.js +17 -10
- package/dist/src/tools/read-file.js.map +1 -1
- package/dist/src/tools/read-file.test.js +20 -10
- package/dist/src/tools/read-file.test.js.map +1 -1
- package/dist/src/tools/ripGrep.js +49 -46
- package/dist/src/tools/ripGrep.js.map +1 -1
- package/dist/src/tools/ripGrep.test.js +52 -37
- package/dist/src/tools/ripGrep.test.js.map +1 -1
- package/dist/src/tools/shell.d.ts +2 -2
- package/dist/src/tools/shell.js +2 -2
- package/dist/src/tools/shell.js.map +1 -1
- package/dist/src/tools/shell.test.js +1 -2
- package/dist/src/tools/shell.test.js.map +1 -1
- package/dist/src/tools/tool-names.d.ts +0 -6
- package/dist/src/tools/tool-names.js +0 -15
- package/dist/src/tools/tool-names.js.map +1 -1
- package/dist/src/tools/tool-registry.d.ts +1 -0
- package/dist/src/tools/tool-registry.js +33 -6
- package/dist/src/tools/tool-registry.js.map +1 -1
- package/dist/src/tools/tool-registry.test.js +47 -0
- package/dist/src/tools/tool-registry.test.js.map +1 -1
- package/dist/src/tools/tools.d.ts +21 -1
- package/dist/src/tools/tools.js +19 -3
- package/dist/src/tools/tools.js.map +1 -1
- package/dist/src/tools/tools.test.js +24 -0
- package/dist/src/tools/tools.test.js.map +1 -1
- package/dist/src/tools/web-fetch.d.ts +9 -1
- package/dist/src/tools/web-fetch.js +273 -34
- package/dist/src/tools/web-fetch.js.map +1 -1
- package/dist/src/tools/web-fetch.test.js +303 -30
- package/dist/src/tools/web-fetch.test.js.map +1 -1
- package/dist/src/tools/write-file.js +14 -10
- package/dist/src/tools/write-file.js.map +1 -1
- package/dist/src/tools/write-file.test.js +75 -0
- package/dist/src/tools/write-file.test.js.map +1 -1
- package/dist/src/tools/write-todos.d.ts +2 -2
- package/dist/src/tools/write-todos.js +1 -1
- package/dist/src/tools/write-todos.js.map +1 -1
- package/dist/src/tools/xcode-mcp-fix-transport.js +4 -1
- package/dist/src/tools/xcode-mcp-fix-transport.js.map +1 -1
- package/dist/src/utils/approvalModeUtils.d.ts +14 -0
- package/dist/src/utils/approvalModeUtils.js +35 -0
- package/dist/src/utils/approvalModeUtils.js.map +1 -0
- package/dist/src/utils/approvalModeUtils.test.d.ts +6 -0
- package/dist/src/utils/approvalModeUtils.test.js +36 -0
- package/dist/src/utils/approvalModeUtils.test.js.map +1 -0
- package/dist/src/utils/authConsent.d.ts +1 -1
- package/dist/src/utils/authConsent.js +10 -8
- package/dist/src/utils/authConsent.js.map +1 -1
- package/dist/src/utils/authConsent.test.js +89 -44
- package/dist/src/utils/authConsent.test.js.map +1 -1
- package/dist/src/utils/compatibility.d.ts +41 -0
- package/dist/src/utils/compatibility.js +112 -0
- package/dist/src/utils/compatibility.js.map +1 -0
- package/dist/src/utils/compatibility.test.d.ts +6 -0
- package/dist/src/utils/compatibility.test.js +233 -0
- package/dist/src/utils/compatibility.test.js.map +1 -0
- package/dist/src/utils/editCorrector.js +22 -29
- package/dist/src/utils/editCorrector.js.map +1 -1
- package/dist/src/utils/editCorrector.test.js.map +1 -1
- package/dist/src/utils/envExpansion.d.ts +18 -0
- package/dist/src/utils/envExpansion.js +46 -0
- package/dist/src/utils/envExpansion.js.map +1 -0
- package/dist/src/utils/envExpansion.test.d.ts +6 -0
- package/dist/src/utils/envExpansion.test.js +110 -0
- package/dist/src/utils/envExpansion.test.js.map +1 -0
- package/dist/src/utils/errors.d.ts +1 -0
- package/dist/src/utils/errors.js +55 -10
- package/dist/src/utils/errors.js.map +1 -1
- package/dist/src/utils/errors.test.js +27 -1
- package/dist/src/utils/errors.test.js.map +1 -1
- package/dist/src/utils/events.d.ts +17 -0
- package/dist/src/utils/events.js +12 -0
- package/dist/src/utils/events.js.map +1 -1
- package/dist/src/utils/events.test.d.ts +1 -1
- package/dist/src/utils/events.test.js +50 -3
- package/dist/src/utils/events.test.js.map +1 -1
- package/dist/src/utils/fastAckHelper.js +2 -1
- package/dist/src/utils/fastAckHelper.js.map +1 -1
- package/dist/src/utils/fetch.d.ts +1 -1
- package/dist/src/utils/fetch.js +15 -2
- package/dist/src/utils/fetch.js.map +1 -1
- package/dist/src/utils/fileDiffUtils.d.ts +2 -2
- package/dist/src/utils/fileDiffUtils.js +1 -2
- package/dist/src/utils/fileDiffUtils.js.map +1 -1
- package/dist/src/utils/fileUtils.d.ts +5 -3
- package/dist/src/utils/fileUtils.js +25 -16
- package/dist/src/utils/fileUtils.js.map +1 -1
- package/dist/src/utils/fileUtils.test.js +14 -13
- package/dist/src/utils/fileUtils.test.js.map +1 -1
- package/dist/src/utils/filesearch/fileSearch.js +4 -1
- package/dist/src/utils/filesearch/fileSearch.js.map +1 -1
- package/dist/src/utils/getFolderStructure.test.js +4 -5
- package/dist/src/utils/getFolderStructure.test.js.map +1 -1
- package/dist/src/utils/getPty.js +4 -0
- package/dist/src/utils/getPty.js.map +1 -1
- package/dist/src/utils/googleErrors.js +29 -5
- package/dist/src/utils/googleErrors.js.map +1 -1
- package/dist/src/utils/googleQuotaErrors.js +10 -0
- package/dist/src/utils/googleQuotaErrors.js.map +1 -1
- package/dist/src/utils/googleQuotaErrors.test.js +16 -1
- package/dist/src/utils/googleQuotaErrors.test.js.map +1 -1
- package/dist/src/utils/memoryDiscovery.js +2 -0
- package/dist/src/utils/memoryDiscovery.js.map +1 -1
- package/dist/src/utils/memoryDiscovery.test.js +1 -2
- package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
- package/dist/src/utils/retry.d.ts +1 -1
- package/dist/src/utils/retry.js +9 -4
- package/dist/src/utils/retry.js.map +1 -1
- package/dist/src/utils/retry.test.js +15 -12
- package/dist/src/utils/retry.test.js.map +1 -1
- package/dist/src/utils/safeJsonStringify.js +3 -0
- package/dist/src/utils/safeJsonStringify.js.map +1 -1
- package/dist/src/utils/schemaValidator.js +5 -3
- package/dist/src/utils/schemaValidator.js.map +1 -1
- package/dist/src/utils/session.d.ts +1 -0
- package/dist/src/utils/session.js +3 -0
- package/dist/src/utils/session.js.map +1 -1
- package/dist/src/utils/sessionUtils.d.ts +14 -0
- package/dist/src/utils/sessionUtils.js +113 -0
- package/dist/src/utils/sessionUtils.js.map +1 -0
- package/dist/src/utils/sessionUtils.test.d.ts +1 -0
- package/dist/src/utils/sessionUtils.test.js +137 -0
- package/dist/src/utils/sessionUtils.test.js.map +1 -0
- package/dist/src/utils/shell-utils.js +1 -0
- package/dist/src/utils/shell-utils.js.map +1 -1
- package/dist/src/utils/stdio.js +6 -0
- package/dist/src/utils/stdio.js.map +1 -1
- package/dist/src/utils/textUtils.d.ts +9 -0
- package/dist/src/utils/textUtils.js +15 -0
- package/dist/src/utils/textUtils.js.map +1 -1
- package/dist/src/utils/textUtils.test.js +42 -1
- package/dist/src/utils/textUtils.test.js.map +1 -1
- package/dist/src/utils/toolCallContext.d.ts +0 -5
- package/dist/src/utils/toolCallContext.js +1 -1
- package/dist/src/utils/toolCallContext.js.map +1 -1
- package/dist/src/utils/userAccountManager.js +3 -0
- package/dist/src/utils/userAccountManager.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +6 -3
- package/dist/docs/architecture.md +0 -80
- package/dist/docs/cli/index.md +0 -123
- package/dist/docs/core/concepts.md +0 -137
- package/dist/docs/get-started/configuration-v1.md +0 -882
- package/dist/google-gemini-cli-core-0.30.0-preview.5.tgz +0 -0
- /package/dist/docs/{core → reference}/memport.md +0 -0
- /package/dist/docs/{core → reference}/tools-api.md +0 -0
- /package/dist/docs/{cli → resources}/uninstall.md +0 -0
|
@@ -5,6 +5,7 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
|
|
7
7
|
import { Config, DEFAULT_FILE_FILTERING_OPTIONS } from './config.js';
|
|
8
|
+
import { DEFAULT_MAX_ATTEMPTS } from '../utils/retry.js';
|
|
8
9
|
import { ExperimentFlags } from '../code_assist/experiments/flagNames.js';
|
|
9
10
|
import { debugLogger } from '../utils/debugLogger.js';
|
|
10
11
|
import { ApprovalMode } from '../policy/types.js';
|
|
@@ -13,7 +14,7 @@ import { FileDiscoveryService } from '../services/fileDiscoveryService.js';
|
|
|
13
14
|
import * as path from 'node:path';
|
|
14
15
|
import * as fs from 'node:fs';
|
|
15
16
|
import { setGeminiMdFilename as mockSetGeminiMdFilename } from '../tools/memoryTool.js';
|
|
16
|
-
import { DEFAULT_TELEMETRY_TARGET, DEFAULT_OTLP_ENDPOINT, } from '../telemetry/index.js';
|
|
17
|
+
import { DEFAULT_TELEMETRY_TARGET, DEFAULT_OTLP_ENDPOINT, uiTelemetryService, } from '../telemetry/index.js';
|
|
17
18
|
import { AuthType, createContentGenerator, createContentGeneratorConfig, } from '../core/contentGenerator.js';
|
|
18
19
|
import { GeminiClient } from '../core/client.js';
|
|
19
20
|
import { GitService } from '../services/gitService.js';
|
|
@@ -21,12 +22,12 @@ import { ShellTool } from '../tools/shell.js';
|
|
|
21
22
|
import { ReadFileTool } from '../tools/read-file.js';
|
|
22
23
|
import { GrepTool } from '../tools/grep.js';
|
|
23
24
|
import { RipGrepTool, canUseRipgrep } from '../tools/ripGrep.js';
|
|
24
|
-
import { logRipgrepFallback } from '../telemetry/loggers.js';
|
|
25
|
+
import { logRipgrepFallback, logApprovalModeDuration, } from '../telemetry/loggers.js';
|
|
25
26
|
import { RipgrepFallbackEvent } from '../telemetry/types.js';
|
|
26
27
|
import { ToolRegistry } from '../tools/tool-registry.js';
|
|
27
28
|
import { ACTIVATE_SKILL_TOOL_NAME } from '../tools/tool-names.js';
|
|
28
29
|
import { DEFAULT_MODEL_CONFIGS } from './defaultModelConfigs.js';
|
|
29
|
-
import { DEFAULT_GEMINI_MODEL } from './models.js';
|
|
30
|
+
import { DEFAULT_GEMINI_MODEL, PREVIEW_GEMINI_3_1_MODEL, DEFAULT_GEMINI_MODEL_AUTO, } from './models.js';
|
|
30
31
|
import { Storage } from './storage.js';
|
|
31
32
|
vi.mock('fs', async (importOriginal) => {
|
|
32
33
|
const actual = await importOriginal();
|
|
@@ -107,6 +108,7 @@ vi.mock('../telemetry/loggers.js', async (importOriginal) => {
|
|
|
107
108
|
return {
|
|
108
109
|
...actual,
|
|
109
110
|
logRipgrepFallback: vi.fn(),
|
|
111
|
+
logApprovalModeDuration: vi.fn(),
|
|
110
112
|
};
|
|
111
113
|
});
|
|
112
114
|
vi.mock('../services/gitService.js', () => {
|
|
@@ -166,7 +168,6 @@ vi.mock('../services/contextManager.js', () => ({
|
|
|
166
168
|
}));
|
|
167
169
|
import { BaseLlmClient } from '../core/baseLlmClient.js';
|
|
168
170
|
import { tokenLimit } from '../core/tokenLimits.js';
|
|
169
|
-
import { uiTelemetryService } from '../telemetry/index.js';
|
|
170
171
|
import { getCodeAssistServer } from '../code_assist/codeAssist.js';
|
|
171
172
|
import { getExperiments } from '../code_assist/experiments/experiments.js';
|
|
172
173
|
import { ContextManager } from '../services/contextManager.js';
|
|
@@ -205,6 +206,26 @@ describe('Server Config (config.ts)', () => {
|
|
|
205
206
|
model: MODEL,
|
|
206
207
|
usageStatisticsEnabled: false,
|
|
207
208
|
};
|
|
209
|
+
describe('maxAttempts', () => {
|
|
210
|
+
it('should default to DEFAULT_MAX_ATTEMPTS', () => {
|
|
211
|
+
const config = new Config(baseParams);
|
|
212
|
+
expect(config.getMaxAttempts()).toBe(DEFAULT_MAX_ATTEMPTS);
|
|
213
|
+
});
|
|
214
|
+
it('should use provided maxAttempts if <= DEFAULT_MAX_ATTEMPTS', () => {
|
|
215
|
+
const config = new Config({
|
|
216
|
+
...baseParams,
|
|
217
|
+
maxAttempts: 5,
|
|
218
|
+
});
|
|
219
|
+
expect(config.getMaxAttempts()).toBe(5);
|
|
220
|
+
});
|
|
221
|
+
it('should cap maxAttempts at DEFAULT_MAX_ATTEMPTS', () => {
|
|
222
|
+
const config = new Config({
|
|
223
|
+
...baseParams,
|
|
224
|
+
maxAttempts: 20,
|
|
225
|
+
});
|
|
226
|
+
expect(config.getMaxAttempts()).toBe(DEFAULT_MAX_ATTEMPTS);
|
|
227
|
+
});
|
|
228
|
+
});
|
|
208
229
|
beforeEach(() => {
|
|
209
230
|
// Reset mocks if necessary
|
|
210
231
|
vi.clearAllMocks();
|
|
@@ -577,6 +598,36 @@ describe('Server Config (config.ts)', () => {
|
|
|
577
598
|
expect(config.getUsageStatisticsEnabled()).toBe(enabled);
|
|
578
599
|
});
|
|
579
600
|
});
|
|
601
|
+
describe('Plan Settings', () => {
|
|
602
|
+
const testCases = [
|
|
603
|
+
{
|
|
604
|
+
name: 'should pass custom plan directory to storage',
|
|
605
|
+
planSettings: { directory: 'custom-plans' },
|
|
606
|
+
expected: 'custom-plans',
|
|
607
|
+
},
|
|
608
|
+
{
|
|
609
|
+
name: 'should call setCustomPlansDir with undefined if directory is not provided',
|
|
610
|
+
planSettings: {},
|
|
611
|
+
expected: undefined,
|
|
612
|
+
},
|
|
613
|
+
{
|
|
614
|
+
name: 'should call setCustomPlansDir with undefined if planSettings is not provided',
|
|
615
|
+
planSettings: undefined,
|
|
616
|
+
expected: undefined,
|
|
617
|
+
},
|
|
618
|
+
];
|
|
619
|
+
testCases.forEach(({ name, planSettings, expected }) => {
|
|
620
|
+
it(`${name}`, () => {
|
|
621
|
+
const setCustomPlansDirSpy = vi.spyOn(Storage.prototype, 'setCustomPlansDir');
|
|
622
|
+
new Config({
|
|
623
|
+
...baseParams,
|
|
624
|
+
planSettings,
|
|
625
|
+
});
|
|
626
|
+
expect(setCustomPlansDirSpy).toHaveBeenCalledWith(expected);
|
|
627
|
+
setCustomPlansDirSpy.mockRestore();
|
|
628
|
+
});
|
|
629
|
+
});
|
|
630
|
+
});
|
|
580
631
|
describe('Telemetry Settings', () => {
|
|
581
632
|
it('should return default telemetry target if not provided', () => {
|
|
582
633
|
const params = {
|
|
@@ -970,6 +1021,66 @@ describe('Server Config (config.ts)', () => {
|
|
|
970
1021
|
expect(mockCoreEvents.emitFeedback).not.toHaveBeenCalled();
|
|
971
1022
|
});
|
|
972
1023
|
});
|
|
1024
|
+
describe('BrowserAgentConfig', () => {
|
|
1025
|
+
it('should return default browser agent config when not provided', () => {
|
|
1026
|
+
const config = new Config(baseParams);
|
|
1027
|
+
const browserConfig = config.getBrowserAgentConfig();
|
|
1028
|
+
expect(browserConfig.enabled).toBe(false);
|
|
1029
|
+
expect(browserConfig.model).toBeUndefined();
|
|
1030
|
+
expect(browserConfig.customConfig.sessionMode).toBe('persistent');
|
|
1031
|
+
expect(browserConfig.customConfig.headless).toBe(false);
|
|
1032
|
+
expect(browserConfig.customConfig.profilePath).toBeUndefined();
|
|
1033
|
+
expect(browserConfig.customConfig.visualModel).toBeUndefined();
|
|
1034
|
+
});
|
|
1035
|
+
it('should return custom browser agent config from agents.overrides', () => {
|
|
1036
|
+
const params = {
|
|
1037
|
+
...baseParams,
|
|
1038
|
+
agents: {
|
|
1039
|
+
overrides: {
|
|
1040
|
+
browser_agent: {
|
|
1041
|
+
enabled: true,
|
|
1042
|
+
modelConfig: { model: 'custom-model' },
|
|
1043
|
+
},
|
|
1044
|
+
},
|
|
1045
|
+
browser: {
|
|
1046
|
+
sessionMode: 'existing',
|
|
1047
|
+
headless: true,
|
|
1048
|
+
profilePath: '/path/to/profile',
|
|
1049
|
+
visualModel: 'custom-visual-model',
|
|
1050
|
+
},
|
|
1051
|
+
},
|
|
1052
|
+
};
|
|
1053
|
+
const config = new Config(params);
|
|
1054
|
+
const browserConfig = config.getBrowserAgentConfig();
|
|
1055
|
+
expect(browserConfig.enabled).toBe(true);
|
|
1056
|
+
expect(browserConfig.model).toBe('custom-model');
|
|
1057
|
+
expect(browserConfig.customConfig.sessionMode).toBe('existing');
|
|
1058
|
+
expect(browserConfig.customConfig.headless).toBe(true);
|
|
1059
|
+
expect(browserConfig.customConfig.profilePath).toBe('/path/to/profile');
|
|
1060
|
+
expect(browserConfig.customConfig.visualModel).toBe('custom-visual-model');
|
|
1061
|
+
});
|
|
1062
|
+
it('should apply defaults for partial custom config', () => {
|
|
1063
|
+
const params = {
|
|
1064
|
+
...baseParams,
|
|
1065
|
+
agents: {
|
|
1066
|
+
overrides: {
|
|
1067
|
+
browser_agent: {
|
|
1068
|
+
enabled: true,
|
|
1069
|
+
},
|
|
1070
|
+
},
|
|
1071
|
+
browser: {
|
|
1072
|
+
headless: true,
|
|
1073
|
+
},
|
|
1074
|
+
},
|
|
1075
|
+
};
|
|
1076
|
+
const config = new Config(params);
|
|
1077
|
+
const browserConfig = config.getBrowserAgentConfig();
|
|
1078
|
+
expect(browserConfig.enabled).toBe(true);
|
|
1079
|
+
expect(browserConfig.customConfig.headless).toBe(true);
|
|
1080
|
+
// Defaults for unspecified fields
|
|
1081
|
+
expect(browserConfig.customConfig.sessionMode).toBe('persistent');
|
|
1082
|
+
});
|
|
1083
|
+
});
|
|
973
1084
|
});
|
|
974
1085
|
describe('setApprovalMode with folder trust', () => {
|
|
975
1086
|
const baseParams = {
|
|
@@ -1035,13 +1146,80 @@ describe('setApprovalMode with folder trust', () => {
|
|
|
1035
1146
|
config.setApprovalMode(ApprovalMode.DEFAULT);
|
|
1036
1147
|
expect(updateSpy).toHaveBeenCalled();
|
|
1037
1148
|
});
|
|
1038
|
-
it('should
|
|
1149
|
+
it('should update system instruction when entering YOLO mode', () => {
|
|
1150
|
+
const config = new Config(baseParams);
|
|
1151
|
+
vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
|
|
1152
|
+
vi.spyOn(config, 'getToolRegistry').mockReturnValue({
|
|
1153
|
+
getTool: vi.fn().mockReturnValue(undefined),
|
|
1154
|
+
unregisterTool: vi.fn(),
|
|
1155
|
+
registerTool: vi.fn(),
|
|
1156
|
+
});
|
|
1157
|
+
const updateSpy = vi.spyOn(config, 'updateSystemInstructionIfInitialized');
|
|
1158
|
+
config.setApprovalMode(ApprovalMode.YOLO);
|
|
1159
|
+
expect(updateSpy).toHaveBeenCalled();
|
|
1160
|
+
});
|
|
1161
|
+
it('should not update system instruction when switching between non-Plan/non-YOLO modes', () => {
|
|
1039
1162
|
const config = new Config(baseParams);
|
|
1040
1163
|
vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
|
|
1041
1164
|
const updateSpy = vi.spyOn(config, 'updateSystemInstructionIfInitialized');
|
|
1042
1165
|
config.setApprovalMode(ApprovalMode.AUTO_EDIT);
|
|
1043
1166
|
expect(updateSpy).not.toHaveBeenCalled();
|
|
1044
1167
|
});
|
|
1168
|
+
describe('approval mode duration logging', () => {
|
|
1169
|
+
beforeEach(() => {
|
|
1170
|
+
vi.mocked(logApprovalModeDuration).mockClear();
|
|
1171
|
+
});
|
|
1172
|
+
it('should initialize lastModeSwitchTime with performance.now() and log positive duration', () => {
|
|
1173
|
+
const startTime = 1000;
|
|
1174
|
+
const endTime = 5000;
|
|
1175
|
+
const performanceSpy = vi.spyOn(performance, 'now');
|
|
1176
|
+
performanceSpy.mockReturnValueOnce(startTime);
|
|
1177
|
+
const config = new Config(baseParams);
|
|
1178
|
+
vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
|
|
1179
|
+
performanceSpy.mockReturnValueOnce(endTime);
|
|
1180
|
+
config.setApprovalMode(ApprovalMode.PLAN);
|
|
1181
|
+
expect(logApprovalModeDuration).toHaveBeenCalledWith(config, expect.objectContaining({
|
|
1182
|
+
mode: ApprovalMode.DEFAULT,
|
|
1183
|
+
duration_ms: endTime - startTime,
|
|
1184
|
+
}));
|
|
1185
|
+
performanceSpy.mockRestore();
|
|
1186
|
+
});
|
|
1187
|
+
it('should skip logging if duration is zero or negative', () => {
|
|
1188
|
+
const startTime = 5000;
|
|
1189
|
+
const endTime = 4000;
|
|
1190
|
+
const performanceSpy = vi.spyOn(performance, 'now');
|
|
1191
|
+
performanceSpy.mockReturnValueOnce(startTime);
|
|
1192
|
+
const config = new Config(baseParams);
|
|
1193
|
+
vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
|
|
1194
|
+
performanceSpy.mockReturnValueOnce(endTime);
|
|
1195
|
+
config.setApprovalMode(ApprovalMode.PLAN);
|
|
1196
|
+
expect(logApprovalModeDuration).not.toHaveBeenCalled();
|
|
1197
|
+
performanceSpy.mockRestore();
|
|
1198
|
+
});
|
|
1199
|
+
it('should update lastModeSwitchTime after logging to prevent double counting', () => {
|
|
1200
|
+
const time1 = 1000;
|
|
1201
|
+
const time2 = 3000;
|
|
1202
|
+
const time3 = 6000;
|
|
1203
|
+
const performanceSpy = vi.spyOn(performance, 'now');
|
|
1204
|
+
performanceSpy.mockReturnValueOnce(time1);
|
|
1205
|
+
const config = new Config(baseParams);
|
|
1206
|
+
vi.spyOn(config, 'isTrustedFolder').mockReturnValue(true);
|
|
1207
|
+
performanceSpy.mockReturnValueOnce(time2);
|
|
1208
|
+
config.setApprovalMode(ApprovalMode.PLAN);
|
|
1209
|
+
expect(logApprovalModeDuration).toHaveBeenCalledWith(config, expect.objectContaining({
|
|
1210
|
+
mode: ApprovalMode.DEFAULT,
|
|
1211
|
+
duration_ms: time2 - time1,
|
|
1212
|
+
}));
|
|
1213
|
+
vi.mocked(logApprovalModeDuration).mockClear();
|
|
1214
|
+
performanceSpy.mockReturnValueOnce(time3);
|
|
1215
|
+
config.setApprovalMode(ApprovalMode.YOLO);
|
|
1216
|
+
expect(logApprovalModeDuration).toHaveBeenCalledWith(config, expect.objectContaining({
|
|
1217
|
+
mode: ApprovalMode.PLAN,
|
|
1218
|
+
duration_ms: time3 - time2,
|
|
1219
|
+
}));
|
|
1220
|
+
performanceSpy.mockRestore();
|
|
1221
|
+
});
|
|
1222
|
+
});
|
|
1045
1223
|
describe('registerCoreTools', () => {
|
|
1046
1224
|
beforeEach(() => {
|
|
1047
1225
|
vi.clearAllMocks();
|
|
@@ -1665,14 +1843,15 @@ describe('Config Quota & Preview Model Access', () => {
|
|
|
1665
1843
|
vi.mocked(getCodeAssistServer).mockReturnValue(undefined);
|
|
1666
1844
|
const result = await config.refreshUserQuota();
|
|
1667
1845
|
expect(result).toBeUndefined();
|
|
1668
|
-
|
|
1846
|
+
// Never set => stays null (unknown); getter returns true so UI shows preview
|
|
1847
|
+
expect(config.getHasAccessToPreviewModel()).toBe(true);
|
|
1669
1848
|
});
|
|
1670
1849
|
it('should return undefined if retrieveUserQuota fails', async () => {
|
|
1671
1850
|
mockCodeAssistServer.retrieveUserQuota.mockRejectedValue(new Error('Network error'));
|
|
1672
1851
|
const result = await config.refreshUserQuota();
|
|
1673
1852
|
expect(result).toBeUndefined();
|
|
1674
|
-
//
|
|
1675
|
-
expect(config.getHasAccessToPreviewModel()).toBe(
|
|
1853
|
+
// Never set => stays null (unknown); getter returns true so UI shows preview
|
|
1854
|
+
expect(config.getHasAccessToPreviewModel()).toBe(true);
|
|
1676
1855
|
});
|
|
1677
1856
|
});
|
|
1678
1857
|
describe('refreshUserQuotaIfStale', () => {
|
|
@@ -1768,6 +1947,26 @@ describe('Config Quota & Preview Model Access', () => {
|
|
|
1768
1947
|
expect(config.isPlanEnabled()).toBe(false);
|
|
1769
1948
|
});
|
|
1770
1949
|
});
|
|
1950
|
+
describe('getPlanModeRoutingEnabled', () => {
|
|
1951
|
+
it('should default to true when not provided', async () => {
|
|
1952
|
+
const config = new Config(baseParams);
|
|
1953
|
+
expect(await config.getPlanModeRoutingEnabled()).toBe(true);
|
|
1954
|
+
});
|
|
1955
|
+
it('should return true when explicitly enabled in planSettings', async () => {
|
|
1956
|
+
const config = new Config({
|
|
1957
|
+
...baseParams,
|
|
1958
|
+
planSettings: { modelRouting: true },
|
|
1959
|
+
});
|
|
1960
|
+
expect(await config.getPlanModeRoutingEnabled()).toBe(true);
|
|
1961
|
+
});
|
|
1962
|
+
it('should return false when explicitly disabled in planSettings', async () => {
|
|
1963
|
+
const config = new Config({
|
|
1964
|
+
...baseParams,
|
|
1965
|
+
planSettings: { modelRouting: false },
|
|
1966
|
+
});
|
|
1967
|
+
expect(await config.getPlanModeRoutingEnabled()).toBe(false);
|
|
1968
|
+
});
|
|
1969
|
+
});
|
|
1771
1970
|
});
|
|
1772
1971
|
describe('Config JIT Initialization', () => {
|
|
1773
1972
|
let config;
|
|
@@ -1939,7 +2138,7 @@ describe('Plans Directory Initialization', () => {
|
|
|
1939
2138
|
plan: true,
|
|
1940
2139
|
});
|
|
1941
2140
|
await config.initialize();
|
|
1942
|
-
const plansDir = config.storage.
|
|
2141
|
+
const plansDir = config.storage.getPlansDir();
|
|
1943
2142
|
expect(fs.promises.mkdir).toHaveBeenCalledWith(plansDir, {
|
|
1944
2143
|
recursive: true,
|
|
1945
2144
|
});
|
|
@@ -1952,7 +2151,7 @@ describe('Plans Directory Initialization', () => {
|
|
|
1952
2151
|
plan: false,
|
|
1953
2152
|
});
|
|
1954
2153
|
await config.initialize();
|
|
1955
|
-
const plansDir = config.storage.
|
|
2154
|
+
const plansDir = config.storage.getPlansDir();
|
|
1956
2155
|
expect(fs.promises.mkdir).not.toHaveBeenCalledWith(plansDir, {
|
|
1957
2156
|
recursive: true,
|
|
1958
2157
|
});
|
|
@@ -2028,6 +2227,21 @@ describe('syncPlanModeTools', () => {
|
|
|
2028
2227
|
const registeredTool = registerSpy.mock.calls.find((call) => call[0] instanceof EnterPlanModeTool);
|
|
2029
2228
|
expect(registeredTool).toBeUndefined();
|
|
2030
2229
|
});
|
|
2230
|
+
it('should NOT register EnterPlanModeTool when in YOLO mode, even if plan is enabled', async () => {
|
|
2231
|
+
const config = new Config({
|
|
2232
|
+
...baseParams,
|
|
2233
|
+
approvalMode: ApprovalMode.YOLO,
|
|
2234
|
+
plan: true,
|
|
2235
|
+
});
|
|
2236
|
+
const registry = new ToolRegistry(config, config.getMessageBus());
|
|
2237
|
+
vi.spyOn(config, 'getToolRegistry').mockReturnValue(registry);
|
|
2238
|
+
const registerSpy = vi.spyOn(registry, 'registerTool');
|
|
2239
|
+
vi.spyOn(registry, 'getTool').mockReturnValue(undefined);
|
|
2240
|
+
config.syncPlanModeTools();
|
|
2241
|
+
const { EnterPlanModeTool } = await import('../tools/enter-plan-mode.js');
|
|
2242
|
+
const registeredTool = registerSpy.mock.calls.find((call) => call[0] instanceof EnterPlanModeTool);
|
|
2243
|
+
expect(registeredTool).toBeUndefined();
|
|
2244
|
+
});
|
|
2031
2245
|
it('should call geminiClient.setTools if initialized', async () => {
|
|
2032
2246
|
const config = new Config(baseParams);
|
|
2033
2247
|
const registry = new ToolRegistry(config, config.getMessageBus());
|
|
@@ -2041,4 +2255,65 @@ describe('syncPlanModeTools', () => {
|
|
|
2041
2255
|
expect(setToolsSpy).toHaveBeenCalled();
|
|
2042
2256
|
});
|
|
2043
2257
|
});
|
|
2258
|
+
describe('Model Persistence Bug Fix (#19864)', () => {
|
|
2259
|
+
const baseParams = {
|
|
2260
|
+
sessionId: 'test-session',
|
|
2261
|
+
cwd: '/tmp',
|
|
2262
|
+
targetDir: '/path/to/target',
|
|
2263
|
+
debugMode: false,
|
|
2264
|
+
model: PREVIEW_GEMINI_3_1_MODEL, // User saved preview model
|
|
2265
|
+
};
|
|
2266
|
+
it('should NOT reset preview model for CodeAssist auth when refreshUserQuota is not called (no projectId)', async () => {
|
|
2267
|
+
const mockContentConfig = {
|
|
2268
|
+
authType: AuthType.LOGIN_WITH_GOOGLE,
|
|
2269
|
+
};
|
|
2270
|
+
const mockContentGenerator = {
|
|
2271
|
+
generateContent: vi.fn(),
|
|
2272
|
+
};
|
|
2273
|
+
vi.mocked(createContentGeneratorConfig).mockResolvedValue(mockContentConfig);
|
|
2274
|
+
vi.mocked(createContentGenerator).mockResolvedValue(mockContentGenerator);
|
|
2275
|
+
// getCodeAssistServer returns undefined by default, so refreshUserQuota() isn't called;
|
|
2276
|
+
// hasAccessToPreviewModel stays null; reset only when === false, so we don't reset.
|
|
2277
|
+
const config = new Config(baseParams);
|
|
2278
|
+
// Verify initial model is the preview model
|
|
2279
|
+
expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
|
|
2280
|
+
// Call refreshAuth to simulate restart (CodeAssist auth, no projectId)
|
|
2281
|
+
await config.refreshAuth(AuthType.LOGIN_WITH_GOOGLE);
|
|
2282
|
+
// Verify the model was NOT reset (bug fix)
|
|
2283
|
+
expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
|
|
2284
|
+
expect(config.getModel()).not.toBe(DEFAULT_GEMINI_MODEL_AUTO);
|
|
2285
|
+
});
|
|
2286
|
+
it('should NOT reset preview model for USE_GEMINI (hasAccessToPreviewModel is set to true)', async () => {
|
|
2287
|
+
const mockContentConfig = {
|
|
2288
|
+
authType: AuthType.USE_GEMINI,
|
|
2289
|
+
};
|
|
2290
|
+
const mockContentGenerator = {
|
|
2291
|
+
generateContent: vi.fn(),
|
|
2292
|
+
};
|
|
2293
|
+
vi.mocked(createContentGeneratorConfig).mockResolvedValue(mockContentConfig);
|
|
2294
|
+
vi.mocked(createContentGenerator).mockResolvedValue(mockContentGenerator);
|
|
2295
|
+
const config = new Config(baseParams);
|
|
2296
|
+
// Verify initial model is the preview model
|
|
2297
|
+
expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
|
|
2298
|
+
// Call refreshAuth
|
|
2299
|
+
await config.refreshAuth(AuthType.USE_GEMINI);
|
|
2300
|
+
// For USE_GEMINI, hasAccessToPreviewModel should be set to true
|
|
2301
|
+
// So the model should NOT be reset
|
|
2302
|
+
expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
|
|
2303
|
+
expect(config.getHasAccessToPreviewModel()).toBe(true);
|
|
2304
|
+
});
|
|
2305
|
+
it('should persist model when user selects it with persistMode=true', () => {
|
|
2306
|
+
const onModelChange = vi.fn();
|
|
2307
|
+
const config = new Config({
|
|
2308
|
+
...baseParams,
|
|
2309
|
+
model: DEFAULT_GEMINI_MODEL_AUTO, // Initial model
|
|
2310
|
+
onModelChange,
|
|
2311
|
+
});
|
|
2312
|
+
// User selects preview model with persist mode enabled
|
|
2313
|
+
config.setModel(PREVIEW_GEMINI_3_1_MODEL, false); // isTemporary = false
|
|
2314
|
+
// Verify onModelChange was called to persist the model
|
|
2315
|
+
expect(onModelChange).toHaveBeenCalledWith(PREVIEW_GEMINI_3_1_MODEL);
|
|
2316
|
+
expect(config.getModel()).toBe(PREVIEW_GEMINI_3_1_MODEL);
|
|
2317
|
+
});
|
|
2318
|
+
});
|
|
2044
2319
|
//# sourceMappingURL=config.test.js.map
|