summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/hooks/useCompletion.integration.test.ts
diff options
context:
space:
mode:
authorDeWitt Clinton <[email protected]>2025-06-12 07:09:38 -0700
committerGitHub <[email protected]>2025-06-12 07:09:38 -0700
commitf2ab6d08c4cd0ca9a5b3900a6bb66a083c0577ee (patch)
treedb2083848fc070f0de6ac4fe385f59e71a04fc46 /packages/cli/src/ui/hooks/useCompletion.integration.test.ts
parent9072a4e5ee5d6a8b524be40b0465b66e5d3dceba (diff)
Improve the performance of filename completion over large repositories. (#938)
Diffstat (limited to 'packages/cli/src/ui/hooks/useCompletion.integration.test.ts')
-rw-r--r--packages/cli/src/ui/hooks/useCompletion.integration.test.ts24
1 files changed, 24 insertions, 0 deletions
diff --git a/packages/cli/src/ui/hooks/useCompletion.integration.test.ts b/packages/cli/src/ui/hooks/useCompletion.integration.test.ts
index 683d3cb1..c38006c3 100644
--- a/packages/cli/src/ui/hooks/useCompletion.integration.test.ts
+++ b/packages/cli/src/ui/hooks/useCompletion.integration.test.ts
@@ -42,6 +42,7 @@ describe('useCompletion git-aware filtering integration', () => {
shouldIgnoreFile: vi.fn(),
filterFiles: vi.fn(),
getIgnoreInfo: vi.fn(() => ({ gitIgnored: [], customIgnored: [] })),
+ glob: vi.fn().mockResolvedValue([]),
};
mockConfig = {
@@ -225,4 +226,27 @@ describe('useCompletion git-aware filtering integration', () => {
{ label: 'component.tsx', value: 'component.tsx' },
]);
});
+
+ it('should use glob for top-level @ completions when available', async () => {
+ const globResults = [`${testCwd}/src/index.ts`, `${testCwd}/README.md`];
+ mockFileDiscoveryService.glob.mockResolvedValue(globResults);
+
+ const { result } = renderHook(() =>
+ useCompletion('@s', testCwd, true, slashCommands, mockConfig),
+ );
+
+ await act(async () => {
+ await new Promise((resolve) => setTimeout(resolve, 150));
+ });
+
+ expect(mockFileDiscoveryService.glob).toHaveBeenCalledWith('**/s*', {
+ cwd: testCwd,
+ dot: true,
+ });
+ expect(fs.readdir).not.toHaveBeenCalled(); // Ensure glob is used instead of readdir
+ expect(result.current.suggestions).toEqual([
+ { label: 'README.md', value: 'README.md' },
+ { label: 'src/index.ts', value: 'src/index.ts' },
+ ]);
+ });
});