2022-05-13 19:59:30 +02:00
|
|
|
import { render, screen } from '@testing-library/react';
|
2023-02-18 11:11:01 +01:00
|
|
|
import type { ReactNode } from 'react';
|
2021-09-18 19:05:28 +02:00
|
|
|
import { ChartCard } from '../../../src/visits/charts/ChartCard';
|
2020-06-06 12:16:19 +02:00
|
|
|
|
2021-09-18 19:05:28 +02:00
|
|
|
describe('<ChartCard />', () => {
|
2022-05-13 19:59:30 +02:00
|
|
|
const setUp = (title: Function | string = '', footer?: ReactNode) => render(
|
|
|
|
<ChartCard title={title} footer={footer} />,
|
|
|
|
);
|
2020-06-06 12:16:19 +02:00
|
|
|
|
|
|
|
it.each([
|
2022-03-26 12:17:42 +01:00
|
|
|
['the title', 'the title'],
|
|
|
|
[() => 'the title from func', 'the title from func'],
|
2020-06-06 12:16:19 +02:00
|
|
|
])('properly renders title by parsing provided value', (title, expectedTitle) => {
|
2022-05-13 19:59:30 +02:00
|
|
|
setUp(title);
|
|
|
|
expect(screen.getByText(expectedTitle)).toBeInTheDocument();
|
2020-06-06 12:16:19 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
it('renders footer only when provided', () => {
|
2022-05-13 19:59:30 +02:00
|
|
|
setUp('', 'the footer');
|
|
|
|
expect(screen.getByText('the footer')).toBeInTheDocument();
|
2020-06-06 12:16:19 +02:00
|
|
|
});
|
|
|
|
});
|