summaryrefslogtreecommitdiff
path: root/packages/core/src/config/config.test.ts
diff options
context:
space:
mode:
authorYuki Okita <[email protected]>2025-07-31 05:38:20 +0900
committerGitHub <[email protected]>2025-07-30 20:38:20 +0000
commitc1fe6889569610878c45216556fb99424b5bcba4 (patch)
treeb96f5f66bc00426fcd3e4b87402067342abbce12 /packages/core/src/config/config.test.ts
parent21965f986c8aa99da5a0f8e52ae823bb2f040d7a (diff)
feat: Multi-Directory Workspace Support (part1: add `--include-directories` option) (#4605)
Co-authored-by: Allen Hutchison <[email protected]>
Diffstat (limited to 'packages/core/src/config/config.test.ts')
-rw-r--r--packages/core/src/config/config.test.ts29
1 files changed, 29 insertions, 0 deletions
diff --git a/packages/core/src/config/config.test.ts b/packages/core/src/config/config.test.ts
index f2169790..dcc81b4f 100644
--- a/packages/core/src/config/config.test.ts
+++ b/packages/core/src/config/config.test.ts
@@ -19,6 +19,18 @@ import {
import { GeminiClient } from '../core/client.js';
import { GitService } from '../services/gitService.js';
+vi.mock('fs', async (importOriginal) => {
+ const actual = await importOriginal<typeof import('fs')>();
+ return {
+ ...actual,
+ existsSync: vi.fn().mockReturnValue(true),
+ statSync: vi.fn().mockReturnValue({
+ isDirectory: vi.fn().mockReturnValue(true),
+ }),
+ realpathSync: vi.fn((path) => path),
+ };
+});
+
// Mock dependencies that might be called during Config construction or createServerConfig
vi.mock('../tools/tool-registry', () => {
const ToolRegistryMock = vi.fn();
@@ -219,6 +231,23 @@ describe('Server Config (config.ts)', () => {
expect(config.getFileFilteringRespectGitIgnore()).toBe(false);
});
+ it('should initialize WorkspaceContext with includeDirectories', () => {
+ const includeDirectories = ['/path/to/dir1', '/path/to/dir2'];
+ const paramsWithIncludeDirs: ConfigParameters = {
+ ...baseParams,
+ includeDirectories,
+ };
+ const config = new Config(paramsWithIncludeDirs);
+ const workspaceContext = config.getWorkspaceContext();
+ const directories = workspaceContext.getDirectories();
+
+ // Should include the target directory plus the included directories
+ expect(directories).toHaveLength(3);
+ expect(directories).toContain(path.resolve(baseParams.targetDir));
+ expect(directories).toContain('/path/to/dir1');
+ expect(directories).toContain('/path/to/dir2');
+ });
+
it('Config constructor should set telemetry to true when provided as true', () => {
const paramsWithTelemetry: ConfigParameters = {
...baseParams,