import * as React from "react"; import {act, render} from "@testing-library/react"; import { Navbar, NavbarBrand, NavbarItem, NavbarContent, NavbarMenuToggle, NavbarMenu, NavbarMenuItem, } from "../src"; window.scrollTo = jest.fn(); // e.g. console.error Warning: Function components cannot be given refs. // Attempts to access this ref will fail. Did you mean to use React.forwardRef()? const spy = jest.spyOn(console, "error").mockImplementation(() => {}); describe("Navbar", () => { afterEach(() => { jest.clearAllMocks(); }); it("should render correctly", () => { const wrapper = render(); expect(() => wrapper.unmount()).not.toThrow(); }); it("ref should be forwarded", () => { const ref = React.createRef(); render(); expect(ref.current).not.toBeNull(); }); it("should render correctly with brand", () => { const wrapper = render( ACME , ); expect(wrapper.getByTestId("navbar-test")).toBeInTheDocument(); }); it("should render correctly content children", () => { const wrapper = render( Dashboard Team Deployments Activity Settings , ); const navbarContent = wrapper.getByTestId("navbar-content-test"); expect(navbarContent.children.length).toBe(5); }); it("should not throw error after toggle click", () => { const items = ["item1", "item2", "item3", "item4", "item5"]; const wrapper = render( Dashboard Team Deployments Activity Settings {items.map((item, index) => ( {item} ))} , ); const toggle = wrapper.getByTestId("navbar-toggle-test"); act(() => { toggle.click(); }); expect(spy).toBeCalledTimes(0); }); it("should render correctly with menu", () => { const items = ["item1", "item2", "item3", "item4", "item5"]; const wrapper = render( Dashboard Team Deployments Activity Settings {items.map((item, index) => ( {item} ))} , ); const toggle = wrapper.getByTestId("navbar-toggle-test"); act(() => { toggle.click(); }); const menu = wrapper.getByTestId("navbar-menu-test"); expect(menu.children.length).toBe(items.length); }); it("should call on onChange when toggle is clicked", () => { const onChange = jest.fn(); const wrapper = render( Dashboard Team Deployments Activity Settings , ); const toggle = wrapper.getByTestId("navbar-toggle-test"); act(() => { toggle.click(); }); expect(onChange).toHaveBeenCalled(); }); it("should render correctly with custom toggle icon", () => { const wrapper = render( test} /> Dashboard Team Deployments Activity Settings , ); const toggle = wrapper.getByTestId("navbar-toggle-test"); expect(toggle).toHaveTextContent("test"); }); });