2022-07-08 15:03:48 +02:00
|
|
|
import { render, screen, waitFor } from '@testing-library/react';
|
|
|
|
import userEvent from '@testing-library/user-event';
|
2021-03-06 16:54:43 +01:00
|
|
|
import { DateIntervalDropdownItems } from '../../../src/utils/dates/DateIntervalDropdownItems';
|
2022-07-08 15:03:48 +02:00
|
|
|
import { DATE_INTERVALS, DateInterval, rangeOrIntervalToString } from '../../../src/utils/dates/types';
|
|
|
|
import { DropdownBtn } from '../../../src/utils/DropdownBtn';
|
2021-03-06 16:54:43 +01:00
|
|
|
|
|
|
|
describe('<DateIntervalDropdownItems />', () => {
|
|
|
|
const onChange = jest.fn();
|
2022-07-08 15:03:48 +02:00
|
|
|
const setUp = async () => {
|
|
|
|
const user = userEvent.setup();
|
|
|
|
const renderResult = render(
|
|
|
|
<DropdownBtn text="text">
|
|
|
|
<DateIntervalDropdownItems allText="All" active="last180Days" onChange={onChange} />
|
|
|
|
</DropdownBtn>,
|
|
|
|
);
|
2021-03-06 16:54:43 +01:00
|
|
|
|
2022-07-08 15:03:48 +02:00
|
|
|
await user.click(screen.getByRole('button'));
|
|
|
|
await waitFor(() => expect(screen.getByRole('menu')).toBeInTheDocument());
|
|
|
|
|
|
|
|
return { user, ...renderResult };
|
|
|
|
};
|
2021-03-06 16:54:43 +01:00
|
|
|
|
|
|
|
afterEach(jest.clearAllMocks);
|
|
|
|
|
2022-07-08 15:03:48 +02:00
|
|
|
it('renders expected amount of items', async () => {
|
|
|
|
await setUp();
|
2021-03-06 16:54:43 +01:00
|
|
|
|
2022-07-08 15:03:48 +02:00
|
|
|
expect(screen.getAllByRole('menuitem')).toHaveLength(DATE_INTERVALS.length + 1);
|
|
|
|
expect(screen.getByRole('menuitem', { name: 'Last 180 days' })).toHaveClass('active');
|
2021-03-06 16:54:43 +01:00
|
|
|
});
|
|
|
|
|
2022-07-08 15:03:48 +02:00
|
|
|
it('sets expected item as active', async () => {
|
|
|
|
await setUp();
|
|
|
|
const EXPECTED_ACTIVE_INDEX = 5;
|
2021-03-06 16:54:43 +01:00
|
|
|
|
2022-07-08 15:03:48 +02:00
|
|
|
DATE_INTERVALS.forEach((interval, index) => {
|
|
|
|
const item = screen.getByRole('menuitem', { name: rangeOrIntervalToString(interval) });
|
|
|
|
|
|
|
|
if (index === EXPECTED_ACTIVE_INDEX) {
|
|
|
|
expect(item).toHaveClass('active');
|
|
|
|
} else {
|
|
|
|
expect(item).not.toHaveClass('active');
|
|
|
|
}
|
|
|
|
});
|
2021-03-06 16:54:43 +01:00
|
|
|
});
|
|
|
|
|
2022-07-08 15:03:48 +02:00
|
|
|
it.each([
|
|
|
|
[3, 'last7Days' as DateInterval],
|
|
|
|
[7, 'last365Days' as DateInterval],
|
|
|
|
[2, 'yesterday' as DateInterval],
|
|
|
|
])('triggers onChange callback when selecting an element', async (index, expectedInterval) => {
|
|
|
|
const { user } = await setUp();
|
|
|
|
|
|
|
|
await user.click(screen.getAllByRole('menuitem')[index]);
|
2021-03-06 16:54:43 +01:00
|
|
|
|
2022-07-08 15:03:48 +02:00
|
|
|
expect(onChange).toHaveBeenCalledWith(expectedInterval);
|
2021-03-06 16:54:43 +01:00
|
|
|
});
|
|
|
|
});
|