/* eslint-disable no-console */ import { render, screen } from '@testing-library/react'; import { MemoryRouter } from 'react-router-dom'; import { NavPillItem, NavPills } from '../../src/utils/NavPills'; describe('<NavPills />', () => { let originalError: typeof console.error; beforeEach(() => { originalError = console.error; console.error = () => {}; // Suppress errors logged during this test }); afterEach(() => { console.error = originalError; }); it.each([ ['Foo'], [<span key="1">Hi!</span>], [[<NavPillItem key="1" to="" />, <span key="2">Hi!</span>]], ])('throws error when any of the children is not a NavPillItem', (children) => { expect.assertions(1); expect(() => render(<NavPills>{children}</NavPills>)).toThrow( 'Only NavPillItem children are allowed inside NavPills.', ); }); it.each([ [undefined], [true], [false], ])('renders provided items', (fill) => { const { container } = render( <MemoryRouter> <NavPills fill={fill}> <NavPillItem to="1">1</NavPillItem> <NavPillItem to="2">2</NavPillItem> <NavPillItem to="3">3</NavPillItem> </NavPills> </MemoryRouter>, ); const links = screen.getAllByRole('link'); expect(links).toHaveLength(3); links.forEach((link, index) => { expect(link).toHaveTextContent(`${index + 1}`); expect(link).toHaveAttribute('href', `/${index + 1}`); }); if (fill) { expect(container.querySelector('.nav')).toHaveClass('nav-fill'); } else { expect(container.querySelector('.nav')).not.toHaveClass('nav-fill'); } }); });