From 90a643761ab50d276ac27d0d76f42e2d8b23c8e5 Mon Sep 17 00:00:00 2001 From: Alejandro Celaya Date: Fri, 15 Jul 2022 22:11:13 +0200 Subject: [PATCH] Migrated ShortUrlsRowMenu test to react testing library --- .../helpers/ShortUrlsRowMenu.test.tsx | 55 ++++++------------- 1 file changed, 16 insertions(+), 39 deletions(-) diff --git a/test/short-urls/helpers/ShortUrlsRowMenu.test.tsx b/test/short-urls/helpers/ShortUrlsRowMenu.test.tsx index 0a967ad9..3a996b3c 100644 --- a/test/short-urls/helpers/ShortUrlsRowMenu.test.tsx +++ b/test/short-urls/helpers/ShortUrlsRowMenu.test.tsx @@ -1,58 +1,35 @@ -import { shallow, ShallowWrapper } from 'enzyme'; -import { DropdownItem } from 'reactstrap'; +import { screen } from '@testing-library/react'; import { Mock } from 'ts-mockery'; +import { MemoryRouter } from 'react-router-dom'; import { ShortUrlsRowMenu as createShortUrlsRowMenu } from '../../../src/short-urls/helpers/ShortUrlsRowMenu'; import { ReachableServer } from '../../../src/servers/data'; import { ShortUrl } from '../../../src/short-urls/data'; -import { DropdownBtnMenu } from '../../../src/utils/DropdownBtnMenu'; +import { renderWithEvents } from '../../__helpers__/setUpTest'; describe('', () => { - let wrapper: ShallowWrapper; - const DeleteShortUrlModal = () => null; - const QrCodeModal = () => null; + const ShortUrlsRowMenu = createShortUrlsRowMenu(() => DeleteShortUrlModal, () => QrCodeModal); const selectedServer = Mock.of({ id: 'abc123' }); const shortUrl = Mock.of({ shortCode: 'abc123', shortUrl: 'https://doma.in/abc123', }); - const createWrapper = () => { - const ShortUrlsRowMenu = createShortUrlsRowMenu(DeleteShortUrlModal, QrCodeModal); - - wrapper = shallow(); - - return wrapper; - }; - - afterEach(() => wrapper?.unmount()); + const setUp = () => renderWithEvents( + + + , + ); it('renders modal windows', () => { - const wrapper = createWrapper(); - const deleteShortUrlModal = wrapper.find(DeleteShortUrlModal); - const qrCodeModal = wrapper.find(QrCodeModal); + setUp(); - expect(deleteShortUrlModal).toHaveLength(1); - expect(qrCodeModal).toHaveLength(1); + expect(screen.getByText('DeleteShortUrlModal')).toBeInTheDocument(); + expect(screen.getByText('QrCodeModal')).toBeInTheDocument(); }); - it('renders correct amount of menu items', () => { - const wrapper = createWrapper(); - const items = wrapper.find(DropdownItem); + it('renders correct amount of menu items', async () => { + const { user } = setUp(); - expect(items).toHaveLength(5); - expect(items.find('[divider]')).toHaveLength(1); - }); - - describe('toggles state when toggling modals or the dropdown', () => { - const assert = (modalComponent: Function) => { - const wrapper = createWrapper(); - - expect(wrapper.find(modalComponent).prop('isOpen')).toEqual(false); - (wrapper.find(modalComponent).prop('toggle') as Function)(); - expect(wrapper.find(modalComponent).prop('isOpen')).toEqual(true); - }; - - it('DeleteShortUrlModal', () => assert(DeleteShortUrlModal)); - it('QrCodeModal', () => assert(QrCodeModal)); - it('ShortUrlRowMenu', () => assert(DropdownBtnMenu)); + await user.click(screen.getByRole('button')); + expect(screen.getAllByRole('menuitem')).toHaveLength(4); }); });