From 935b12763ba2997d154e18767229f4befaeef0c3 Mon Sep 17 00:00:00 2001 From: Alejandro Celaya Date: Thu, 7 Jul 2022 19:01:17 +0200 Subject: [PATCH] Migrated TagsModeDropdown test to react testing library --- test/tags/TagsModeDropdown.test.tsx | 45 +++++++++++++---------------- 1 file changed, 20 insertions(+), 25 deletions(-) diff --git a/test/tags/TagsModeDropdown.test.tsx b/test/tags/TagsModeDropdown.test.tsx index 97f170b8..5c4e8ca7 100644 --- a/test/tags/TagsModeDropdown.test.tsx +++ b/test/tags/TagsModeDropdown.test.tsx @@ -1,42 +1,37 @@ -import { shallow, ShallowWrapper } from 'enzyme'; -import { DropdownItem } from 'reactstrap'; -import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; -import { faBars as listIcon, faThLarge as cardsIcon } from '@fortawesome/free-solid-svg-icons'; +import { render, screen } from '@testing-library/react'; +import userEvent from '@testing-library/user-event'; import { TagsModeDropdown } from '../../src/tags/TagsModeDropdown'; -import { DropdownBtn } from '../../src/utils/DropdownBtn'; +import { TagsMode } from '../../src/settings/reducers/settings'; describe('', () => { const onChange = jest.fn(); - let wrapper: ShallowWrapper; - - beforeEach(() => { - wrapper = shallow(); + const setUp = (mode: TagsMode) => ({ + user: userEvent.setup(), + ...render(), }); afterEach(jest.clearAllMocks); - afterEach(() => wrapper?.unmount()); - it('renders expected items', () => { - const btn = wrapper.find(DropdownBtn); - const items = wrapper.find(DropdownItem); - const icons = wrapper.find(FontAwesomeIcon); - - expect(btn).toHaveLength(1); - expect(btn.prop('text')).toEqual('Display mode: list'); - expect(items).toHaveLength(2); - expect(icons).toHaveLength(2); - expect(icons.first().prop('icon')).toEqual(cardsIcon); - expect(icons.last().prop('icon')).toEqual(listIcon); + it.each([ + ['cards' as TagsMode], + ['list' as TagsMode], + ])('renders expected initial value', (mode) => { + setUp(mode); + expect(screen.getByRole('button')).toHaveTextContent(`Display mode: ${mode}`); }); - it('changes active element on click', () => { - const items = wrapper.find(DropdownItem); + it('changes active element on click', async () => { + const { user } = setUp('list'); + const clickItem = async (index: 0 | 1) => { + await user.click(screen.getByRole('button')); + await user.click(screen.getAllByRole('menuitem')[index]); + }; expect(onChange).not.toHaveBeenCalled(); - items.first().simulate('click'); + await clickItem(0); expect(onChange).toHaveBeenCalledWith('cards'); - items.last().simulate('click'); + await clickItem(1); expect(onChange).toHaveBeenCalledWith('list'); }); });