summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/commands/terminalSetupCommand.test.ts
diff options
context:
space:
mode:
authorDeepankar Sharma <[email protected]>2025-08-13 13:32:54 -0400
committerGitHub <[email protected]>2025-08-13 17:32:54 +0000
commit9c7fb870c1a7c80741fafdfc6837d4b92e373b2d (patch)
tree1e31f201520c9724b4659ee7a36c21215e6280b9 /packages/cli/src/ui/commands/terminalSetupCommand.test.ts
parent74a13fb535b255797d6c9aa3499acfea6aadc58d (diff)
Add terminal setup command for Shift+Enter and Ctrl+Enter support (#3289)
Co-authored-by: jacob314 <[email protected]>
Diffstat (limited to 'packages/cli/src/ui/commands/terminalSetupCommand.test.ts')
-rw-r--r--packages/cli/src/ui/commands/terminalSetupCommand.test.ts85
1 files changed, 85 insertions, 0 deletions
diff --git a/packages/cli/src/ui/commands/terminalSetupCommand.test.ts b/packages/cli/src/ui/commands/terminalSetupCommand.test.ts
new file mode 100644
index 00000000..85f8735e
--- /dev/null
+++ b/packages/cli/src/ui/commands/terminalSetupCommand.test.ts
@@ -0,0 +1,85 @@
+/**
+ * @license
+ * Copyright 2025 Google LLC
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import { describe, it, expect, vi, beforeEach } from 'vitest';
+import { terminalSetupCommand } from './terminalSetupCommand.js';
+import * as terminalSetupModule from '../utils/terminalSetup.js';
+import { CommandContext } from './types.js';
+
+vi.mock('../utils/terminalSetup.js');
+
+describe('terminalSetupCommand', () => {
+ beforeEach(() => {
+ vi.clearAllMocks();
+ });
+
+ it('should have correct metadata', () => {
+ expect(terminalSetupCommand.name).toBe('terminal-setup');
+ expect(terminalSetupCommand.description).toContain('multiline input');
+ expect(terminalSetupCommand.kind).toBe('built-in');
+ });
+
+ it('should return success message when terminal setup succeeds', async () => {
+ vi.spyOn(terminalSetupModule, 'terminalSetup').mockResolvedValue({
+ success: true,
+ message: 'Terminal configured successfully',
+ });
+
+ const result = await terminalSetupCommand.action({} as CommandContext, '');
+
+ expect(result).toEqual({
+ type: 'message',
+ content: 'Terminal configured successfully',
+ messageType: 'info',
+ });
+ });
+
+ it('should append restart message when terminal setup requires restart', async () => {
+ vi.spyOn(terminalSetupModule, 'terminalSetup').mockResolvedValue({
+ success: true,
+ message: 'Terminal configured successfully',
+ requiresRestart: true,
+ });
+
+ const result = await terminalSetupCommand.action({} as CommandContext, '');
+
+ expect(result).toEqual({
+ type: 'message',
+ content:
+ 'Terminal configured successfully\n\nPlease restart your terminal for the changes to take effect.',
+ messageType: 'info',
+ });
+ });
+
+ it('should return error message when terminal setup fails', async () => {
+ vi.spyOn(terminalSetupModule, 'terminalSetup').mockResolvedValue({
+ success: false,
+ message: 'Failed to detect terminal',
+ });
+
+ const result = await terminalSetupCommand.action({} as CommandContext, '');
+
+ expect(result).toEqual({
+ type: 'message',
+ content: 'Failed to detect terminal',
+ messageType: 'error',
+ });
+ });
+
+ it('should handle exceptions from terminal setup', async () => {
+ vi.spyOn(terminalSetupModule, 'terminalSetup').mockRejectedValue(
+ new Error('Unexpected error'),
+ );
+
+ const result = await terminalSetupCommand.action({} as CommandContext, '');
+
+ expect(result).toEqual({
+ type: 'message',
+ content: 'Failed to configure terminal: Error: Unexpected error',
+ messageType: 'error',
+ });
+ });
+});