Material UI + Enzyme testing component

前端 未结 3 1040
一生所求
一生所求 2021-02-04 11:25

I have component in React which I\'m trying to test with Jest, unfortunately test do not pass.

The component code:

import React, {Component} from \'react         


        
3条回答
  •  别跟我提以往
    2021-02-04 12:20

    Following is a humble attempt to provide a more complete answer from create-react-app and @material-ui perspective.

    1. Create setupTests.js directly in src folder and paste the following code.

    import { configure } from "enzyme";
    import Adapter from "enzyme-adapter-react-16";
    
    configure({ adapter: new Adapter() });
    

    2. The following is react stateless component which uses material-ui components.

    import React from "react";
    import TextField from "@material-ui/core/TextField";
    
    const SearchField = props => (
       
    );
    
    export default SearchField;
    

    Note that in the above component, the component expects parent component to pass the props for placeholder and onChange() event handler

    3. Coming to the test case for for the above component we can write either in a way material-ui suggests or in a pure enzyme style. Both will work.

    Pure Enzyme Style

    import React from "react";
    import { mount } from "enzyme";
    import TextField from "@material-ui/core/TextField";
    import SearchField from "../SearchField";
    describe("SearchField Enzyme mount() ", () => {
      const fieldProps = {
        placeholder: "A placeholder",
        onChange: jest.fn()
      };
      const Composition = props => {
        return ;
      };
    
      it("renders a  component with expected props", () => {
        const wrapper = mount();
        expect(wrapper.childAt(0).props().placeholder).toEqual("A placeholder");
        expect(wrapper.childAt(0).props().onChange).toBeDefined();
      });
      it("should trigger onChange on  on key press", () => {
        const wrapper = mount();
        wrapper.find("input").simulate("change");
        expect(fieldProps.onChange).toHaveBeenCalled();
      });
      it("should render ", () => {
        const wrapper = mount();
        expect(wrapper.find(TextField)).toHaveLength(1);
        expect(wrapper.find(TextField).props().InputProps.disableUnderline).toBe(
          true
        );
      });
    });
    

    Material UI style

    import React from "react";
    import { createMount } from "@material-ui/core/test-utils";
    import TextField from "@material-ui/core/TextField";
    import SearchField from "../SearchField";
    describe("SearchField", () => {
      let mount;
      const fieldProps = {
        placeholder: "A placeholder",
        onChange: jest.fn()
      };
      beforeEach(() => {
        mount = createMount();
      });
    
      afterEach(() => {
        mount.cleanUp();
      });
    
      it("renders a  component with expected props", () => {
        const wrapper = mount();
        expect(wrapper.props().placeholder).toEqual("A placeholder");
        expect(wrapper.props().onChange).toBeDefined();
      });
      it("should trigger onChange on  on key press", () => {
        const wrapper = mount();
        wrapper.find("input").simulate("change");
        expect(fieldProps.onChange).toHaveBeenCalled();
      });
    });
    

    5. The error you are getting is due to the fact that babel is not getting a chance to process your file. The create-react-app expects you to run tests like yarn run test and not like jest your/test/file.js. If you use latter babel won't be employed.

    If you want to use jest to run the file you will have to write a jest.config.js file or configure jest in package.json file to use babel-jest + other babel dependencies to transpile your code before jest tries to execute tests.

    I was in the same boat yesterday as I tried to use @material-ui for the first time and came here to get a more complete answer.

提交回复
热议问题