@machina.ai/cell-cli-core 1.38.1-rc2 → 1.40.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/docs/AFTER_MERGE_PROMPT.md +1 -1
- package/dist/docs/admin/enterprise-controls.md +1 -1
- package/dist/docs/changelogs/index.md +42 -0
- package/dist/docs/changelogs/latest.md +254 -361
- package/dist/docs/changelogs/preview.md +237 -406
- package/dist/docs/cli/acp-mode.md +6 -6
- package/dist/docs/cli/auto-memory.md +143 -0
- package/dist/docs/cli/checkpointing.md +5 -5
- package/dist/docs/cli/cli-reference.md +12 -11
- package/dist/docs/cli/creating-skills.md +2 -2
- package/dist/docs/cli/custom-commands.md +15 -14
- package/dist/docs/cli/enterprise.md +17 -14
- package/dist/docs/cli/gemini-ignore.md +2 -2
- package/dist/docs/cli/generation-settings.md +21 -20
- package/dist/docs/cli/model-routing.md +2 -2
- package/dist/docs/cli/model-steering.md +1 -1
- package/dist/docs/cli/plan-mode.md +11 -6
- package/dist/docs/cli/sandbox.md +7 -5
- package/dist/docs/cli/settings.md +32 -28
- package/dist/docs/cli/system-prompt.md +8 -8
- package/dist/docs/cli/telemetry.md +18 -11
- package/dist/docs/cli/themes.md +2 -2
- package/dist/docs/cli/trusted-folders.md +41 -13
- package/dist/docs/cli/tutorials/mcp-setup.md +1 -1
- package/dist/docs/cli/tutorials/memory-management.md +3 -1
- package/dist/docs/cli/tutorials/plan-mode-steering.md +2 -2
- package/dist/docs/cli/tutorials/session-management.md +1 -1
- package/dist/docs/cli/tutorials/shell-commands.md +1 -1
- package/dist/docs/cli/tutorials/task-planning.md +3 -3
- package/dist/docs/core/index.md +5 -6
- package/dist/docs/core/local-model-routing.md +1 -1
- package/dist/docs/core/remote-agents.md +1 -1
- package/dist/docs/core/subagents.md +38 -8
- package/dist/docs/extensions/best-practices.md +5 -4
- package/dist/docs/extensions/reference.md +6 -5
- package/dist/docs/extensions/releasing.md +6 -5
- package/dist/docs/extensions/writing-extensions.md +11 -11
- package/dist/docs/get-started/{authentication.md → authentication.mdx} +139 -93
- package/dist/docs/get-started/gemini-3.md +1 -1
- package/dist/docs/get-started/index.md +4 -4
- package/dist/docs/get-started/installation.mdx +201 -0
- package/dist/docs/hooks/best-practices.md +18 -17
- package/dist/docs/hooks/index.md +10 -8
- package/dist/docs/hooks/reference.md +10 -10
- package/dist/docs/ide-integration/ide-companion-spec.md +14 -14
- package/dist/docs/ide-integration/index.md +4 -4
- package/dist/docs/index.md +2 -2
- package/dist/docs/integration-tests.md +84 -2
- package/dist/docs/issue-and-pr-automation.md +8 -7
- package/dist/docs/npm.md +2 -2
- package/dist/docs/reference/commands.md +11 -11
- package/dist/docs/reference/configuration.md +150 -47
- package/dist/docs/reference/keyboard-shortcuts.md +79 -2
- package/dist/docs/reference/memport.md +2 -3
- package/dist/docs/reference/policy-engine.md +60 -26
- package/dist/docs/reference/tools.md +38 -4
- package/dist/docs/release-confidence.md +1 -1
- package/dist/docs/releases.md +19 -19
- package/dist/docs/resources/faq.md +5 -5
- package/dist/docs/resources/tos-privacy.md +10 -9
- package/dist/docs/resources/troubleshooting.md +17 -16
- package/dist/docs/resources/uninstall.md +5 -4
- package/dist/docs/sidebar.json +13 -1
- package/dist/docs/tools/ask-user.md +3 -3
- package/dist/docs/tools/file-system.md +7 -7
- package/dist/docs/tools/mcp-resources.md +44 -0
- package/dist/docs/tools/mcp-server.md +42 -39
- package/dist/docs/tools/shell.md +5 -5
- package/dist/docs/tools/tracker.md +61 -0
- package/dist/package.json +5 -4
- package/dist/src/agent/content-utils.d.ts +0 -6
- package/dist/src/agent/content-utils.js +0 -14
- package/dist/src/agent/content-utils.js.map +1 -1
- package/dist/src/agent/content-utils.test.js +1 -18
- package/dist/src/agent/content-utils.test.js.map +1 -1
- package/dist/src/agent/event-translator.js +8 -3
- package/dist/src/agent/event-translator.js.map +1 -1
- package/dist/src/agent/event-translator.test.js +14 -9
- package/dist/src/agent/event-translator.test.js.map +1 -1
- package/dist/src/agent/legacy-agent-session.js +9 -3
- package/dist/src/agent/legacy-agent-session.js.map +1 -1
- package/dist/src/agent/legacy-agent-session.test.js +4 -3
- package/dist/src/agent/legacy-agent-session.test.js.map +1 -1
- package/dist/src/agent/tool-display-utils.d.ts +30 -0
- package/dist/src/agent/tool-display-utils.js +69 -0
- package/dist/src/agent/tool-display-utils.js.map +1 -0
- package/dist/src/agent/tool-display-utils.test.js +101 -0
- package/dist/src/agent/tool-display-utils.test.js.map +1 -0
- package/dist/src/agent/types.d.ts +25 -5
- package/dist/src/agents/a2aUtils.js +28 -15
- package/dist/src/agents/a2aUtils.js.map +1 -1
- package/dist/src/agents/a2aUtils.test.js +43 -0
- package/dist/src/agents/a2aUtils.test.js.map +1 -1
- package/dist/src/agents/agent-tool.d.ts +31 -0
- package/dist/src/agents/agent-tool.js +155 -0
- package/dist/src/agents/agent-tool.js.map +1 -0
- package/dist/src/agents/agent-tool.test.js +110 -0
- package/dist/src/agents/agent-tool.test.js.map +1 -0
- package/dist/src/agents/agentLoader.d.ts +79 -4
- package/dist/src/agents/agentLoader.js +40 -2
- package/dist/src/agents/agentLoader.js.map +1 -1
- package/dist/src/agents/agentLoader.test.js +32 -0
- package/dist/src/agents/agentLoader.test.js.map +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.js +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.js.map +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.test.js +19 -7
- package/dist/src/agents/browser/analyzeScreenshot.test.js.map +1 -1
- package/dist/src/agents/browser/browserAgentInvocation.d.ts +2 -2
- package/dist/src/agents/browser/browserAgentInvocation.js +2 -1
- package/dist/src/agents/browser/browserAgentInvocation.js.map +1 -1
- package/dist/src/agents/browser/browserAgentInvocation.test.js +61 -17
- package/dist/src/agents/browser/browserAgentInvocation.test.js.map +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.js +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.js.map +1 -1
- package/dist/src/agents/browser/mcpToolWrapper.test.js +22 -10
- package/dist/src/agents/browser/mcpToolWrapper.test.js.map +1 -1
- package/dist/src/agents/codebase-investigator.js +2 -2
- package/dist/src/agents/codebase-investigator.js.map +1 -1
- package/dist/src/agents/generalist-agent.js +3 -2
- package/dist/src/agents/generalist-agent.js.map +1 -1
- package/dist/src/agents/generalist-agent.test.js +1 -0
- package/dist/src/agents/generalist-agent.test.js.map +1 -1
- package/dist/src/agents/local-executor.d.ts +1 -1
- package/dist/src/agents/local-executor.js +10 -7
- package/dist/src/agents/local-executor.js.map +1 -1
- package/dist/src/agents/local-executor.test.js +5 -3
- package/dist/src/agents/local-executor.test.js.map +1 -1
- package/dist/src/agents/local-invocation.d.ts +2 -2
- package/dist/src/agents/local-invocation.js +8 -2
- package/dist/src/agents/local-invocation.js.map +1 -1
- package/dist/src/agents/local-invocation.test.js +29 -13
- package/dist/src/agents/local-invocation.test.js.map +1 -1
- package/dist/src/agents/registry.d.ts +2 -0
- package/dist/src/agents/registry.js +20 -19
- package/dist/src/agents/registry.js.map +1 -1
- package/dist/src/agents/registry.test.js +19 -30
- package/dist/src/agents/registry.test.js.map +1 -1
- package/dist/src/agents/remote-invocation.d.ts +3 -4
- package/dist/src/agents/remote-invocation.js +2 -1
- package/dist/src/agents/remote-invocation.js.map +1 -1
- package/dist/src/agents/remote-invocation.test.js +45 -18
- package/dist/src/agents/remote-invocation.test.js.map +1 -1
- package/dist/src/agents/skill-extraction-agent.d.ts +3 -2
- package/dist/src/agents/skill-extraction-agent.js +99 -56
- package/dist/src/agents/skill-extraction-agent.js.map +1 -1
- package/dist/src/agents/skill-extraction-agent.test.js +54 -0
- package/dist/src/agents/skill-extraction-agent.test.js.map +1 -0
- package/dist/src/availability/policyCatalog.js +1 -1
- package/dist/src/availability/policyCatalog.js.map +1 -1
- package/dist/src/availability/policyCatalog.test.js +1 -1
- package/dist/src/availability/policyCatalog.test.js.map +1 -1
- package/dist/src/code_assist/oauth2.js +14 -4
- package/dist/src/code_assist/oauth2.js.map +1 -1
- package/dist/src/commands/memory.d.ts +77 -0
- package/dist/src/commands/memory.js +494 -0
- package/dist/src/commands/memory.js.map +1 -1
- package/dist/src/commands/memory.test.js +720 -1
- package/dist/src/commands/memory.test.js.map +1 -1
- package/dist/src/config/config-agents-reload.test.js +26 -31
- package/dist/src/config/config-agents-reload.test.js.map +1 -1
- package/dist/src/config/config.d.ts +24 -10
- package/dist/src/config/config.js +148 -82
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +373 -10
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/constants.d.ts +1 -0
- package/dist/src/config/constants.js +2 -0
- package/dist/src/config/constants.js.map +1 -1
- package/dist/src/config/defaultModelConfigs.js +7 -7
- package/dist/src/config/defaultModelConfigs.js.map +1 -1
- package/dist/src/config/memory.js +1 -1
- package/dist/src/config/memory.js.map +1 -1
- package/dist/src/config/path-validation.test.js +15 -6
- package/dist/src/config/path-validation.test.js.map +1 -1
- package/dist/src/config/projectRegistry.js +113 -32
- package/dist/src/config/projectRegistry.js.map +1 -1
- package/dist/src/config/projectRegistry.test.js +51 -0
- package/dist/src/config/projectRegistry.test.js.map +1 -1
- package/dist/src/config/storage.d.ts +5 -1
- package/dist/src/config/storage.js +14 -1
- package/dist/src/config/storage.js.map +1 -1
- package/dist/src/config/storage.test.js +12 -0
- package/dist/src/config/storage.test.js.map +1 -1
- package/dist/src/confirmation-bus/message-bus.d.ts +4 -1
- package/dist/src/confirmation-bus/message-bus.js +39 -1
- package/dist/src/confirmation-bus/message-bus.js.map +1 -1
- package/dist/src/confirmation-bus/message-bus.test.js +43 -0
- package/dist/src/confirmation-bus/message-bus.test.js.map +1 -1
- package/dist/src/context/config/configLoader.d.ts +13 -0
- package/dist/src/context/config/configLoader.js +65 -0
- package/dist/src/context/config/configLoader.js.map +1 -0
- package/dist/src/context/config/configLoader.test.d.ts +6 -0
- package/dist/src/context/config/configLoader.test.js +79 -0
- package/dist/src/context/config/configLoader.test.js.map +1 -0
- package/dist/src/context/config/profiles.d.ts +17 -0
- package/dist/src/context/config/profiles.js +93 -0
- package/dist/src/context/config/profiles.js.map +1 -0
- package/dist/src/context/config/registry.d.ts +21 -0
- package/dist/src/context/config/registry.js +32 -0
- package/dist/src/context/config/registry.js.map +1 -0
- package/dist/src/context/config/schema.d.ts +45 -0
- package/dist/src/context/config/schema.js +47 -0
- package/dist/src/context/config/schema.js.map +1 -0
- package/dist/src/context/config/types.d.ts +39 -0
- package/dist/src/context/config/types.js +7 -0
- package/dist/src/context/config/types.js.map +1 -0
- package/dist/src/context/contextManager.barrier.test.d.ts +6 -0
- package/dist/src/context/contextManager.barrier.test.js +56 -0
- package/dist/src/context/contextManager.barrier.test.js.map +1 -0
- package/dist/src/context/contextManager.d.ts +49 -0
- package/dist/src/context/contextManager.js +120 -0
- package/dist/src/context/contextManager.js.map +1 -0
- package/dist/src/context/eventBus.d.ts +28 -0
- package/dist/src/context/eventBus.js +27 -0
- package/dist/src/context/eventBus.js.map +1 -0
- package/dist/src/context/graph/behaviorRegistry.d.ts +28 -0
- package/dist/src/context/graph/behaviorRegistry.js +14 -0
- package/dist/src/context/graph/behaviorRegistry.js.map +1 -0
- package/dist/src/context/graph/builtinBehaviors.d.ts +11 -0
- package/dist/src/context/graph/builtinBehaviors.js +145 -0
- package/dist/src/context/graph/builtinBehaviors.js.map +1 -0
- package/dist/src/context/graph/fromGraph.d.ts +9 -0
- package/dist/src/context/graph/fromGraph.js +34 -0
- package/dist/src/context/graph/fromGraph.js.map +1 -0
- package/dist/src/context/graph/mapper.d.ts +16 -0
- package/dist/src/context/graph/mapper.js +16 -0
- package/dist/src/context/graph/mapper.js.map +1 -0
- package/dist/src/context/graph/render.d.ts +15 -0
- package/dist/src/context/graph/render.js +72 -0
- package/dist/src/context/graph/render.js.map +1 -0
- package/dist/src/context/graph/toGraph.d.ts +10 -0
- package/dist/src/context/graph/toGraph.js +172 -0
- package/dist/src/context/graph/toGraph.js.map +1 -0
- package/dist/src/context/graph/types.d.ts +139 -0
- package/dist/src/context/graph/types.js +36 -0
- package/dist/src/context/graph/types.js.map +1 -0
- package/dist/src/context/historyObserver.d.ts +27 -0
- package/dist/src/context/historyObserver.js +64 -0
- package/dist/src/context/historyObserver.js.map +1 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.d.ts +33 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.js +197 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.js.map +1 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.test.d.ts +6 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.test.js +89 -0
- package/dist/src/context/pipeline/contextWorkingBuffer.test.js.map +1 -0
- package/dist/src/context/pipeline/environment.d.ts +27 -0
- package/dist/src/context/pipeline/environment.js +2 -0
- package/dist/src/context/pipeline/environment.js.map +1 -0
- package/dist/src/context/pipeline/environmentImpl.d.ts +28 -0
- package/dist/src/context/pipeline/environmentImpl.js +40 -0
- package/dist/src/context/pipeline/environmentImpl.js.map +1 -0
- package/dist/src/context/pipeline/environmentImpl.test.d.ts +1 -0
- package/dist/src/context/pipeline/environmentImpl.test.js +32 -0
- package/dist/src/context/pipeline/environmentImpl.test.js.map +1 -0
- package/dist/src/context/pipeline/inbox.d.ts +15 -0
- package/dist/src/context/pipeline/inbox.js +52 -0
- package/dist/src/context/pipeline/inbox.js.map +1 -0
- package/dist/src/context/pipeline/inbox.test.d.ts +1 -0
- package/dist/src/context/pipeline/inbox.test.js +36 -0
- package/dist/src/context/pipeline/inbox.test.js.map +1 -0
- package/dist/src/context/pipeline/orchestrator.d.ts +22 -0
- package/dist/src/context/pipeline/orchestrator.js +126 -0
- package/dist/src/context/pipeline/orchestrator.js.map +1 -0
- package/dist/src/context/pipeline/orchestrator.test.d.ts +6 -0
- package/dist/src/context/pipeline/orchestrator.test.js +154 -0
- package/dist/src/context/pipeline/orchestrator.test.js.map +1 -0
- package/dist/src/context/pipeline.d.ts +52 -0
- package/dist/src/context/pipeline.js +7 -0
- package/dist/src/context/pipeline.js.map +1 -0
- package/dist/src/context/processors/blobDegradationProcessor.d.ts +6 -0
- package/dist/src/context/processors/blobDegradationProcessor.js +127 -0
- package/dist/src/context/processors/blobDegradationProcessor.js.map +1 -0
- package/dist/src/context/processors/blobDegradationProcessor.test.d.ts +6 -0
- package/dist/src/context/processors/blobDegradationProcessor.test.js +72 -0
- package/dist/src/context/processors/blobDegradationProcessor.test.js.map +1 -0
- package/dist/src/context/processors/historyTruncationProcessor.d.ts +11 -0
- package/dist/src/context/processors/historyTruncationProcessor.js +61 -0
- package/dist/src/context/processors/historyTruncationProcessor.js.map +1 -0
- package/dist/src/context/processors/nodeDistillationProcessor.d.ts +8 -0
- package/dist/src/context/processors/nodeDistillationProcessor.js +167 -0
- package/dist/src/context/processors/nodeDistillationProcessor.js.map +1 -0
- package/dist/src/context/processors/nodeDistillationProcessor.test.d.ts +6 -0
- package/dist/src/context/processors/nodeDistillationProcessor.test.js +77 -0
- package/dist/src/context/processors/nodeDistillationProcessor.test.js.map +1 -0
- package/dist/src/context/processors/nodeTruncationProcessor.d.ts +8 -0
- package/dist/src/context/processors/nodeTruncationProcessor.js +109 -0
- package/dist/src/context/processors/nodeTruncationProcessor.js.map +1 -0
- package/dist/src/context/processors/nodeTruncationProcessor.test.d.ts +6 -0
- package/dist/src/context/processors/nodeTruncationProcessor.test.js +71 -0
- package/dist/src/context/processors/nodeTruncationProcessor.test.js.map +1 -0
- package/dist/src/context/processors/rollingSummaryProcessor.d.ts +8 -0
- package/dist/src/context/processors/rollingSummaryProcessor.js +129 -0
- package/dist/src/context/processors/rollingSummaryProcessor.js.map +1 -0
- package/dist/src/context/processors/rollingSummaryProcessor.test.d.ts +1 -0
- package/dist/src/context/processors/rollingSummaryProcessor.test.js +60 -0
- package/dist/src/context/processors/rollingSummaryProcessor.test.js.map +1 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.d.ts +9 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.js +75 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.js.map +1 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.test.d.ts +1 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.test.js +80 -0
- package/dist/src/context/processors/stateSnapshotAsyncProcessor.test.js.map +1 -0
- package/dist/src/context/processors/stateSnapshotProcessor.d.ts +9 -0
- package/dist/src/context/processors/stateSnapshotProcessor.js +130 -0
- package/dist/src/context/processors/stateSnapshotProcessor.js.map +1 -0
- package/dist/src/context/processors/stateSnapshotProcessor.test.d.ts +1 -0
- package/dist/src/context/processors/stateSnapshotProcessor.test.js +91 -0
- package/dist/src/context/processors/stateSnapshotProcessor.test.js.map +1 -0
- package/dist/src/context/processors/toolMaskingProcessor.d.ts +8 -0
- package/dist/src/context/processors/toolMaskingProcessor.js +194 -0
- package/dist/src/context/processors/toolMaskingProcessor.js.map +1 -0
- package/dist/src/context/processors/toolMaskingProcessor.test.d.ts +1 -0
- package/dist/src/context/processors/toolMaskingProcessor.test.js +50 -0
- package/dist/src/context/processors/toolMaskingProcessor.test.js.map +1 -0
- package/dist/src/context/system-tests/lifecycle.golden.test.d.ts +6 -0
- package/dist/src/context/system-tests/lifecycle.golden.test.js +195 -0
- package/dist/src/context/system-tests/lifecycle.golden.test.js.map +1 -0
- package/dist/src/context/system-tests/simulationHarness.d.ts +41 -0
- package/dist/src/context/system-tests/simulationHarness.js +88 -0
- package/dist/src/context/system-tests/simulationHarness.js.map +1 -0
- package/dist/src/context/testing/contextTestUtils.d.ts +44 -0
- package/dist/src/context/testing/contextTestUtils.js +176 -0
- package/dist/src/context/testing/contextTestUtils.js.map +1 -0
- package/dist/src/context/testing/testProfile.d.ts +7 -0
- package/dist/src/context/testing/testProfile.js +20 -0
- package/dist/src/context/testing/testProfile.js.map +1 -0
- package/dist/src/context/tracer.d.ts +19 -0
- package/dist/src/context/tracer.js +79 -0
- package/dist/src/context/tracer.js.map +1 -0
- package/dist/src/context/tracer.test.d.ts +6 -0
- package/dist/src/context/tracer.test.js +71 -0
- package/dist/src/context/tracer.test.js.map +1 -0
- package/dist/src/context/utils/contextTokenCalculator.d.ts +53 -0
- package/dist/src/context/utils/contextTokenCalculator.js +97 -0
- package/dist/src/context/utils/contextTokenCalculator.js.map +1 -0
- package/dist/src/context/utils/snapshotGenerator.d.ts +12 -0
- package/dist/src/context/utils/snapshotGenerator.js +43 -0
- package/dist/src/context/utils/snapshotGenerator.js.map +1 -0
- package/dist/src/core/agentChatHistory.d.ts +26 -0
- package/dist/src/core/agentChatHistory.js +50 -0
- package/dist/src/core/agentChatHistory.js.map +1 -0
- package/dist/src/core/client.js +3 -1
- package/dist/src/core/client.js.map +1 -1
- package/dist/src/core/client.test.js +4 -0
- package/dist/src/core/client.test.js.map +1 -1
- package/dist/src/core/contentGenerator.d.ts +8 -1
- package/dist/src/core/contentGenerator.js +46 -4
- package/dist/src/core/contentGenerator.js.map +1 -1
- package/dist/src/core/contentGenerator.test.js +174 -8
- package/dist/src/core/contentGenerator.test.js.map +1 -1
- package/dist/src/core/coreToolHookTriggers.d.ts +1 -1
- package/dist/src/core/coreToolHookTriggers.js +5 -1
- package/dist/src/core/coreToolHookTriggers.js.map +1 -1
- package/dist/src/core/coreToolHookTriggers.test.js +1 -1
- package/dist/src/core/coreToolHookTriggers.test.js.map +1 -1
- package/dist/src/core/geminiChat.d.ts +2 -1
- package/dist/src/core/geminiChat.js +7 -2
- package/dist/src/core/geminiChat.js.map +1 -1
- package/dist/src/core/geminiChat.test.js +19 -6
- package/dist/src/core/geminiChat.test.js.map +1 -1
- package/dist/src/core/geminiChat_network_retry.test.js +42 -0
- package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
- package/dist/src/core/localLiteRtLmClient.js +2 -0
- package/dist/src/core/localLiteRtLmClient.js.map +1 -1
- package/dist/src/core/localLiteRtLmClient.test.js +7 -0
- package/dist/src/core/localLiteRtLmClient.test.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.js +19 -6
- package/dist/src/core/loggingContentGenerator.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.test.js +55 -0
- package/dist/src/core/loggingContentGenerator.test.js.map +1 -1
- package/dist/src/core/prompts-substitution.test.js +1 -0
- package/dist/src/core/prompts-substitution.test.js.map +1 -1
- package/dist/src/core/prompts.d.ts +1 -1
- package/dist/src/core/prompts.js +2 -2
- package/dist/src/core/prompts.js.map +1 -1
- package/dist/src/core/prompts.test.js +39 -8
- package/dist/src/core/prompts.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/hookRunner.js +8 -0
- package/dist/src/hooks/hookRunner.js.map +1 -1
- package/dist/src/hooks/hookRunner.test.js +23 -0
- package/dist/src/hooks/hookRunner.test.js.map +1 -1
- package/dist/src/ide/ide-client.js +3 -4
- package/dist/src/ide/ide-client.js.map +1 -1
- package/dist/src/index.d.ts +7 -3
- package/dist/src/index.js +7 -2
- package/dist/src/index.js.map +1 -1
- package/dist/src/mcp/mcpLauncher.js +1 -1
- package/dist/src/mcp/mcpLauncher.js.map +1 -1
- package/dist/src/mcp/oauth-provider.test.js +24 -17
- package/dist/src/mcp/oauth-provider.test.js.map +1 -1
- package/dist/src/policy/config.d.ts +2 -0
- package/dist/src/policy/config.js +67 -12
- package/dist/src/policy/config.js.map +1 -1
- package/dist/src/policy/core-tools-mapping.test.d.ts +6 -0
- package/dist/src/policy/core-tools-mapping.test.js +44 -0
- package/dist/src/policy/core-tools-mapping.test.js.map +1 -0
- package/dist/src/policy/policies/agents.toml +10 -0
- package/dist/src/policy/policies/plan.toml +17 -43
- package/dist/src/policy/policies/read-only.toml +24 -38
- package/dist/src/policy/policy-engine.d.ts +1 -1
- package/dist/src/policy/policy-engine.js +72 -67
- package/dist/src/policy/policy-engine.js.map +1 -1
- package/dist/src/policy/policy-engine.test.js +71 -4
- package/dist/src/policy/policy-engine.test.js.map +1 -1
- package/dist/src/policy/sandboxPolicyManager.js +4 -4
- package/dist/src/policy/sandboxPolicyManager.js.map +1 -1
- package/dist/src/policy/shell-safety-regression.test.d.ts +6 -0
- package/dist/src/policy/shell-safety-regression.test.js +86 -0
- package/dist/src/policy/shell-safety-regression.test.js.map +1 -0
- package/dist/src/policy/shell-safety.test.js +24 -0
- package/dist/src/policy/shell-safety.test.js.map +1 -1
- package/dist/src/policy/shell-substitution.test.d.ts +6 -0
- package/dist/src/policy/shell-substitution.test.js +75 -0
- package/dist/src/policy/shell-substitution.test.js.map +1 -0
- package/dist/src/policy/toml-loader.test.js +25 -11
- package/dist/src/policy/toml-loader.test.js.map +1 -1
- package/dist/src/policy/types.d.ts +6 -2
- package/dist/src/policy/types.js +4 -2
- package/dist/src/policy/types.js.map +1 -1
- package/dist/src/prompts/promptProvider.d.ts +1 -1
- package/dist/src/prompts/promptProvider.js +41 -24
- package/dist/src/prompts/promptProvider.js.map +1 -1
- package/dist/src/prompts/promptProvider.test.js +36 -2
- package/dist/src/prompts/promptProvider.test.js.map +1 -1
- package/dist/src/prompts/snippets-memory-v2.test.d.ts +6 -0
- package/dist/src/prompts/snippets-memory-v2.test.js +94 -0
- package/dist/src/prompts/snippets-memory-v2.test.js.map +1 -0
- package/dist/src/prompts/snippets.d.ts +19 -1
- package/dist/src/prompts/snippets.js +33 -6
- package/dist/src/prompts/snippets.js.map +1 -1
- package/dist/src/prompts/snippets.legacy.d.ts +6 -1
- package/dist/src/prompts/snippets.legacy.js +14 -7
- package/dist/src/prompts/snippets.legacy.js.map +1 -1
- package/dist/src/prompts/utils.test.js +1 -0
- package/dist/src/prompts/utils.test.js.map +1 -1
- package/dist/src/routing/modelRouterService.js +1 -1
- package/dist/src/routing/modelRouterService.js.map +1 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.d.ts +2 -0
- package/dist/src/sandbox/linux/LinuxSandboxManager.js +43 -19
- package/dist/src/sandbox/linux/LinuxSandboxManager.js.map +1 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.test.js +16 -0
- package/dist/src/sandbox/linux/LinuxSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/linux/bwrapArgsBuilder.d.ts +3 -7
- package/dist/src/sandbox/linux/bwrapArgsBuilder.js +96 -105
- package/dist/src/sandbox/linux/bwrapArgsBuilder.js.map +1 -1
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.js +144 -41
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.js.map +1 -1
- package/dist/src/sandbox/macos/MacOsSandboxManager.js +19 -10
- package/dist/src/sandbox/macos/MacOsSandboxManager.js.map +1 -1
- package/dist/src/sandbox/macos/MacOsSandboxManager.test.js +24 -37
- package/dist/src/sandbox/macos/MacOsSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.d.ts +3 -9
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.js +129 -96
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.js.map +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.test.js +78 -77
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.test.js.map +1 -1
- package/dist/src/sandbox/utils/fsUtils.d.ts +2 -3
- package/dist/src/sandbox/utils/fsUtils.js +12 -27
- package/dist/src/sandbox/utils/fsUtils.js.map +1 -1
- package/dist/src/sandbox/utils/fsUtils.test.js +87 -29
- package/dist/src/sandbox/utils/fsUtils.test.js.map +1 -1
- package/dist/src/sandbox/windows/GeminiSandbox.cs +186 -77
- package/dist/src/sandbox/windows/WindowsSandboxManager.d.ts +4 -16
- package/dist/src/sandbox/windows/WindowsSandboxManager.js +138 -204
- package/dist/src/sandbox/windows/WindowsSandboxManager.js.map +1 -1
- package/dist/src/sandbox/windows/WindowsSandboxManager.test.js +105 -122
- package/dist/src/sandbox/windows/WindowsSandboxManager.test.js.map +1 -1
- package/dist/src/scheduler/policy.js +1 -2
- package/dist/src/scheduler/policy.js.map +1 -1
- package/dist/src/scheduler/policy.test.js +58 -2
- package/dist/src/scheduler/policy.test.js.map +1 -1
- package/dist/src/scheduler/scheduler.d.ts +2 -1
- package/dist/src/scheduler/scheduler.js +13 -14
- package/dist/src/scheduler/scheduler.js.map +1 -1
- package/dist/src/scheduler/scheduler.test.js +66 -0
- package/dist/src/scheduler/scheduler.test.js.map +1 -1
- package/dist/src/scheduler/scheduler_hooks.test.js +1 -0
- package/dist/src/scheduler/scheduler_hooks.test.js.map +1 -1
- package/dist/src/scheduler/scheduler_parallel.test.js +2 -0
- package/dist/src/scheduler/scheduler_parallel.test.js.map +1 -1
- package/dist/src/scheduler/tool-executor.js +2 -0
- package/dist/src/scheduler/tool-executor.js.map +1 -1
- package/dist/src/services/chatRecordingService.d.ts +12 -153
- package/dist/src/services/chatRecordingService.js +444 -350
- package/dist/src/services/chatRecordingService.js.map +1 -1
- package/dist/src/services/chatRecordingService.test.js +174 -128
- package/dist/src/services/chatRecordingService.test.js.map +1 -1
- package/dist/src/services/chatRecordingTypes.d.ts +111 -0
- package/dist/src/services/chatRecordingTypes.js +10 -0
- package/dist/src/services/chatRecordingTypes.js.map +1 -0
- package/dist/src/services/gitService.d.ts +2 -0
- package/dist/src/services/gitService.js +10 -1
- package/dist/src/services/gitService.js.map +1 -1
- package/dist/src/services/gitService.test.js +6 -2
- package/dist/src/services/gitService.test.js.map +1 -1
- package/dist/src/services/keychainService.d.ts +2 -2
- package/dist/src/services/keychainService.js +9 -9
- package/dist/src/services/keychainService.js.map +1 -1
- package/dist/src/services/keychainService.test.js +7 -7
- package/dist/src/services/keychainService.test.js.map +1 -1
- package/dist/src/services/keychainTypes.d.ts +1 -1
- package/dist/src/services/memoryPatchUtils.d.ts +42 -0
- package/dist/src/services/memoryPatchUtils.js +216 -0
- package/dist/src/services/memoryPatchUtils.js.map +1 -0
- package/dist/src/services/memoryService.d.ts +21 -1
- package/dist/src/services/memoryService.js +405 -64
- package/dist/src/services/memoryService.js.map +1 -1
- package/dist/src/services/memoryService.test.js +686 -2
- package/dist/src/services/memoryService.test.js.map +1 -1
- package/dist/src/services/sandboxManager.d.ts +33 -19
- package/dist/src/services/sandboxManager.integration.test.js +728 -266
- package/dist/src/services/sandboxManager.integration.test.js.map +1 -1
- package/dist/src/services/sandboxManager.js +65 -62
- package/dist/src/services/sandboxManager.js.map +1 -1
- package/dist/src/services/sandboxManager.test.js +17 -114
- package/dist/src/services/sandboxManager.test.js.map +1 -1
- package/dist/src/services/sandboxedFileSystemService.js +72 -62
- package/dist/src/services/sandboxedFileSystemService.js.map +1 -1
- package/dist/src/services/sessionSummaryUtils.d.ts +1 -1
- package/dist/src/services/sessionSummaryUtils.js +111 -38
- package/dist/src/services/sessionSummaryUtils.js.map +1 -1
- package/dist/src/services/sessionSummaryUtils.test.js +204 -51
- package/dist/src/services/sessionSummaryUtils.test.js.map +1 -1
- package/dist/src/services/shellExecutionService.d.ts +19 -0
- package/dist/src/services/shellExecutionService.js +88 -34
- package/dist/src/services/shellExecutionService.js.map +1 -1
- package/dist/src/services/shellExecutionService.test.js +38 -4
- package/dist/src/services/shellExecutionService.test.js.map +1 -1
- package/dist/src/telemetry/activity-monitor.js +1 -0
- package/dist/src/telemetry/activity-monitor.js.map +1 -1
- package/dist/src/telemetry/config.js +3 -0
- package/dist/src/telemetry/config.js.map +1 -1
- package/dist/src/telemetry/conseca-logger.js +18 -20
- package/dist/src/telemetry/conseca-logger.js.map +1 -1
- package/dist/src/telemetry/conseca-logger.test.js +100 -0
- package/dist/src/telemetry/conseca-logger.test.js.map +1 -1
- package/dist/src/telemetry/event-loop-monitor.d.ts +17 -0
- package/dist/src/telemetry/event-loop-monitor.js +76 -0
- package/dist/src/telemetry/event-loop-monitor.js.map +1 -0
- 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/llmRole.d.ts +2 -1
- package/dist/src/telemetry/llmRole.js +1 -0
- package/dist/src/telemetry/llmRole.js.map +1 -1
- package/dist/src/telemetry/loggers.test.js +184 -8
- package/dist/src/telemetry/loggers.test.js.map +1 -1
- package/dist/src/telemetry/memory-monitor.d.ts +1 -0
- package/dist/src/telemetry/memory-monitor.js +8 -1
- package/dist/src/telemetry/memory-monitor.js.map +1 -1
- package/dist/src/telemetry/memory-monitor.test.js +6 -1
- package/dist/src/telemetry/memory-monitor.test.js.map +1 -1
- package/dist/src/telemetry/metrics.d.ts +12 -0
- package/dist/src/telemetry/metrics.js +19 -0
- package/dist/src/telemetry/metrics.js.map +1 -1
- package/dist/src/telemetry/sdk.js +20 -1
- package/dist/src/telemetry/sdk.js.map +1 -1
- package/dist/src/telemetry/trace.d.ts +23 -6
- package/dist/src/telemetry/trace.js +71 -22
- package/dist/src/telemetry/trace.js.map +1 -1
- package/dist/src/telemetry/trace.test.js +79 -15
- package/dist/src/telemetry/trace.test.js.map +1 -1
- package/dist/src/telemetry/types.js +61 -15
- package/dist/src/telemetry/types.js.map +1 -1
- package/dist/src/test-utils/mock-tool.d.ts +3 -2
- package/dist/src/test-utils/mock-tool.js +4 -3
- package/dist/src/test-utils/mock-tool.js.map +1 -1
- package/dist/src/tools/activate-skill.js +1 -1
- package/dist/src/tools/activate-skill.js.map +1 -1
- package/dist/src/tools/activate-skill.test.js +6 -2
- package/dist/src/tools/activate-skill.test.js.map +1 -1
- package/dist/src/tools/ask-user.d.ts +2 -2
- package/dist/src/tools/ask-user.js +1 -1
- package/dist/src/tools/ask-user.js.map +1 -1
- package/dist/src/tools/ask-user.test.js +9 -3
- package/dist/src/tools/ask-user.test.js.map +1 -1
- package/dist/src/tools/complete-task.d.ts +2 -2
- package/dist/src/tools/complete-task.js +1 -1
- package/dist/src/tools/complete-task.js.map +1 -1
- package/dist/src/tools/complete-task.test.js +9 -3
- package/dist/src/tools/complete-task.test.js.map +1 -1
- package/dist/src/tools/definitions/base-declarations.d.ts +2 -0
- package/dist/src/tools/definitions/base-declarations.js +3 -0
- package/dist/src/tools/definitions/base-declarations.js.map +1 -1
- package/dist/src/tools/definitions/coreTools.d.ts +3 -1
- package/dist/src/tools/definitions/coreTools.js +13 -1
- package/dist/src/tools/definitions/coreTools.js.map +1 -1
- package/dist/src/tools/definitions/model-family-sets/default-legacy.js +29 -1
- 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 +29 -1
- package/dist/src/tools/definitions/model-family-sets/gemini-3.js.map +1 -1
- package/dist/src/tools/definitions/types.d.ts +2 -0
- package/dist/src/tools/edit.js +20 -4
- package/dist/src/tools/edit.js.map +1 -1
- package/dist/src/tools/edit.test.js +41 -18
- package/dist/src/tools/edit.test.js.map +1 -1
- package/dist/src/tools/enter-plan-mode.d.ts +2 -2
- 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 +10 -4
- package/dist/src/tools/enter-plan-mode.test.js.map +1 -1
- package/dist/src/tools/exit-plan-mode.d.ts +2 -2
- package/dist/src/tools/exit-plan-mode.js +9 -12
- package/dist/src/tools/exit-plan-mode.js.map +1 -1
- package/dist/src/tools/exit-plan-mode.test.js +44 -17
- package/dist/src/tools/exit-plan-mode.test.js.map +1 -1
- package/dist/src/tools/get-internal-docs.js +6 -3
- package/dist/src/tools/get-internal-docs.js.map +1 -1
- package/dist/src/tools/get-internal-docs.test.js +4 -4
- package/dist/src/tools/get-internal-docs.test.js.map +1 -1
- package/dist/src/tools/glob.js +1 -1
- package/dist/src/tools/glob.js.map +1 -1
- package/dist/src/tools/glob.test.js +16 -16
- package/dist/src/tools/glob.test.js.map +1 -1
- package/dist/src/tools/grep.js +21 -12
- package/dist/src/tools/grep.js.map +1 -1
- package/dist/src/tools/grep.test.js +18 -18
- package/dist/src/tools/grep.test.js.map +1 -1
- package/dist/src/tools/line-endings.test.js +3 -3
- package/dist/src/tools/line-endings.test.js.map +1 -1
- package/dist/src/tools/list-mcp-resources.d.ts +24 -0
- package/dist/src/tools/list-mcp-resources.js +74 -0
- package/dist/src/tools/list-mcp-resources.js.map +1 -0
- package/dist/src/tools/list-mcp-resources.test.d.ts +6 -0
- package/dist/src/tools/list-mcp-resources.test.js +79 -0
- package/dist/src/tools/list-mcp-resources.test.js.map +1 -0
- package/dist/src/tools/ls.js +2 -2
- package/dist/src/tools/ls.js.map +1 -1
- package/dist/src/tools/ls.test.js +21 -21
- package/dist/src/tools/ls.test.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.d.ts +3 -1
- package/dist/src/tools/mcp-client-manager.js +24 -1
- package/dist/src/tools/mcp-client-manager.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.test.js +43 -0
- package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
- package/dist/src/tools/mcp-client.js +10 -12
- package/dist/src/tools/mcp-client.js.map +1 -1
- package/dist/src/tools/mcp-client.test.js +14 -2
- package/dist/src/tools/mcp-client.test.js.map +1 -1
- package/dist/src/tools/mcp-tool.d.ts +2 -2
- package/dist/src/tools/mcp-tool.js +1 -1
- package/dist/src/tools/mcp-tool.js.map +1 -1
- package/dist/src/tools/mcp-tool.test.js +51 -21
- package/dist/src/tools/mcp-tool.test.js.map +1 -1
- package/dist/src/tools/memoryTool.d.ts +4 -3
- package/dist/src/tools/memoryTool.js +43 -14
- package/dist/src/tools/memoryTool.js.map +1 -1
- package/dist/src/tools/memoryTool.test.js +29 -9
- package/dist/src/tools/memoryTool.test.js.map +1 -1
- package/dist/src/tools/read-file.js +1 -1
- package/dist/src/tools/read-file.js.map +1 -1
- package/dist/src/tools/read-file.test.js +17 -17
- package/dist/src/tools/read-file.test.js.map +1 -1
- package/dist/src/tools/read-many-files.js +4 -4
- package/dist/src/tools/read-many-files.js.map +1 -1
- package/dist/src/tools/read-many-files.test.js +70 -24
- package/dist/src/tools/read-many-files.test.js.map +1 -1
- package/dist/src/tools/read-mcp-resource.d.ts +25 -0
- package/dist/src/tools/read-mcp-resource.js +120 -0
- package/dist/src/tools/read-mcp-resource.js.map +1 -0
- package/dist/src/tools/read-mcp-resource.test.d.ts +6 -0
- package/dist/src/tools/read-mcp-resource.test.js +110 -0
- package/dist/src/tools/read-mcp-resource.test.js.map +1 -0
- package/dist/src/tools/ripGrep.d.ts +3 -2
- package/dist/src/tools/ripGrep.js +26 -55
- package/dist/src/tools/ripGrep.js.map +1 -1
- package/dist/src/tools/ripGrep.test.js +113 -167
- 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 +51 -21
- package/dist/src/tools/shell.js.map +1 -1
- package/dist/src/tools/shell.test.js +479 -76
- package/dist/src/tools/shell.test.js.map +1 -1
- package/dist/src/tools/shellBackgroundTools.d.ts +3 -3
- package/dist/src/tools/shellBackgroundTools.integration.test.js +6 -2
- package/dist/src/tools/shellBackgroundTools.integration.test.js.map +1 -1
- package/dist/src/tools/shellBackgroundTools.js +2 -2
- package/dist/src/tools/shellBackgroundTools.js.map +1 -1
- package/dist/src/tools/shellBackgroundTools.test.js +30 -10
- package/dist/src/tools/shellBackgroundTools.test.js.map +1 -1
- package/dist/src/tools/tool-error.d.ts +1 -0
- package/dist/src/tools/tool-error.js +1 -0
- package/dist/src/tools/tool-error.js.map +1 -1
- package/dist/src/tools/tool-names.d.ts +5 -4
- package/dist/src/tools/tool-names.js +8 -2
- package/dist/src/tools/tool-names.js.map +1 -1
- package/dist/src/tools/tool-registry.js +137 -114
- package/dist/src/tools/tool-registry.js.map +1 -1
- package/dist/src/tools/tool-registry.test.js +3 -1
- package/dist/src/tools/tool-registry.test.js.map +1 -1
- package/dist/src/tools/tools.d.ts +6 -6
- package/dist/src/tools/tools.js +6 -2
- package/dist/src/tools/tools.js.map +1 -1
- package/dist/src/tools/topicTool.d.ts +2 -2
- package/dist/src/tools/topicTool.js +1 -1
- package/dist/src/tools/topicTool.js.map +1 -1
- package/dist/src/tools/topicTool.test.js +6 -2
- package/dist/src/tools/topicTool.test.js.map +1 -1
- package/dist/src/tools/trackerTools.d.ts +7 -7
- package/dist/src/tools/trackerTools.js +6 -6
- package/dist/src/tools/trackerTools.js.map +1 -1
- package/dist/src/tools/web-fetch.js +1 -1
- package/dist/src/tools/web-fetch.js.map +1 -1
- package/dist/src/tools/web-fetch.test.js +59 -23
- package/dist/src/tools/web-fetch.test.js.map +1 -1
- package/dist/src/tools/web-search.js +1 -1
- package/dist/src/tools/web-search.js.map +1 -1
- package/dist/src/tools/web-search.test.js +5 -5
- package/dist/src/tools/web-search.test.js.map +1 -1
- package/dist/src/tools/write-file.js +22 -4
- package/dist/src/tools/write-file.js.map +1 -1
- package/dist/src/tools/write-file.test.js +29 -11
- package/dist/src/tools/write-file.test.js.map +1 -1
- package/dist/src/tools/write-todos.js +1 -1
- package/dist/src/tools/write-todos.js.map +1 -1
- package/dist/src/utils/compatibility.js +6 -1
- package/dist/src/utils/compatibility.js.map +1 -1
- package/dist/src/utils/compatibility.test.js +23 -0
- package/dist/src/utils/compatibility.test.js.map +1 -1
- package/dist/src/utils/errors.d.ts +3 -0
- package/dist/src/utils/errors.js +6 -0
- package/dist/src/utils/errors.js.map +1 -1
- package/dist/src/utils/fileUtils.d.ts +1 -2
- package/dist/src/utils/fileUtils.js +80 -40
- package/dist/src/utils/fileUtils.js.map +1 -1
- package/dist/src/utils/fileUtils.test.js +61 -0
- package/dist/src/utils/fileUtils.test.js.map +1 -1
- package/dist/src/utils/filesearch/fileSearch.d.ts +2 -0
- package/dist/src/utils/filesearch/fileSearch.js +97 -6
- package/dist/src/utils/filesearch/fileSearch.js.map +1 -1
- package/dist/src/utils/filesearch/fileSearch.test.js +54 -0
- package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -1
- package/dist/src/utils/filesearch/fileWatcher.d.ts +25 -0
- package/dist/src/utils/filesearch/fileWatcher.js +86 -0
- package/dist/src/utils/filesearch/fileWatcher.js.map +1 -0
- package/dist/src/utils/filesearch/fileWatcher.test.js +142 -0
- package/dist/src/utils/filesearch/fileWatcher.test.js.map +1 -0
- package/dist/src/utils/getFolderStructure.js +4 -2
- package/dist/src/utils/getFolderStructure.js.map +1 -1
- package/dist/src/utils/gitIgnoreParser.js +1 -1
- package/dist/src/utils/gitIgnoreParser.js.map +1 -1
- package/dist/src/utils/googleQuotaErrors.d.ts +2 -1
- package/dist/src/utils/googleQuotaErrors.js +30 -35
- package/dist/src/utils/googleQuotaErrors.js.map +1 -1
- package/dist/src/utils/googleQuotaErrors.test.js +24 -0
- package/dist/src/utils/googleQuotaErrors.test.js.map +1 -1
- package/dist/src/utils/ignoreFileParser.js +1 -1
- package/dist/src/utils/ignoreFileParser.js.map +1 -1
- package/dist/src/utils/memoryDiscovery.js +15 -5
- package/dist/src/utils/memoryDiscovery.js.map +1 -1
- package/dist/src/utils/oauth-flow.js +17 -5
- package/dist/src/utils/oauth-flow.js.map +1 -1
- package/dist/src/utils/oauth-flow.test.js +20 -0
- package/dist/src/utils/oauth-flow.test.js.map +1 -1
- package/dist/src/utils/paths.d.ts +9 -0
- package/dist/src/utils/paths.js +37 -0
- package/dist/src/utils/paths.js.map +1 -1
- package/dist/src/utils/paths.test.js +45 -1
- package/dist/src/utils/paths.test.js.map +1 -1
- package/dist/src/utils/planUtils.d.ts +11 -2
- package/dist/src/utils/planUtils.js +43 -11
- package/dist/src/utils/planUtils.js.map +1 -1
- package/dist/src/utils/planUtils.test.js +10 -9
- package/dist/src/utils/planUtils.test.js.map +1 -1
- package/dist/src/utils/process-utils.d.ts +2 -1
- package/dist/src/utils/process-utils.js +64 -33
- package/dist/src/utils/process-utils.js.map +1 -1
- package/dist/src/utils/process-utils.test.js +9 -0
- package/dist/src/utils/process-utils.test.js.map +1 -1
- package/dist/src/utils/retry.js +18 -6
- package/dist/src/utils/retry.js.map +1 -1
- package/dist/src/utils/retry.test.js +30 -0
- package/dist/src/utils/retry.test.js.map +1 -1
- package/dist/src/utils/sessionOperations.js +3 -2
- package/dist/src/utils/sessionOperations.js.map +1 -1
- package/dist/src/utils/shell-utils.d.ts +2 -0
- package/dist/src/utils/shell-utils.js +237 -107
- package/dist/src/utils/shell-utils.js.map +1 -1
- package/dist/src/utils/tool-utils.d.ts +1 -29
- package/dist/src/utils/tool-utils.js +0 -39
- package/dist/src/utils/tool-utils.js.map +1 -1
- package/dist/src/utils/tool-utils.test.js +2 -76
- package/dist/src/utils/tool-utils.test.js.map +1 -1
- package/dist/src/utils/tool-visibility.d.ts +40 -0
- package/dist/src/utils/tool-visibility.js +111 -0
- package/dist/src/utils/tool-visibility.js.map +1 -0
- package/dist/src/utils/tool-visibility.test.d.ts +6 -0
- package/dist/src/utils/tool-visibility.test.js +96 -0
- package/dist/src/utils/tool-visibility.test.js.map +1 -0
- package/dist/src/utils/trust.d.ts +64 -0
- package/dist/src/utils/trust.js +276 -0
- package/dist/src/utils/trust.js.map +1 -0
- package/dist/src/utils/trust.test.d.ts +6 -0
- package/dist/src/utils/trust.test.js +159 -0
- package/dist/src/utils/trust.test.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -4
- package/dist/docs/get-started/installation.md +0 -181
- package/dist/src/agents/memory-manager-agent.d.ts +0 -25
- package/dist/src/agents/memory-manager-agent.js +0 -138
- package/dist/src/agents/memory-manager-agent.js.map +0 -1
- package/dist/src/agents/memory-manager-agent.test.js +0 -123
- package/dist/src/agents/memory-manager-agent.test.js.map +0 -1
- package/dist/src/agents/subagent-tool-wrapper.d.ts +0 -38
- package/dist/src/agents/subagent-tool-wrapper.js +0 -58
- package/dist/src/agents/subagent-tool-wrapper.js.map +0 -1
- package/dist/src/agents/subagent-tool-wrapper.test.js +0 -123
- package/dist/src/agents/subagent-tool-wrapper.test.js.map +0 -1
- package/dist/src/agents/subagent-tool.d.ts +0 -18
- package/dist/src/agents/subagent-tool.js +0 -134
- package/dist/src/agents/subagent-tool.js.map +0 -1
- package/dist/src/agents/subagent-tool.test.js +0 -287
- package/dist/src/agents/subagent-tool.test.js.map +0 -1
- package/dist/src/policy/policies/tracker.toml +0 -34
- package/dist/src/prompts/snippets-memory-manager.test.js +0 -31
- package/dist/src/prompts/snippets-memory-manager.test.js.map +0 -1
- /package/dist/src/{agents/memory-manager-agent.test.d.ts → agent/tool-display-utils.test.d.ts} +0 -0
- /package/dist/src/agents/{subagent-tool.test.d.ts → agent-tool.test.d.ts} +0 -0
- /package/dist/src/{prompts/snippets-memory-manager.test.d.ts → agents/skill-extraction-agent.test.d.ts} +0 -0
- /package/dist/src/{agents/subagent-tool-wrapper.test.d.ts → utils/filesearch/fileWatcher.test.d.ts} +0 -0
|
@@ -20,6 +20,7 @@ import { AuthType, createContentGenerator, createContentGeneratorConfig, } from
|
|
|
20
20
|
import { GeminiClient } from '../core/client.js';
|
|
21
21
|
import { GitService } from '../services/gitService.js';
|
|
22
22
|
import { ShellTool } from '../tools/shell.js';
|
|
23
|
+
import { AgentTool } from '../agents/agent-tool.js';
|
|
23
24
|
import { ReadFileTool } from '../tools/read-file.js';
|
|
24
25
|
import { GrepTool } from '../tools/grep.js';
|
|
25
26
|
import { RipGrepTool, canUseRipgrep } from '../tools/ripGrep.js';
|
|
@@ -138,9 +139,6 @@ vi.mock('../agents/registry.js', () => {
|
|
|
138
139
|
AgentRegistryMock.prototype.getDefinition = vi.fn();
|
|
139
140
|
return { AgentRegistry: AgentRegistryMock };
|
|
140
141
|
});
|
|
141
|
-
vi.mock('../agents/subagent-tool.js', () => ({
|
|
142
|
-
SubagentTool: vi.fn(),
|
|
143
|
-
}));
|
|
144
142
|
vi.mock('../resources/resource-registry.js', () => ({
|
|
145
143
|
ResourceRegistry: vi.fn(),
|
|
146
144
|
}));
|
|
@@ -235,6 +233,61 @@ describe('Server Config (config.ts)', () => {
|
|
|
235
233
|
expect(config.getMaxAttempts()).toBe(DEFAULT_MAX_ATTEMPTS);
|
|
236
234
|
});
|
|
237
235
|
});
|
|
236
|
+
describe('setShellExecutionConfig', () => {
|
|
237
|
+
it('should preserve existing shell execution fields that are not being updated', () => {
|
|
238
|
+
const config = new Config({
|
|
239
|
+
...baseParams,
|
|
240
|
+
sandbox: {
|
|
241
|
+
enabled: true,
|
|
242
|
+
command: 'windows-native',
|
|
243
|
+
networkAccess: false,
|
|
244
|
+
},
|
|
245
|
+
shellBackgroundCompletionBehavior: 'notify',
|
|
246
|
+
});
|
|
247
|
+
expect(config.getShellExecutionConfig()).toEqual(expect.objectContaining({
|
|
248
|
+
sandboxConfig: expect.objectContaining({
|
|
249
|
+
enabled: true,
|
|
250
|
+
command: 'windows-native',
|
|
251
|
+
networkAccess: false,
|
|
252
|
+
}),
|
|
253
|
+
backgroundCompletionBehavior: 'notify',
|
|
254
|
+
}));
|
|
255
|
+
config.setShellExecutionConfig({
|
|
256
|
+
terminalWidth: 123,
|
|
257
|
+
terminalHeight: 45,
|
|
258
|
+
showColor: true,
|
|
259
|
+
pager: 'cat',
|
|
260
|
+
sanitizationConfig: config.sanitizationConfig,
|
|
261
|
+
sandboxManager: config.sandboxManager,
|
|
262
|
+
});
|
|
263
|
+
expect(config.getShellExecutionConfig()).toEqual(expect.objectContaining({
|
|
264
|
+
terminalWidth: 123,
|
|
265
|
+
terminalHeight: 45,
|
|
266
|
+
sandboxConfig: expect.objectContaining({
|
|
267
|
+
enabled: true,
|
|
268
|
+
command: 'windows-native',
|
|
269
|
+
networkAccess: false,
|
|
270
|
+
}),
|
|
271
|
+
backgroundCompletionBehavior: 'notify',
|
|
272
|
+
}));
|
|
273
|
+
});
|
|
274
|
+
it('should ignore properties that are explicitly undefined and preserve existing values', () => {
|
|
275
|
+
const config = new Config(baseParams);
|
|
276
|
+
config.setShellExecutionConfig({
|
|
277
|
+
terminalWidth: 80,
|
|
278
|
+
showColor: true,
|
|
279
|
+
});
|
|
280
|
+
expect(config.getShellExecutionConfig().terminalWidth).toBe(80);
|
|
281
|
+
expect(config.getShellExecutionConfig().showColor).toBe(true);
|
|
282
|
+
// Provide undefined for terminalWidth, which should be ignored
|
|
283
|
+
config.setShellExecutionConfig({
|
|
284
|
+
terminalWidth: undefined,
|
|
285
|
+
showColor: false,
|
|
286
|
+
});
|
|
287
|
+
expect(config.getShellExecutionConfig().terminalWidth).toBe(80); // Should still be 80, not undefined
|
|
288
|
+
expect(config.getShellExecutionConfig().showColor).toBe(false); // Should be updated
|
|
289
|
+
});
|
|
290
|
+
});
|
|
238
291
|
beforeEach(() => {
|
|
239
292
|
// Reset mocks if necessary
|
|
240
293
|
vi.clearAllMocks();
|
|
@@ -515,6 +568,56 @@ describe('Server Config (config.ts)', () => {
|
|
|
515
568
|
expect(config.getGemini31FlashLiteLaunchedSync()).toBe(true);
|
|
516
569
|
});
|
|
517
570
|
});
|
|
571
|
+
describe('getProModelNoAccessSync', () => {
|
|
572
|
+
it('should return experiment value for AuthType.LOGIN_WITH_GOOGLE', async () => {
|
|
573
|
+
vi.mocked(getExperiments).mockResolvedValue({
|
|
574
|
+
experimentIds: [],
|
|
575
|
+
flags: {
|
|
576
|
+
[ExperimentFlags.PRO_MODEL_NO_ACCESS]: {
|
|
577
|
+
boolValue: true,
|
|
578
|
+
},
|
|
579
|
+
},
|
|
580
|
+
});
|
|
581
|
+
const config = new Config(baseParams);
|
|
582
|
+
vi.mocked(createContentGeneratorConfig).mockResolvedValue({
|
|
583
|
+
authType: AuthType.LOGIN_WITH_GOOGLE,
|
|
584
|
+
});
|
|
585
|
+
await config.refreshAuth(AuthType.LOGIN_WITH_GOOGLE);
|
|
586
|
+
expect(config.getProModelNoAccessSync()).toBe(true);
|
|
587
|
+
});
|
|
588
|
+
it('should return experiment value for AuthType.COMPUTE_ADC', async () => {
|
|
589
|
+
vi.mocked(getExperiments).mockResolvedValue({
|
|
590
|
+
experimentIds: [],
|
|
591
|
+
flags: {
|
|
592
|
+
[ExperimentFlags.PRO_MODEL_NO_ACCESS]: {
|
|
593
|
+
boolValue: true,
|
|
594
|
+
},
|
|
595
|
+
},
|
|
596
|
+
});
|
|
597
|
+
const config = new Config(baseParams);
|
|
598
|
+
vi.mocked(createContentGeneratorConfig).mockResolvedValue({
|
|
599
|
+
authType: AuthType.COMPUTE_ADC,
|
|
600
|
+
});
|
|
601
|
+
await config.refreshAuth(AuthType.COMPUTE_ADC);
|
|
602
|
+
expect(config.getProModelNoAccessSync()).toBe(true);
|
|
603
|
+
});
|
|
604
|
+
it('should return false for other auth types even if experiment is true', async () => {
|
|
605
|
+
vi.mocked(getExperiments).mockResolvedValue({
|
|
606
|
+
experimentIds: [],
|
|
607
|
+
flags: {
|
|
608
|
+
[ExperimentFlags.PRO_MODEL_NO_ACCESS]: {
|
|
609
|
+
boolValue: true,
|
|
610
|
+
},
|
|
611
|
+
},
|
|
612
|
+
});
|
|
613
|
+
const config = new Config(baseParams);
|
|
614
|
+
vi.mocked(createContentGeneratorConfig).mockResolvedValue({
|
|
615
|
+
authType: AuthType.USE_GEMINI,
|
|
616
|
+
});
|
|
617
|
+
await config.refreshAuth(AuthType.USE_GEMINI);
|
|
618
|
+
expect(config.getProModelNoAccessSync()).toBe(false);
|
|
619
|
+
});
|
|
620
|
+
});
|
|
518
621
|
describe('getRequestTimeoutMs', () => {
|
|
519
622
|
it('should return undefined if the flag is not set', () => {
|
|
520
623
|
const config = new Config(baseParams);
|
|
@@ -573,15 +676,32 @@ describe('Server Config (config.ts)', () => {
|
|
|
573
676
|
};
|
|
574
677
|
vi.mocked(createContentGeneratorConfig).mockResolvedValue(mockContentConfig);
|
|
575
678
|
await config.refreshAuth(authType);
|
|
576
|
-
expect(createContentGeneratorConfig).toHaveBeenCalledWith(expect.any(Config), authType, {
|
|
679
|
+
expect(createContentGeneratorConfig).toHaveBeenCalledWith(expect.any(Config), authType, undefined, undefined, undefined, undefined, {
|
|
577
680
|
clientId: undefined,
|
|
578
681
|
deviceEndpoint: undefined,
|
|
579
682
|
tokenEndpoint: undefined,
|
|
580
|
-
}, undefined
|
|
683
|
+
}, undefined);
|
|
581
684
|
// Verify that contentGeneratorConfig is updated
|
|
582
685
|
expect(config.getContentGeneratorConfig()).toEqual(mockContentConfig);
|
|
583
686
|
expect(GeminiClient).toHaveBeenCalledWith(config);
|
|
584
687
|
});
|
|
688
|
+
it('should pass Vertex AI routing settings when refreshing auth', async () => {
|
|
689
|
+
const vertexAiRouting = {
|
|
690
|
+
requestType: 'shared',
|
|
691
|
+
sharedRequestType: 'priority',
|
|
692
|
+
};
|
|
693
|
+
const config = new Config({
|
|
694
|
+
...baseParams,
|
|
695
|
+
vertexAiRouting,
|
|
696
|
+
});
|
|
697
|
+
vi.mocked(createContentGeneratorConfig).mockResolvedValue({});
|
|
698
|
+
await config.refreshAuth(AuthType.USE_VERTEX_AI);
|
|
699
|
+
expect(createContentGeneratorConfig).toHaveBeenCalledWith(config, AuthType.USE_VERTEX_AI, undefined, undefined, undefined, vertexAiRouting, {
|
|
700
|
+
clientId: undefined,
|
|
701
|
+
deviceEndpoint: undefined,
|
|
702
|
+
tokenEndpoint: undefined,
|
|
703
|
+
}, undefined);
|
|
704
|
+
});
|
|
585
705
|
it('should reset model availability status', async () => {
|
|
586
706
|
const config = new Config(baseParams);
|
|
587
707
|
const service = config.getModelAvailabilityService();
|
|
@@ -1089,6 +1209,13 @@ describe('Server Config (config.ts)', () => {
|
|
|
1089
1209
|
const wasReadFileToolRegistered = registerToolMock.mock.calls.some((call) => call[0] instanceof vi.mocked(ReadFileTool));
|
|
1090
1210
|
expect(wasReadFileToolRegistered).toBe(false);
|
|
1091
1211
|
});
|
|
1212
|
+
it('should register AgentTool', async () => {
|
|
1213
|
+
const config = new Config(baseParams);
|
|
1214
|
+
await config.initialize();
|
|
1215
|
+
const registerToolMock = (await vi.importMock('../tools/tool-registry')).ToolRegistry.prototype.registerTool;
|
|
1216
|
+
const wasRegistered = registerToolMock.mock.calls.some((call) => call[0] instanceof vi.mocked(AgentTool));
|
|
1217
|
+
expect(wasRegistered).toBe(true);
|
|
1218
|
+
});
|
|
1092
1219
|
it('should register EnterPlanModeTool and ExitPlanModeTool when plan is enabled', async () => {
|
|
1093
1220
|
const params = {
|
|
1094
1221
|
...baseParams,
|
|
@@ -1364,6 +1491,75 @@ describe('Server Config (config.ts)', () => {
|
|
|
1364
1491
|
expect(config1.topicState.getTopic()).toBe('Topic 1');
|
|
1365
1492
|
expect(config2.topicState.getTopic()).toBe('Topic 2');
|
|
1366
1493
|
});
|
|
1494
|
+
it('updates storage session-scoped directories when the sessionId changes', async () => {
|
|
1495
|
+
const config = new Config({
|
|
1496
|
+
...baseParams,
|
|
1497
|
+
sessionId: 'session-one',
|
|
1498
|
+
plan: true,
|
|
1499
|
+
});
|
|
1500
|
+
await config.initialize();
|
|
1501
|
+
const tempDir = config.storage.getProjectTempDir();
|
|
1502
|
+
const oldPlansDir = path.join(tempDir, 'session-one', 'plans');
|
|
1503
|
+
const oldTrackerService = config.getTrackerService();
|
|
1504
|
+
config.setSessionId('session-two');
|
|
1505
|
+
expect(config.getSessionId()).toBe('session-two');
|
|
1506
|
+
expect(config.storage.getProjectTempPlansDir()).toBe(path.join(tempDir, 'session-two', 'plans'));
|
|
1507
|
+
expect(config.storage.getProjectTempTrackerDir()).toBe(path.join(tempDir, 'session-two', 'tracker'));
|
|
1508
|
+
expect(config.getTrackerService()).not.toBe(oldTrackerService);
|
|
1509
|
+
expect(config.getTrackerService().trackerDir).toBe(path.join(tempDir, 'session-two', 'tracker'));
|
|
1510
|
+
expect(config.getWorkspaceContext().getDirectories()).not.toContain(oldPlansDir);
|
|
1511
|
+
});
|
|
1512
|
+
it('does not throw when changing sessions before the previous plans dir exists', async () => {
|
|
1513
|
+
const config = new Config({
|
|
1514
|
+
...baseParams,
|
|
1515
|
+
sessionId: 'session-one',
|
|
1516
|
+
plan: true,
|
|
1517
|
+
});
|
|
1518
|
+
await config.initialize();
|
|
1519
|
+
const missingPlansDir = config.storage.getProjectTempPlansDir();
|
|
1520
|
+
const realpathMock = vi.mocked(fs.realpathSync);
|
|
1521
|
+
const originalImplementation = realpathMock.getMockImplementation();
|
|
1522
|
+
try {
|
|
1523
|
+
realpathMock.mockImplementation((input) => {
|
|
1524
|
+
const normalizedInput = typeof input === 'string' || Buffer.isBuffer(input)
|
|
1525
|
+
? input
|
|
1526
|
+
: input.toString();
|
|
1527
|
+
if (normalizedInput === missingPlansDir) {
|
|
1528
|
+
const error = new Error(`ENOENT: no such file or directory, ${normalizedInput}`);
|
|
1529
|
+
Object.assign(error, { code: 'ENOENT' });
|
|
1530
|
+
throw error;
|
|
1531
|
+
}
|
|
1532
|
+
if (originalImplementation) {
|
|
1533
|
+
return originalImplementation(input);
|
|
1534
|
+
}
|
|
1535
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
1536
|
+
return normalizedInput;
|
|
1537
|
+
});
|
|
1538
|
+
expect(() => config.setSessionId('session-two')).not.toThrow();
|
|
1539
|
+
}
|
|
1540
|
+
finally {
|
|
1541
|
+
realpathMock.mockImplementation((input) => {
|
|
1542
|
+
if (originalImplementation) {
|
|
1543
|
+
return originalImplementation(input);
|
|
1544
|
+
}
|
|
1545
|
+
const normalizedInput = typeof input === 'string' || Buffer.isBuffer(input)
|
|
1546
|
+
? input
|
|
1547
|
+
: input.toString();
|
|
1548
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
1549
|
+
return normalizedInput;
|
|
1550
|
+
});
|
|
1551
|
+
}
|
|
1552
|
+
});
|
|
1553
|
+
it('clears the approved plan when starting a new session', () => {
|
|
1554
|
+
const config = new Config({
|
|
1555
|
+
...baseParams,
|
|
1556
|
+
sessionId: 'session-one',
|
|
1557
|
+
});
|
|
1558
|
+
config.setApprovedPlanPath('/tmp/session-one/plans/approved.md');
|
|
1559
|
+
expect(() => config.resetNewSessionState('session-two')).not.toThrow();
|
|
1560
|
+
expect(config.getSessionId()).toBe('session-two');
|
|
1561
|
+
expect(config.getApprovedPlanPath()).toBeUndefined();
|
|
1562
|
+
});
|
|
1367
1563
|
});
|
|
1368
1564
|
describe('GemmaModelRouterSettings', () => {
|
|
1369
1565
|
const MODEL = DEFAULT_GEMINI_MODEL;
|
|
@@ -1399,6 +1595,8 @@ describe('GemmaModelRouterSettings', () => {
|
|
|
1399
1595
|
const config = new Config(baseParams);
|
|
1400
1596
|
const settings = config.getGemmaModelRouterSettings();
|
|
1401
1597
|
expect(settings.enabled).toBe(false);
|
|
1598
|
+
expect(settings.autoStartServer).toBe(true);
|
|
1599
|
+
expect(settings.binaryPath).toBe('');
|
|
1402
1600
|
expect(settings.classifier?.host).toBe('http://localhost:9379');
|
|
1403
1601
|
expect(settings.classifier?.model).toBe('gemma3-1b-gpu-custom');
|
|
1404
1602
|
});
|
|
@@ -1407,6 +1605,8 @@ describe('GemmaModelRouterSettings', () => {
|
|
|
1407
1605
|
...baseParams,
|
|
1408
1606
|
gemmaModelRouter: {
|
|
1409
1607
|
enabled: true,
|
|
1608
|
+
autoStartServer: false,
|
|
1609
|
+
binaryPath: '/custom/lit',
|
|
1410
1610
|
classifier: {
|
|
1411
1611
|
host: 'http://custom:1234',
|
|
1412
1612
|
model: 'custom-gemma',
|
|
@@ -1416,6 +1616,8 @@ describe('GemmaModelRouterSettings', () => {
|
|
|
1416
1616
|
const config = new Config(params);
|
|
1417
1617
|
const settings = config.getGemmaModelRouterSettings();
|
|
1418
1618
|
expect(settings.enabled).toBe(true);
|
|
1619
|
+
expect(settings.autoStartServer).toBe(false);
|
|
1620
|
+
expect(settings.binaryPath).toBe('/custom/lit');
|
|
1419
1621
|
expect(settings.classifier?.host).toBe('http://custom:1234');
|
|
1420
1622
|
expect(settings.classifier?.model).toBe('custom-gemma');
|
|
1421
1623
|
});
|
|
@@ -1429,6 +1631,8 @@ describe('GemmaModelRouterSettings', () => {
|
|
|
1429
1631
|
const config = new Config(params);
|
|
1430
1632
|
const settings = config.getGemmaModelRouterSettings();
|
|
1431
1633
|
expect(settings.enabled).toBe(true);
|
|
1634
|
+
expect(settings.autoStartServer).toBe(true);
|
|
1635
|
+
expect(settings.binaryPath).toBe('');
|
|
1432
1636
|
expect(settings.classifier?.host).toBe('http://localhost:9379');
|
|
1433
1637
|
expect(settings.classifier?.model).toBe('gemma3-1b-gpu-custom');
|
|
1434
1638
|
});
|
|
@@ -2337,6 +2541,62 @@ describe('Config Quota & Preview Model Access', () => {
|
|
|
2337
2541
|
// Never set => stays null (unknown); getter returns true so UI shows preview
|
|
2338
2542
|
expect(config.getHasAccessToPreviewModel()).toBe(true);
|
|
2339
2543
|
});
|
|
2544
|
+
it('should derive quota from remainingFraction when remainingAmount is missing', async () => {
|
|
2545
|
+
mockCodeAssistServer.retrieveUserQuota.mockResolvedValue({
|
|
2546
|
+
buckets: [
|
|
2547
|
+
{
|
|
2548
|
+
modelId: 'gemini-3-flash-preview',
|
|
2549
|
+
remainingFraction: 0.96,
|
|
2550
|
+
},
|
|
2551
|
+
],
|
|
2552
|
+
});
|
|
2553
|
+
config.setModel('gemini-3-flash-preview');
|
|
2554
|
+
mockCoreEvents.emitQuotaChanged.mockClear();
|
|
2555
|
+
await config.refreshUserQuota();
|
|
2556
|
+
// Normalized: limit=100, remaining=96
|
|
2557
|
+
expect(mockCoreEvents.emitQuotaChanged).toHaveBeenCalledWith(96, 100, undefined);
|
|
2558
|
+
expect(config.getQuotaRemaining()).toBe(96);
|
|
2559
|
+
expect(config.getQuotaLimit()).toBe(100);
|
|
2560
|
+
});
|
|
2561
|
+
it('should store quota from remainingFraction when remainingFraction is 0', async () => {
|
|
2562
|
+
mockCodeAssistServer.retrieveUserQuota.mockResolvedValue({
|
|
2563
|
+
buckets: [
|
|
2564
|
+
{
|
|
2565
|
+
modelId: 'gemini-3-pro-preview',
|
|
2566
|
+
remainingFraction: 0,
|
|
2567
|
+
},
|
|
2568
|
+
],
|
|
2569
|
+
});
|
|
2570
|
+
config.setModel('gemini-3-pro-preview');
|
|
2571
|
+
mockCoreEvents.emitQuotaChanged.mockClear();
|
|
2572
|
+
await config.refreshUserQuota();
|
|
2573
|
+
// remaining=0, limit=100 but limit>0 check still passes
|
|
2574
|
+
// however remaining=0 means 0% remaining = 100% used
|
|
2575
|
+
expect(config.getQuotaRemaining()).toBe(0);
|
|
2576
|
+
expect(config.getQuotaLimit()).toBe(100);
|
|
2577
|
+
});
|
|
2578
|
+
it('should emit QuotaChanged when model is switched via setModel', async () => {
|
|
2579
|
+
mockCodeAssistServer.retrieveUserQuota.mockResolvedValue({
|
|
2580
|
+
buckets: [
|
|
2581
|
+
{
|
|
2582
|
+
modelId: 'gemini-2.5-pro',
|
|
2583
|
+
remainingAmount: '10',
|
|
2584
|
+
remainingFraction: 0.2,
|
|
2585
|
+
},
|
|
2586
|
+
{
|
|
2587
|
+
modelId: 'gemini-2.5-flash',
|
|
2588
|
+
remainingAmount: '80',
|
|
2589
|
+
remainingFraction: 0.8,
|
|
2590
|
+
},
|
|
2591
|
+
],
|
|
2592
|
+
});
|
|
2593
|
+
config.setModel('auto-gemini-2.5');
|
|
2594
|
+
await config.refreshUserQuota();
|
|
2595
|
+
mockCoreEvents.emitQuotaChanged.mockClear();
|
|
2596
|
+
// Switch to a specific model — should re-emit quota for that model
|
|
2597
|
+
config.setModel('gemini-2.5-pro');
|
|
2598
|
+
expect(mockCoreEvents.emitQuotaChanged).toHaveBeenCalledWith(10, 50, undefined);
|
|
2599
|
+
});
|
|
2340
2600
|
});
|
|
2341
2601
|
describe('refreshUserQuotaIfStale', () => {
|
|
2342
2602
|
beforeEach(() => {
|
|
@@ -2521,7 +2781,97 @@ describe('Config JIT Initialization', () => {
|
|
|
2521
2781
|
expect(MemoryContextManager).not.toHaveBeenCalled();
|
|
2522
2782
|
expect(config.getUserMemory()).toBe('Initial Memory');
|
|
2523
2783
|
});
|
|
2524
|
-
describe('
|
|
2784
|
+
describe('isMemoryV2Enabled', () => {
|
|
2785
|
+
it('should default to true', () => {
|
|
2786
|
+
const params = {
|
|
2787
|
+
sessionId: 'test-session',
|
|
2788
|
+
targetDir: '/tmp/test',
|
|
2789
|
+
debugMode: false,
|
|
2790
|
+
model: 'test-model',
|
|
2791
|
+
cwd: '/tmp/test',
|
|
2792
|
+
};
|
|
2793
|
+
config = new Config(params);
|
|
2794
|
+
expect(config.isMemoryV2Enabled()).toBe(true);
|
|
2795
|
+
});
|
|
2796
|
+
it('should return false when experimentalMemoryV2 is explicitly false', () => {
|
|
2797
|
+
const params = {
|
|
2798
|
+
sessionId: 'test-session',
|
|
2799
|
+
targetDir: '/tmp/test',
|
|
2800
|
+
debugMode: false,
|
|
2801
|
+
model: 'test-model',
|
|
2802
|
+
cwd: '/tmp/test',
|
|
2803
|
+
experimentalMemoryV2: false,
|
|
2804
|
+
};
|
|
2805
|
+
config = new Config(params);
|
|
2806
|
+
expect(config.isMemoryV2Enabled()).toBe(false);
|
|
2807
|
+
});
|
|
2808
|
+
it('should return true when experimentalMemoryV2 is true', () => {
|
|
2809
|
+
const params = {
|
|
2810
|
+
sessionId: 'test-session',
|
|
2811
|
+
targetDir: '/tmp/test',
|
|
2812
|
+
debugMode: false,
|
|
2813
|
+
model: 'test-model',
|
|
2814
|
+
cwd: '/tmp/test',
|
|
2815
|
+
experimentalMemoryV2: true,
|
|
2816
|
+
};
|
|
2817
|
+
config = new Config(params);
|
|
2818
|
+
expect(config.isMemoryV2Enabled()).toBe(true);
|
|
2819
|
+
});
|
|
2820
|
+
it('should NOT add the global ~/.cell-cli directory to the workspace when enabled', async () => {
|
|
2821
|
+
// The prompt-driven memoryV2 mode does not broaden the workspace
|
|
2822
|
+
// to include the global ~/.cell-cli/ directory. Cross-project personal
|
|
2823
|
+
// preferences are routed to ~/.cell-cli/GEMINI.md via the surgical
|
|
2824
|
+
// isPathAllowed allowlist instead — see the next two tests.
|
|
2825
|
+
const params = {
|
|
2826
|
+
sessionId: 'test-session',
|
|
2827
|
+
targetDir: '/tmp/test',
|
|
2828
|
+
debugMode: false,
|
|
2829
|
+
model: 'test-model',
|
|
2830
|
+
cwd: '/tmp/test',
|
|
2831
|
+
experimentalMemoryV2: true,
|
|
2832
|
+
};
|
|
2833
|
+
config = new Config(params);
|
|
2834
|
+
await config.initialize();
|
|
2835
|
+
const directories = config.getWorkspaceContext().getDirectories();
|
|
2836
|
+
expect(directories).not.toContain(Storage.getGlobalGeminiDir());
|
|
2837
|
+
});
|
|
2838
|
+
it('should allow isPathAllowed to write the global ~/.cell-cli/GEMINI.md file', async () => {
|
|
2839
|
+
// Surgical allowlist: when memoryV2 is on, the prompt routes
|
|
2840
|
+
// cross-project personal preferences to ~/.cell-cli/GEMINI.md, so the
|
|
2841
|
+
// agent must be able to edit that exact file via edit/write_file.
|
|
2842
|
+
const params = {
|
|
2843
|
+
sessionId: 'test-session',
|
|
2844
|
+
targetDir: '/tmp/test',
|
|
2845
|
+
debugMode: false,
|
|
2846
|
+
model: 'test-model',
|
|
2847
|
+
cwd: '/tmp/test',
|
|
2848
|
+
experimentalMemoryV2: true,
|
|
2849
|
+
};
|
|
2850
|
+
config = new Config(params);
|
|
2851
|
+
await config.initialize();
|
|
2852
|
+
const globalGeminiMdPath = path.join(Storage.getGlobalGeminiDir(), 'GEMINI.md');
|
|
2853
|
+
expect(config.isPathAllowed(globalGeminiMdPath)).toBe(true);
|
|
2854
|
+
});
|
|
2855
|
+
it('should NOT allow isPathAllowed to write other files under ~/.cell-cli/ (least privilege)', async () => {
|
|
2856
|
+
// The allowlist is surgical: only ~/.cell-cli/GEMINI.md is reachable.
|
|
2857
|
+
// settings.json, keybindings.json, credentials, etc. remain disallowed.
|
|
2858
|
+
const params = {
|
|
2859
|
+
sessionId: 'test-session',
|
|
2860
|
+
targetDir: '/tmp/test',
|
|
2861
|
+
debugMode: false,
|
|
2862
|
+
model: 'test-model',
|
|
2863
|
+
cwd: '/tmp/test',
|
|
2864
|
+
experimentalMemoryV2: true,
|
|
2865
|
+
};
|
|
2866
|
+
config = new Config(params);
|
|
2867
|
+
await config.initialize();
|
|
2868
|
+
const globalDir = Storage.getGlobalGeminiDir();
|
|
2869
|
+
expect(config.isPathAllowed(path.join(globalDir, 'settings.json'))).toBe(false);
|
|
2870
|
+
expect(config.isPathAllowed(path.join(globalDir, 'keybindings.json'))).toBe(false);
|
|
2871
|
+
expect(config.isPathAllowed(path.join(globalDir, 'oauth_creds.json'))).toBe(false);
|
|
2872
|
+
});
|
|
2873
|
+
});
|
|
2874
|
+
describe('isAutoMemoryEnabled', () => {
|
|
2525
2875
|
it('should default to false', () => {
|
|
2526
2876
|
const params = {
|
|
2527
2877
|
sessionId: 'test-session',
|
|
@@ -2531,19 +2881,32 @@ describe('Config JIT Initialization', () => {
|
|
|
2531
2881
|
cwd: '/tmp/test',
|
|
2532
2882
|
};
|
|
2533
2883
|
config = new Config(params);
|
|
2534
|
-
expect(config.
|
|
2884
|
+
expect(config.isAutoMemoryEnabled()).toBe(false);
|
|
2885
|
+
});
|
|
2886
|
+
it('should return true when experimentalAutoMemory is true', () => {
|
|
2887
|
+
const params = {
|
|
2888
|
+
sessionId: 'test-session',
|
|
2889
|
+
targetDir: '/tmp/test',
|
|
2890
|
+
debugMode: false,
|
|
2891
|
+
model: 'test-model',
|
|
2892
|
+
cwd: '/tmp/test',
|
|
2893
|
+
experimentalAutoMemory: true,
|
|
2894
|
+
};
|
|
2895
|
+
config = new Config(params);
|
|
2896
|
+
expect(config.isAutoMemoryEnabled()).toBe(true);
|
|
2535
2897
|
});
|
|
2536
|
-
it('should
|
|
2898
|
+
it('should be independent of experimentalMemoryV2', () => {
|
|
2537
2899
|
const params = {
|
|
2538
2900
|
sessionId: 'test-session',
|
|
2539
2901
|
targetDir: '/tmp/test',
|
|
2540
2902
|
debugMode: false,
|
|
2541
2903
|
model: 'test-model',
|
|
2542
2904
|
cwd: '/tmp/test',
|
|
2543
|
-
|
|
2905
|
+
experimentalMemoryV2: true,
|
|
2544
2906
|
};
|
|
2545
2907
|
config = new Config(params);
|
|
2546
|
-
expect(config.
|
|
2908
|
+
expect(config.isMemoryV2Enabled()).toBe(true);
|
|
2909
|
+
expect(config.isAutoMemoryEnabled()).toBe(false);
|
|
2547
2910
|
});
|
|
2548
2911
|
});
|
|
2549
2912
|
describe('reloadSkills', () => {
|