shlink-web-client/test/short-urls/helpers/ShortUrlsRowMenu.test.tsx

36 lines
1.4 KiB
TypeScript
Raw Normal View History

import { screen } from '@testing-library/react';
import { fromPartial } from '@total-typescript/shoehorn';
import { MemoryRouter } from 'react-router-dom';
import type { ShortUrl } from '../../../shlink-web-component/short-urls/data';
import { ShortUrlsRowMenu as createShortUrlsRowMenu } from '../../../shlink-web-component/short-urls/helpers/ShortUrlsRowMenu';
2023-02-18 12:40:37 +03:00
import type { ReachableServer } from '../../../src/servers/data';
import { renderWithEvents } from '../../__helpers__/setUpTest';
2019-01-13 15:08:47 +03:00
describe('<ShortUrlsRowMenu />', () => {
const ShortUrlsRowMenu = createShortUrlsRowMenu(() => <i>DeleteShortUrlModal</i>, () => <i>QrCodeModal</i>);
const selectedServer = fromPartial<ReachableServer>({ id: 'abc123' });
const shortUrl = fromPartial<ShortUrl>({
2019-01-13 15:08:47 +03:00
shortCode: 'abc123',
shortUrl: 'https://s.test/abc123',
});
const setUp = () => renderWithEvents(
<MemoryRouter>
<ShortUrlsRowMenu selectedServer={selectedServer} shortUrl={shortUrl} />
</MemoryRouter>,
);
2019-01-13 15:08:47 +03:00
it('renders modal windows', () => {
setUp();
2019-01-13 15:08:47 +03:00
expect(screen.getByText('DeleteShortUrlModal')).toBeInTheDocument();
expect(screen.getByText('QrCodeModal')).toBeInTheDocument();
2019-01-13 15:08:47 +03:00
});
it('renders correct amount of menu items', async () => {
const { user } = setUp();
2019-01-13 15:08:47 +03:00
await user.click(screen.getByRole('button'));
expect(screen.getAllByRole('menuitem')).toHaveLength(4);
2019-01-13 15:08:47 +03:00
});
});