shlink-web-client/test/utils/dates/DateIntervalSelector.test.tsx

29 lines
1.1 KiB
TypeScript
Raw Normal View History

import { screen, waitFor } from '@testing-library/react';
import type { DateInterval } from '../../../src/utils/dates/DateIntervalSelector';
import { DateIntervalSelector, INTERVAL_TO_STRING_MAP } from '../../../src/utils/dates/DateIntervalSelector';
2023-09-30 10:45:52 +02:00
import { checkAccessibility } from '../../__helpers__/accessibility';
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';
2023-05-27 11:57:26 +02:00
const onChange = vi.fn();
const setUp = () => renderWithEvents(
<DateIntervalSelector allText="All text" active={activeInterval} onChange={onChange} />,
);
2021-03-06 17:21:23 +01:00
2023-09-30 10:45:52 +02:00
it('passes a11y checks', () => checkAccessibility(setUp()));
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
expect(btn).toHaveTextContent(INTERVAL_TO_STRING_MAP[activeInterval] ?? '');
expect(items).toHaveLength(8);
2021-03-06 17:21:23 +01:00
});
});