2022-05-28 12:33:50 +02:00
|
|
|
import { render, screen } from '@testing-library/react';
|
2021-09-18 12:59:54 +02:00
|
|
|
import { Mock } from 'ts-mockery';
|
|
|
|
import { Chart, ChartDataset } from 'chart.js';
|
2021-09-18 19:05:28 +02:00
|
|
|
import { DoughnutChartLegend } from '../../../src/visits/charts/DoughnutChartLegend';
|
2021-09-18 12:59:54 +02:00
|
|
|
|
2021-09-18 19:05:28 +02:00
|
|
|
describe('<DoughnutChartLegend />', () => {
|
2022-03-26 12:17:42 +01:00
|
|
|
const labels = ['foo', 'bar', 'baz', 'foo2', 'bar2'];
|
2022-05-28 12:33:50 +02:00
|
|
|
const colors = ['green', 'blue', 'yellow'];
|
2021-09-18 12:59:54 +02:00
|
|
|
const defaultColor = 'red';
|
2022-03-26 12:17:42 +01:00
|
|
|
const datasets = [Mock.of<ChartDataset>({ backgroundColor: colors })];
|
2021-09-18 12:59:54 +02:00
|
|
|
const chart = Mock.of<Chart>({
|
|
|
|
config: {
|
|
|
|
data: { labels, datasets },
|
|
|
|
options: { defaultColor } as any,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2021-09-20 22:00:34 +02:00
|
|
|
it('renders the expected amount of items with expected colors and labels', () => {
|
2022-05-28 12:33:50 +02:00
|
|
|
render(<DoughnutChartLegend chart={chart} />);
|
|
|
|
|
|
|
|
const items = screen.getAllByRole('listitem');
|
2021-09-18 12:59:54 +02:00
|
|
|
|
|
|
|
expect.assertions(labels.length * 2 + 1);
|
|
|
|
expect(items).toHaveLength(labels.length);
|
2022-05-28 12:33:50 +02:00
|
|
|
|
2021-09-18 12:59:54 +02:00
|
|
|
labels.forEach((label, index) => {
|
2022-05-28 12:33:50 +02:00
|
|
|
const item = items[index];
|
2021-09-18 12:59:54 +02:00
|
|
|
|
2022-05-28 12:33:50 +02:00
|
|
|
expect(item.querySelector('.doughnut-chart-legend__item-color')).toHaveAttribute(
|
|
|
|
'style',
|
|
|
|
`background-color: ${colors[index] ?? defaultColor};`,
|
|
|
|
);
|
|
|
|
expect(item.querySelector('.doughnut-chart-legend__item-text')).toHaveTextContent(label);
|
2021-09-18 12:59:54 +02:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|