diff options
| author | haroldmciver-go <[email protected]> | 2025-07-14 12:22:37 -0400 |
|---|---|---|
| committer | GitHub <[email protected]> | 2025-07-14 16:22:37 +0000 |
| commit | c313c3dee1872a0edc943ad096eab68a03a3dda5 (patch) | |
| tree | 2674ca3a913af495579f78ebd0e2c22009c7d0c9 /packages/cli/src/ui/hooks/slashCommandProcessor.test.ts | |
| parent | 80c81f2a4cafd88333defa6b86b69f572dfec5d0 (diff) | |
updated '/auth' to use new slash command arch (#3797)
Co-authored-by: Abhi <[email protected]>
Diffstat (limited to 'packages/cli/src/ui/hooks/slashCommandProcessor.test.ts')
| -rw-r--r-- | packages/cli/src/ui/hooks/slashCommandProcessor.test.ts | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts b/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts index 563092a2..d920117d 100644 --- a/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts +++ b/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts @@ -507,6 +507,33 @@ describe('useSlashCommandProcessor', () => { expect(commandResult).toEqual({ type: 'handled' }); }); + it('should open the auth dialog when a new command returns an auth dialog action', async () => { + const mockAction = vi.fn().mockResolvedValue({ + type: 'dialog', + dialog: 'auth', + }); + const newAuthCommand: SlashCommand = { name: 'auth', action: mockAction }; + + const mockLoader = async () => [newAuthCommand]; + const commandServiceInstance = new ActualCommandService(mockLoader); + vi.mocked(CommandService).mockImplementation( + () => commandServiceInstance, + ); + + const { result } = getProcessorHook(); + await vi.waitFor(() => { + expect( + result.current.slashCommands.some((c) => c.name === 'auth'), + ).toBe(true); + }); + + const commandResult = await result.current.handleSlashCommand('/auth'); + + expect(mockAction).toHaveBeenCalledTimes(1); + expect(mockOpenAuthDialog).toHaveBeenCalledWith(); + expect(commandResult).toEqual({ type: 'handled' }); + }); + it('should open the theme dialog when a new command returns a theme dialog action', async () => { const mockAction = vi.fn().mockResolvedValue({ type: 'dialog', |
