shlink-web-client/test/visits/charts/DoughnutChartLegend.test.tsx

34 lines
1.2 KiB
TypeScript
Raw Normal View History

2021-09-18 12:59:54 +02:00
import { shallow } from 'enzyme';
import { Mock } from 'ts-mockery';
import { Chart, ChartDataset } from 'chart.js';
import { DoughnutChartLegend } from '../../../src/visits/charts/DoughnutChartLegend';
2021-09-18 12:59:54 +02:00
describe('<DoughnutChartLegend />', () => {
2022-03-26 12:17:42 +01:00
const labels = ['foo', 'bar', 'baz', 'foo2', 'bar2'];
const colors = ['foo_color', 'bar_color', 'baz_color'];
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,
},
});
it('renders the expected amount of items with expected colors and labels', () => {
const wrapper = shallow(<DoughnutChartLegend chart={chart} />);
2021-09-18 12:59:54 +02:00
const items = wrapper.find('li');
expect.assertions(labels.length * 2 + 1);
expect(items).toHaveLength(labels.length);
labels.forEach((label, index) => {
const item = items.at(index);
expect(item.find('.doughnut-chart-legend__item-color').prop('style')).toEqual({
2021-09-18 12:59:54 +02:00
backgroundColor: colors[index] ?? defaultColor,
});
expect(item.find('.doughnut-chart-legend__item-text').text()).toEqual(label);
2021-09-18 12:59:54 +02:00
});
});
});