有一个组件,可以使用给定的道具来处理某些事件。使用给定的测试代码,我认为单元测试可以满足其需求。另外,显示的报告说我的组件上有未发现的行,我在这些行上添加了//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();
});
});