diff options
| author | Lee Won Jun <[email protected]> | 2025-07-16 08:45:10 +0900 |
|---|---|---|
| committer | GitHub <[email protected]> | 2025-07-15 23:45:10 +0000 |
| commit | ec5e9d1025fee66938153140b5f37e35b50c67ed (patch) | |
| tree | b3e50ec98036388dfee14fa20407988c2c60eae9 /packages/cli/src/ui/hooks/useCompletion.test.ts | |
| parent | 615748657aaf5c0b5d19c7ff046346a29275ed81 (diff) | |
Improve altName completion behavior in slash commands (#4227)
Co-authored-by: Jacob Richman <[email protected]>
Diffstat (limited to 'packages/cli/src/ui/hooks/useCompletion.test.ts')
| -rw-r--r-- | packages/cli/src/ui/hooks/useCompletion.test.ts | 38 |
1 files changed, 31 insertions, 7 deletions
diff --git a/packages/cli/src/ui/hooks/useCompletion.test.ts b/packages/cli/src/ui/hooks/useCompletion.test.ts index b2790808..7f2823c7 100644 --- a/packages/cli/src/ui/hooks/useCompletion.test.ts +++ b/packages/cli/src/ui/hooks/useCompletion.test.ts @@ -65,6 +65,12 @@ describe('useCompletion', () => { action: vi.fn(), }, { + name: 'stats', + altName: 'usage', + description: 'check session stats. Usage: /stats [model|tools]', + action: vi.fn(), + }, + { name: 'clear', description: 'Clear the screen', action: vi.fn(), @@ -299,7 +305,7 @@ describe('useCompletion', () => { ), ); - expect(result.current.suggestions.length).toBe(4); + expect(result.current.suggestions.length).toBe(5); expect(result.current.activeSuggestionIndex).toBe(0); act(() => { @@ -325,7 +331,7 @@ describe('useCompletion', () => { act(() => { result.current.navigateUp(); }); - expect(result.current.activeSuggestionIndex).toBe(3); + expect(result.current.activeSuggestionIndex).toBe(4); }); it('should handle navigation with large suggestion lists and scrolling', () => { @@ -372,9 +378,9 @@ describe('useCompletion', () => { ), ); - expect(result.current.suggestions).toHaveLength(4); + expect(result.current.suggestions).toHaveLength(5); expect(result.current.suggestions.map((s) => s.label)).toEqual( - expect.arrayContaining(['help', 'clear', 'memory', 'chat']), + expect.arrayContaining(['help', 'clear', 'memory', 'chat', 'stats']), ); expect(result.current.showSuggestions).toBe(true); expect(result.current.activeSuggestionIndex).toBe(0); @@ -397,10 +403,28 @@ describe('useCompletion', () => { expect(result.current.suggestions[0].description).toBe('Show help'); }); - it('should suggest commands by altName', () => { + it.each([['/?'], ['/usage']])( + 'should not suggest commands when altName is fully typed', + (altName) => { + const { result } = renderHook(() => + useCompletion( + altName, + testCwd, + true, + mockSlashCommands, + mockCommandContext, + mockConfig, + ), + ); + + expect(result.current.suggestions).toHaveLength(0); + }, + ); + + it('should suggest commands based on partial altName matches', () => { const { result } = renderHook(() => useCompletion( - '/?', + '/usag', // part of the word "usage" testCwd, true, mockSlashCommands, @@ -410,7 +434,7 @@ describe('useCompletion', () => { ); expect(result.current.suggestions).toHaveLength(1); - expect(result.current.suggestions[0].label).toBe('help'); + expect(result.current.suggestions[0].label).toBe('stats'); }); it('should not show suggestions for exact leaf command match', () => { |
