From 59087ced8aea3d6bcd243125a9b2d348c9d51ef1 Mon Sep 17 00:00:00 2001 From: Alejandro Celaya Date: Sat, 11 Jun 2022 09:14:51 +0200 Subject: [PATCH] Migrated NavPills test to react testing library --- test/utils/NavPills.test.tsx | 57 +++++++++++++++++++++++------------- 1 file changed, 36 insertions(+), 21 deletions(-) diff --git a/test/utils/NavPills.test.tsx b/test/utils/NavPills.test.tsx index b06d1524..63f45f9f 100644 --- a/test/utils/NavPills.test.tsx +++ b/test/utils/NavPills.test.tsx @@ -1,20 +1,28 @@ -import { shallow } from 'enzyme'; -import { Card, Nav } from 'reactstrap'; +/* eslint-disable no-console */ +import { render, screen } from '@testing-library/react'; +import { MemoryRouter } from 'react-router-dom'; import { NavPillItem, NavPills } from '../../src/utils/NavPills'; describe('', () => { + let originalError: typeof console.error; + + beforeEach(() => { + originalError = console.error; + console.error = () => {}; // Suppress errors logged during this test + }); + afterEach(() => { + console.error = originalError; + }); + it.each([ ['Foo'], [Hi!], [[, Hi!]], ])('throws error when any of the children is not a NavPillItem', (children) => { expect.assertions(1); - - try { - shallow({children}); - } catch (e: any) { - expect(e.message).toEqual('Only NavPillItem children are allowed inside NavPills.'); - } + expect(() => render({children})).toThrow( + 'Only NavPillItem children are allowed inside NavPills.', + ); }); it.each([ @@ -22,20 +30,27 @@ describe('', () => { [true], [false], ])('renders provided items', (fill) => { - const wrapper = shallow( - - 1 - 2 - 3 - , + const { container } = render( + + + 1 + 2 + 3 + + , ); - const card = wrapper.find(Card); - const nav = wrapper.find(Nav); - expect(card).toHaveLength(1); - expect(card.prop('body')).toEqual(true); - expect(nav).toHaveLength(1); - expect(nav.prop('pills')).toEqual(true); - expect(nav.prop('fill')).toEqual(!!fill); + const links = screen.getAllByRole('link'); + expect(links).toHaveLength(3); + links.forEach((link, index) => { + expect(link).toHaveTextContent(`${index + 1}`); + expect(link).toHaveAttribute('href', `/${index + 1}`); + }); + + if (fill) { + expect(container.querySelector('.nav')).toHaveClass('nav-fill'); + } else { + expect(container.querySelector('.nav')).not.toHaveClass('nav-fill'); + } }); });