summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts
diff options
context:
space:
mode:
authorharoldmciver-go <[email protected]>2025-07-14 12:22:37 -0400
committerGitHub <[email protected]>2025-07-14 16:22:37 +0000
commitc313c3dee1872a0edc943ad096eab68a03a3dda5 (patch)
tree2674ca3a913af495579f78ebd0e2c22009c7d0c9 /packages/cli/src/ui/hooks/slashCommandProcessor.test.ts
parent80c81f2a4cafd88333defa6b86b69f572dfec5d0 (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.ts27
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',