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');
+ }
});
});