2022-07-11 19:26:52 +03:00
|
|
|
import { screen } from '@testing-library/react';
|
2020-09-04 19:43:26 +03:00
|
|
|
import { range } from 'ramda';
|
2023-02-18 13:11:01 +03:00
|
|
|
import type { ReactNode } from 'react';
|
2023-07-16 09:47:10 +03:00
|
|
|
import { SortableBarChartCard } from '../../../src/shlink-web-component/visits/charts/SortableBarChartCard';
|
|
|
|
import type { Stats } from '../../../src/shlink-web-component/visits/types';
|
2021-11-01 14:48:11 +03:00
|
|
|
import { rangeOf } from '../../../src/utils/utils';
|
2022-07-11 19:26:52 +03:00
|
|
|
import { renderWithEvents } from '../../__helpers__/setUpTest';
|
2019-01-13 01:47:41 +03:00
|
|
|
|
2021-09-18 20:05:28 +03:00
|
|
|
describe('<SortableBarChartCard />', () => {
|
2019-01-13 01:47:41 +03:00
|
|
|
const sortingItems = {
|
|
|
|
name: 'Name',
|
|
|
|
amount: 'Amount',
|
|
|
|
};
|
|
|
|
const stats = {
|
|
|
|
Foo: 100,
|
|
|
|
Bar: 50,
|
|
|
|
};
|
2022-07-11 19:26:52 +03:00
|
|
|
const setUp = (withPagination = false, extraStats = {}, extra?: (foo?: string[]) => ReactNode) => renderWithEvents(
|
|
|
|
<SortableBarChartCard
|
|
|
|
title="Foo"
|
|
|
|
stats={{ ...stats, ...extraStats }}
|
|
|
|
sortingItems={sortingItems}
|
|
|
|
withPagination={withPagination}
|
|
|
|
extraHeaderContent={extra}
|
|
|
|
/>,
|
|
|
|
);
|
2019-01-13 01:47:41 +03:00
|
|
|
|
|
|
|
it('renders stats unchanged when no ordering is set', () => {
|
2022-07-11 19:26:52 +03:00
|
|
|
const { container } = setUp();
|
2019-01-13 01:47:41 +03:00
|
|
|
|
2022-07-11 19:26:52 +03:00
|
|
|
expect(container.firstChild).not.toBeNull();
|
|
|
|
expect(container.firstChild).toMatchSnapshot();
|
2019-01-13 01:47:41 +03:00
|
|
|
});
|
|
|
|
|
2022-07-11 19:26:52 +03:00
|
|
|
it.each([
|
|
|
|
['Name', 1],
|
|
|
|
['Amount', 1],
|
|
|
|
['Name', 2],
|
|
|
|
['Amount', 2],
|
|
|
|
])('renders properly ordered stats when ordering is set', async (name, clicks) => {
|
|
|
|
const { user } = setUp();
|
2019-01-13 01:47:41 +03:00
|
|
|
|
2022-07-11 19:26:52 +03:00
|
|
|
await user.click(screen.getByRole('button'));
|
|
|
|
await Promise.all(rangeOf(clicks, async () => user.click(screen.getByRole('menuitem', { name }))));
|
2019-01-13 01:47:41 +03:00
|
|
|
|
2022-07-11 19:26:52 +03:00
|
|
|
expect(screen.getByRole('document')).toMatchSnapshot();
|
2019-01-13 01:47:41 +03:00
|
|
|
});
|
|
|
|
|
2022-07-11 19:26:52 +03:00
|
|
|
it.each([
|
|
|
|
[0],
|
|
|
|
[1],
|
|
|
|
[2],
|
|
|
|
[3],
|
|
|
|
])('renders properly paginated stats when pagination is set', async (itemIndex) => {
|
|
|
|
const { user } = setUp(true, range(1, 159).reduce<Stats>((accum, value) => {
|
|
|
|
accum[`key_${value}`] = value;
|
|
|
|
return accum;
|
|
|
|
}, {}));
|
|
|
|
|
|
|
|
await user.click(screen.getAllByRole('button')[1]);
|
|
|
|
await user.click(screen.getAllByRole('menuitem')[itemIndex]);
|
|
|
|
|
|
|
|
expect(screen.getByRole('document')).toMatchSnapshot();
|
2019-03-10 19:55:02 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
it('renders extra header content', () => {
|
2022-07-11 19:26:52 +03:00
|
|
|
setUp(false, {}, () => (
|
2019-03-10 19:55:02 +03:00
|
|
|
<span>
|
2022-07-11 19:26:52 +03:00
|
|
|
<span className="foo-span">Foo in header</span>
|
|
|
|
<span className="bar-span">Bar in header</span>
|
|
|
|
</span>
|
|
|
|
));
|
2019-01-13 01:47:41 +03:00
|
|
|
|
2022-07-11 19:26:52 +03:00
|
|
|
expect(screen.getByText('Foo in header')).toHaveClass('foo-span');
|
|
|
|
expect(screen.getByText('Bar in header')).toHaveClass('bar-span');
|
2019-01-13 01:47:41 +03:00
|
|
|
});
|
|
|
|
});
|