diff options
| author | DeWitt Clinton <[email protected]> | 2025-06-12 07:09:38 -0700 |
|---|---|---|
| committer | GitHub <[email protected]> | 2025-06-12 07:09:38 -0700 |
| commit | f2ab6d08c4cd0ca9a5b3900a6bb66a083c0577ee (patch) | |
| tree | db2083848fc070f0de6ac4fe385f59e71a04fc46 /packages/cli/src/ui/hooks/useCompletion.integration.test.ts | |
| parent | 9072a4e5ee5d6a8b524be40b0465b66e5d3dceba (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.ts | 24 |
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' }, + ]); + }); }); |
