import { screen } from '@testing-library/react'; import { PaginationDropdown } from '../../src/utils/PaginationDropdown'; import { renderWithEvents } from '../__helpers__/setUpTest'; describe('<PaginationDropdown />', () => { const setValue = jest.fn(); const setUp = async () => { const result = renderWithEvents(<PaginationDropdown ranges={[10, 50, 100, 200]} value={50} setValue={setValue} />); const { user } = result; await user.click(screen.getByRole('button')); return result; }; afterEach(jest.clearAllMocks); it('renders expected amount of items', async () => { await setUp(); expect(screen.getAllByRole('menuitem')).toHaveLength(5); }); it.each([ [0, 10], [1, 50], [2, 100], [3, 200], ])('sets expected value when an item is clicked', async (index, expectedValue) => { const { user } = await setUp(); expect(setValue).not.toHaveBeenCalled(); await user.click(screen.getAllByRole('menuitem')[index]); expect(setValue).toHaveBeenCalledWith(expectedValue); }); });