2022-07-09 23:03:21 +02:00
|
|
|
import { screen, waitFor } from '@testing-library/react';
|
2021-03-06 17:21:23 +01:00
|
|
|
import { DateInterval, rangeOrIntervalToString } from '../../../src/utils/dates/types';
|
|
|
|
import { DateIntervalSelector } from '../../../src/utils/dates/DateIntervalSelector';
|
2022-07-10 19:44:49 +02:00
|
|
|
import { renderWithEvents } from '../../__helpers__/setUpTest';
|
2021-03-06 17:21:23 +01:00
|
|
|
|
|
|
|
describe('<DateIntervalSelector />', () => {
|
|
|
|
const activeInterval: DateInterval = 'last7Days';
|
|
|
|
const onChange = jest.fn();
|
2022-07-09 23:03:21 +02:00
|
|
|
const setUp = () => renderWithEvents(
|
|
|
|
<DateIntervalSelector allText="All text" active={activeInterval} onChange={onChange} />,
|
|
|
|
);
|
2021-03-06 17:21:23 +01:00
|
|
|
|
2022-07-08 15:11:51 +02:00
|
|
|
it('passes props down to nested DateIntervalDropdownItems', async () => {
|
|
|
|
const { user } = setUp();
|
|
|
|
const btn = screen.getByRole('button');
|
|
|
|
|
|
|
|
await user.click(btn);
|
|
|
|
await waitFor(() => expect(screen.getByRole('menu')).toBeInTheDocument());
|
|
|
|
|
|
|
|
const items = screen.getAllByRole('menuitem');
|
2021-03-06 17:21:23 +01:00
|
|
|
|
2022-07-08 15:11:51 +02:00
|
|
|
expect(btn).toHaveTextContent(rangeOrIntervalToString(activeInterval) ?? '');
|
|
|
|
expect(items).toHaveLength(8);
|
2021-03-06 17:21:23 +01:00
|
|
|
});
|
|
|
|
});
|