2021-09-18 19:05:28 +02:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
|
|
|
import { Doughnut } from 'react-chartjs-2';
|
|
|
|
import { keys, values } from 'ramda';
|
|
|
|
import { DoughnutChart } from '../../../src/visits/charts/DoughnutChart';
|
|
|
|
|
2021-09-19 10:57:36 +02:00
|
|
|
describe('<DoughnutChart />', () => {
|
2021-09-18 19:05:28 +02:00
|
|
|
let wrapper: ShallowWrapper;
|
|
|
|
const stats = {
|
|
|
|
foo: 123,
|
|
|
|
bar: 456,
|
|
|
|
};
|
|
|
|
|
|
|
|
afterEach(() => wrapper?.unmount());
|
|
|
|
|
|
|
|
it('renders Doughnut with expected props', () => {
|
|
|
|
wrapper = shallow(<DoughnutChart stats={stats} />);
|
|
|
|
const doughnut = wrapper.find(Doughnut);
|
|
|
|
const cols = wrapper.find('.col-sm-12');
|
|
|
|
|
|
|
|
expect(doughnut).toHaveLength(1);
|
|
|
|
|
2022-03-07 18:06:28 +01:00
|
|
|
const { labels, datasets } = doughnut.prop('data') as any;
|
2021-09-18 19:05:28 +02:00
|
|
|
const [{ data, backgroundColor, borderColor }] = datasets;
|
2022-03-07 18:06:28 +01:00
|
|
|
const { plugins, scales } = (doughnut.prop('options') ?? {}) as any;
|
2021-09-18 19:05:28 +02:00
|
|
|
|
|
|
|
expect(labels).toEqual(keys(stats));
|
|
|
|
expect(data).toEqual(values(stats));
|
|
|
|
expect(datasets).toHaveLength(1);
|
|
|
|
expect(backgroundColor).toEqual([
|
|
|
|
'#97BBCD',
|
|
|
|
'#F7464A',
|
|
|
|
'#46BFBD',
|
|
|
|
'#FDB45C',
|
|
|
|
'#949FB1',
|
|
|
|
'#57A773',
|
|
|
|
'#414066',
|
|
|
|
'#08B2E3',
|
|
|
|
'#B6C454',
|
|
|
|
'#DCDCDC',
|
|
|
|
'#463730',
|
|
|
|
]);
|
|
|
|
expect(borderColor).toEqual('white');
|
|
|
|
expect(plugins.legend).toEqual({ display: false });
|
|
|
|
expect(scales).toBeUndefined();
|
|
|
|
expect(cols).toHaveLength(2);
|
|
|
|
});
|
|
|
|
});
|