2022-07-15 23:11:13 +03:00
|
|
|
import { screen } from '@testing-library/react';
|
2023-04-13 22:48:29 +03:00
|
|
|
import { fromPartial } from '@total-typescript/shoehorn';
|
2022-07-15 23:11:13 +03:00
|
|
|
import { MemoryRouter } from 'react-router-dom';
|
2023-08-06 22:27:57 +03:00
|
|
|
import type { ShlinkShortUrl } from '../../../src/short-urls/data';
|
2023-08-02 10:01:44 +03:00
|
|
|
import { ShortUrlsRowMenu as createShortUrlsRowMenu } from '../../../src/short-urls/helpers/ShortUrlsRowMenu';
|
2022-07-15 23:11:13 +03:00
|
|
|
import { renderWithEvents } from '../../__helpers__/setUpTest';
|
2019-01-13 15:08:47 +03:00
|
|
|
|
|
|
|
describe('<ShortUrlsRowMenu />', () => {
|
2022-07-15 23:11:13 +03:00
|
|
|
const ShortUrlsRowMenu = createShortUrlsRowMenu(() => <i>DeleteShortUrlModal</i>, () => <i>QrCodeModal</i>);
|
2023-08-06 22:27:57 +03:00
|
|
|
const shortUrl = fromPartial<ShlinkShortUrl>({
|
2019-01-13 15:08:47 +03:00
|
|
|
shortCode: 'abc123',
|
2023-01-18 00:53:49 +03:00
|
|
|
shortUrl: 'https://s.test/abc123',
|
2020-08-30 10:59:14 +03:00
|
|
|
});
|
2022-07-15 23:11:13 +03:00
|
|
|
const setUp = () => renderWithEvents(
|
|
|
|
<MemoryRouter>
|
2023-08-04 12:16:01 +03:00
|
|
|
<ShortUrlsRowMenu shortUrl={shortUrl} />
|
2022-07-15 23:11:13 +03:00
|
|
|
</MemoryRouter>,
|
|
|
|
);
|
2019-01-13 15:08:47 +03:00
|
|
|
|
|
|
|
it('renders modal windows', () => {
|
2022-07-15 23:11:13 +03:00
|
|
|
setUp();
|
2019-01-13 15:08:47 +03:00
|
|
|
|
2022-07-15 23:11:13 +03:00
|
|
|
expect(screen.getByText('DeleteShortUrlModal')).toBeInTheDocument();
|
|
|
|
expect(screen.getByText('QrCodeModal')).toBeInTheDocument();
|
2019-01-13 15:08:47 +03:00
|
|
|
});
|
|
|
|
|
2022-07-15 23:11:13 +03:00
|
|
|
it('renders correct amount of menu items', async () => {
|
|
|
|
const { user } = setUp();
|
2019-01-13 15:08:47 +03:00
|
|
|
|
2022-07-15 23:11:13 +03:00
|
|
|
await user.click(screen.getByRole('button'));
|
|
|
|
expect(screen.getAllByRole('menuitem')).toHaveLength(4);
|
2019-01-13 15:08:47 +03:00
|
|
|
});
|
|
|
|
});
|