import { screen } from '@testing-library/react'; import { createMemoryHistory } from 'history'; import { Router } from 'react-router'; import { MainHeader } from '../../src/common/MainHeader'; import { checkAccessibility } from '../__helpers__/accessibility'; import { renderWithStore } from '../__helpers__/setUpTest'; describe('', () => { const setUp = (pathname = '') => { const history = createMemoryHistory(); history.push(pathname); return renderWithStore( , ); }; it('passes a11y checks', () => checkAccessibility(setUp())); it('renders ServersDropdown', () => { setUp(); expect(screen.getByRole('button', { name: 'Servers' })).toBeInTheDocument(); }); it.each([ ['/foo', false], ['/bar', false], ['/settings', true], ['/settings/foo', true], ['/settings/bar', true], ])('sets link to settings as active only when current path is settings', (currentPath, isActive) => { setUp(currentPath); expect(screen.getByRole('menuitem', { name: /Settings$/ })).toHaveAttribute( 'data-active', isActive ? 'true' : 'false', ); }); });