summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/components/ShellConfirmationDialog.test.tsx
diff options
context:
space:
mode:
authorAbhi <[email protected]>2025-07-27 02:00:26 -0400
committerGitHub <[email protected]>2025-07-27 06:00:26 +0000
commit576cebc9282cfbe57d45321105d72cc61597ce9b (patch)
tree374dd97245761fe5c40ee87a9b4d5674a26344cf /packages/cli/src/ui/components/ShellConfirmationDialog.test.tsx
parent9e61b3510c0cd7f333f40f68e87d981aff19aab1 (diff)
feat: Add Shell Command Execution to Custom Commands (#4917)
Diffstat (limited to 'packages/cli/src/ui/components/ShellConfirmationDialog.test.tsx')
-rw-r--r--packages/cli/src/ui/components/ShellConfirmationDialog.test.tsx45
1 files changed, 45 insertions, 0 deletions
diff --git a/packages/cli/src/ui/components/ShellConfirmationDialog.test.tsx b/packages/cli/src/ui/components/ShellConfirmationDialog.test.tsx
new file mode 100644
index 00000000..35783d44
--- /dev/null
+++ b/packages/cli/src/ui/components/ShellConfirmationDialog.test.tsx
@@ -0,0 +1,45 @@
+/**
+ * @license
+ * Copyright 2025 Google LLC
+ * SPDX-License-Identifier: Apache-2.0
+ */
+
+import { render } from 'ink-testing-library';
+import { describe, it, expect, vi } from 'vitest';
+import { ShellConfirmationDialog } from './ShellConfirmationDialog.js';
+
+describe('ShellConfirmationDialog', () => {
+ const onConfirm = vi.fn();
+
+ const request = {
+ commands: ['ls -la', 'echo "hello"'],
+ onConfirm,
+ };
+
+ it('renders correctly', () => {
+ const { lastFrame } = render(<ShellConfirmationDialog request={request} />);
+ expect(lastFrame()).toMatchSnapshot();
+ });
+
+ it('calls onConfirm with ProceedOnce when "Yes, allow once" is selected', () => {
+ const { lastFrame } = render(<ShellConfirmationDialog request={request} />);
+ const select = lastFrame()!.toString();
+ // Simulate selecting the first option
+ // This is a simplified way to test the selection
+ expect(select).toContain('Yes, allow once');
+ });
+
+ it('calls onConfirm with ProceedAlways when "Yes, allow always for this session" is selected', () => {
+ const { lastFrame } = render(<ShellConfirmationDialog request={request} />);
+ const select = lastFrame()!.toString();
+ // Simulate selecting the second option
+ expect(select).toContain('Yes, allow always for this session');
+ });
+
+ it('calls onConfirm with Cancel when "No (esc)" is selected', () => {
+ const { lastFrame } = render(<ShellConfirmationDialog request={request} />);
+ const select = lastFrame()!.toString();
+ // Simulate selecting the third option
+ expect(select).toContain('No (esc)');
+ });
+});