React, Jest and Material-UI: How to test for content rendered in a modal or popover

前端 未结 2 1299
[愿得一人]
[愿得一人] 2021-02-14 19:12

There are a few material-ui components that do not render their results in the same place as the component is placed by their parent. Among these we have the Dialog

2条回答
  •  刺人心
    刺人心 (楼主)
    2021-02-14 19:45

    Yes this can be tricky. The issue is two-fold:

    1. firing a click event means you need to make your test an async function
    2. the menu items are not in your wrapper element - as you noted they are elsewhere in the DOM.

    For the menu items, you'll need to locate them where they actually are. The button that opens the menu is in your wrapper element, but the menu and the menu items won't be, so you'll need to get the menu by role then you can get the items within menu by their text.

    Here's an example of how I'd do this using React Testing Library.

    import React, { ReactElement } from "react";
    import { render, screen } from "@testing-library/react";
    import AppMenu from "./AppMenu";
    import { getByText, fireEvent, getByLabelText } from "@testing-library/react";
    
    
    test("It renders some menu items", async () => {
      const { container } = render();
      const button = getByText(container, "Menu");
    
      fireEvent.click(button);
    
      const menuItem = screen.getByRole("menu");
    
      expect(await getByLabelText(menuItem, "Home")).toBeTruthy();
      expect(await getByLabelText(menuItem, "Sign in")).toBeTruthy();
    });
    

提交回复
热议问题