mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-03-10 22:21:22 -07:00
90 lines
2.3 KiB
TypeScript
90 lines
2.3 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2025 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import { renderWithProviders } from '../../../test-utils/render.js';
|
|
import { HalfLinePaddedBox } from './HalfLinePaddedBox.js';
|
|
import { Text, useIsScreenReaderEnabled } from 'ink';
|
|
import { describe, it, expect, vi, afterEach } from 'vitest';
|
|
import { isITerm2 } from '../../utils/terminalUtils.js';
|
|
|
|
vi.mock('ink', async () => {
|
|
const actual = await vi.importActual('ink');
|
|
return {
|
|
...actual,
|
|
useIsScreenReaderEnabled: vi.fn(() => false),
|
|
};
|
|
});
|
|
|
|
describe('<HalfLinePaddedBox />', () => {
|
|
const mockUseIsScreenReaderEnabled = vi.mocked(useIsScreenReaderEnabled);
|
|
|
|
afterEach(() => {
|
|
vi.restoreAllMocks();
|
|
});
|
|
|
|
it('renders standard background and blocks when not iTerm2', async () => {
|
|
vi.mocked(isITerm2).mockReturnValue(false);
|
|
|
|
const { lastFrame, unmount } = renderWithProviders(
|
|
<HalfLinePaddedBox backgroundBaseColor="blue" backgroundOpacity={0.5}>
|
|
<Text>Content</Text>
|
|
</HalfLinePaddedBox>,
|
|
{ width: 10 },
|
|
);
|
|
|
|
expect(lastFrame()).toMatchSnapshot();
|
|
|
|
unmount();
|
|
});
|
|
|
|
it('renders iTerm2-specific blocks when iTerm2 is detected', async () => {
|
|
vi.mocked(isITerm2).mockReturnValue(true);
|
|
|
|
const { lastFrame, unmount } = renderWithProviders(
|
|
<HalfLinePaddedBox backgroundBaseColor="blue" backgroundOpacity={0.5}>
|
|
<Text>Content</Text>
|
|
</HalfLinePaddedBox>,
|
|
{ width: 10 },
|
|
);
|
|
|
|
expect(lastFrame()).toMatchSnapshot();
|
|
|
|
unmount();
|
|
});
|
|
|
|
it('renders nothing when useBackgroundColor is false', async () => {
|
|
const { lastFrame, unmount } = renderWithProviders(
|
|
<HalfLinePaddedBox
|
|
backgroundBaseColor="blue"
|
|
backgroundOpacity={0.5}
|
|
useBackgroundColor={false}
|
|
>
|
|
<Text>Content</Text>
|
|
</HalfLinePaddedBox>,
|
|
{ width: 10 },
|
|
);
|
|
|
|
expect(lastFrame()).toMatchSnapshot();
|
|
|
|
unmount();
|
|
});
|
|
|
|
it('renders nothing when screen reader is enabled', async () => {
|
|
mockUseIsScreenReaderEnabled.mockReturnValue(true);
|
|
|
|
const { lastFrame, unmount } = renderWithProviders(
|
|
<HalfLinePaddedBox backgroundBaseColor="blue" backgroundOpacity={0.5}>
|
|
<Text>Content</Text>
|
|
</HalfLinePaddedBox>,
|
|
{ width: 10 },
|
|
);
|
|
|
|
expect(lastFrame()).toMatchSnapshot();
|
|
|
|
unmount();
|
|
});
|
|
});
|