import { render, screen, waitFor } from '@testing-library/react'; import userEvent from '@testing-library/user-event'; import { DateIntervalDropdownItems } from '../../../src/utils/dates/DateIntervalDropdownItems'; import { DATE_INTERVALS, DateInterval, rangeOrIntervalToString } from '../../../src/utils/dates/types'; import { DropdownBtn } from '../../../src/utils/DropdownBtn'; describe('', () => { const onChange = jest.fn(); const setUp = async () => { const user = userEvent.setup(); const renderResult = render( , ); await user.click(screen.getByRole('button')); await waitFor(() => expect(screen.getByRole('menu')).toBeInTheDocument()); return { user, ...renderResult }; }; afterEach(jest.clearAllMocks); it('renders expected amount of items', async () => { await setUp(); expect(screen.getAllByRole('menuitem')).toHaveLength(DATE_INTERVALS.length + 1); expect(screen.getByRole('menuitem', { name: 'Last 180 days' })).toHaveClass('active'); }); it('sets expected item as active', async () => { await setUp(); const EXPECTED_ACTIVE_INDEX = 5; 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'); } }); }); 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]); expect(onChange).toHaveBeenCalledWith(expectedInterval); }); });