mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-05-04 08:54:28 -07:00
49 lines
1.2 KiB
TypeScript
49 lines
1.2 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2025 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import { describe, it, expect, afterEach, vi } from 'vitest';
|
|
import { renderWithProviders } from '../../../test-utils/render.js';
|
|
import { SectionHeader } from './SectionHeader.js';
|
|
|
|
describe('<SectionHeader />', () => {
|
|
afterEach(() => {
|
|
vi.restoreAllMocks();
|
|
});
|
|
|
|
it.each([
|
|
{
|
|
description: 'renders correctly with a standard title',
|
|
title: 'My Header',
|
|
width: 40,
|
|
},
|
|
{
|
|
description:
|
|
'renders correctly when title is truncated but still shows dashes',
|
|
title: 'Very Long Header Title That Will Truncate',
|
|
width: 20,
|
|
},
|
|
{
|
|
description: 'renders correctly in a narrow container',
|
|
title: 'Narrow Container',
|
|
width: 25,
|
|
},
|
|
{
|
|
description: 'renders correctly with a subtitle',
|
|
title: 'Shortcuts',
|
|
subtitle: ' See /help for more',
|
|
width: 40,
|
|
},
|
|
])('$description', async ({ title, subtitle, width }) => {
|
|
const { lastFrame, unmount } = await renderWithProviders(
|
|
<SectionHeader title={title} subtitle={subtitle} />,
|
|
{ width },
|
|
);
|
|
|
|
expect(lastFrame()).toMatchSnapshot();
|
|
unmount();
|
|
});
|
|
});
|