在带有Jest和酶的React中正确测试条件事件

时间:2019-02-15 14:11:54

标签: javascript reactjs jestjs enzyme

有一个组件,可以使用给定的道具来处理某些事件。使用给定的测试代码,我认为单元测试可以满足其需求。另外,显示的报告说我的组件上有未发现的行,我在这些行上添加了//coverage作为注释。

component.js

@autobind
  onMouseEnter(e) {
     if (this.props.onMouseEnter) { //coverage
      this.props.onMouseEnter(e); //coverage
      return; //coverage
    }
    this.setState({
      value: e.target
    });
  }

  ...

      <a
        onMouseEnter={e => this.onMouseEnter(e)} //coverage
        {...otherProps}
      >
        {children}
      </a>

component.test.js

describe("LinkButton Component Testing", () => {
  let wrapper;
  let linkbutton;
  let mockMouseEnter;
  beforeAll(() => {
    mockMouseEnter = jest.fn(e => {
      wrapper.setState({ value: e.target });
      return e.target;
    });
    wrapper = mount(
      <Link passHref href="#deneme">
        <LinkButton
          text="Deneme Title"
          data-test="test"
          onMouseEnter={mockMouseEnter}
        >
          <span>Sample Link</span>
        </LinkButton>
      </Link>
    );
    linkbutton = wrapper.find(
      '[data-test="test"]'
    );
  });

  test("testing onmouseenter props with mock function", () => {
    const anchorLink = linkbutton.hostNodes();
    expect(
      anchorLink.props().onMouseEnter
    ).not.toBeUndefined();

    linkbutton.find("a").simulate("mouseenter");
    expect(
      wrapper.children().props().onMouseEnter
    ).toBeTruthy();
    expect(
      mockMouseEnter.mock.results[0].value.text
    ).toEqual("Sample Link");
    expect(
      linkbutton.get(0).props.onMouseEnter.name
    ).toBe("mockConstructor");
    expect(
      mockMouseEnter.mock.calls.length
    ).toEqual(1);
    expect(
      mockMouseEnter.mock.results[0].value.text
    ).toEqual("Sample Link");

    expect(wrapper.state().value.text).toEqual(
      "Sample Link"
    );
    expect(linkbutton.children()).toHaveLength(2);

    wrapper.simulate("mouseleave");
  });

  test("testing onmouseEnter without given prop", () => {
    wrapper.unmount();
    const newWrapper = mount(
      <Link passHref href="#deneme">
        <LinkButton
          text="Deneme Title"
          data-test="test"
        >
          <span>Sample Link</span>
        </LinkButton>
      </Link>
    );

    const newLinkbutton = newWrapper.find(
      '[data-test="test"]'
    );
    debugger;
    expect(
      newLinkbutton.get(0).props.onMouseEnter
    ).toBeUndefined();
    expect(newWrapper.state()).toBeNull();
  });
});

0 个答案:

没有答案