mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-10 18:27:25 +03:00
Migrated DoughnutChartLegend test to react testing library
This commit is contained in:
parent
56150e8707
commit
89f830d9bb
1 changed files with 13 additions and 10 deletions
|
@ -1,11 +1,11 @@
|
|||
import { shallow } from 'enzyme';
|
||||
import { render, screen } from '@testing-library/react';
|
||||
import { Mock } from 'ts-mockery';
|
||||
import { Chart, ChartDataset } from 'chart.js';
|
||||
import { DoughnutChartLegend } from '../../../src/visits/charts/DoughnutChartLegend';
|
||||
|
||||
describe('<DoughnutChartLegend />', () => {
|
||||
const labels = ['foo', 'bar', 'baz', 'foo2', 'bar2'];
|
||||
const colors = ['foo_color', 'bar_color', 'baz_color'];
|
||||
const colors = ['green', 'blue', 'yellow'];
|
||||
const defaultColor = 'red';
|
||||
const datasets = [Mock.of<ChartDataset>({ backgroundColor: colors })];
|
||||
const chart = Mock.of<Chart>({
|
||||
|
@ -16,18 +16,21 @@ describe('<DoughnutChartLegend />', () => {
|
|||
});
|
||||
|
||||
it('renders the expected amount of items with expected colors and labels', () => {
|
||||
const wrapper = shallow(<DoughnutChartLegend chart={chart} />);
|
||||
const items = wrapper.find('li');
|
||||
render(<DoughnutChartLegend chart={chart} />);
|
||||
|
||||
const items = screen.getAllByRole('listitem');
|
||||
|
||||
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({
|
||||
backgroundColor: colors[index] ?? defaultColor,
|
||||
});
|
||||
expect(item.find('.doughnut-chart-legend__item-text').text()).toEqual(label);
|
||||
labels.forEach((label, index) => {
|
||||
const item = items[index];
|
||||
|
||||
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);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Reference in a new issue