import { screen } from '@testing-library/react'; import { MemoryRouter } from 'react-router-dom'; import { Mock } from 'ts-mockery'; import type { ReachableServer } from '../../../src/servers/data'; import type { ShortUrl } from '../../../src/short-urls/data'; import { ShortUrlsRowMenu as createShortUrlsRowMenu } from '../../../src/short-urls/helpers/ShortUrlsRowMenu'; import { renderWithEvents } from '../../__helpers__/setUpTest'; describe('', () => { const ShortUrlsRowMenu = createShortUrlsRowMenu(() => DeleteShortUrlModal, () => QrCodeModal); const selectedServer = Mock.of({ id: 'abc123' }); const shortUrl = Mock.of({ shortCode: 'abc123', shortUrl: 'https://s.test/abc123', }); const setUp = () => renderWithEvents( , ); it('renders modal windows', () => { setUp(); expect(screen.getByText('DeleteShortUrlModal')).toBeInTheDocument(); expect(screen.getByText('QrCodeModal')).toBeInTheDocument(); }); it('renders correct amount of menu items', async () => { const { user } = setUp(); await user.click(screen.getByRole('button')); expect(screen.getAllByRole('menuitem')).toHaveLength(4); }); });