Enzyme
Enzyme
首先需要在项目中安装
$ npm i enzyme @types/enzyme enzyme-to-json enzyme-adapter-react-16 -D
然后在
module.exports = {
// OTHER PORTIONS AS MENTIONED BEFORE
// Setup Enzyme
snapshotSerializers: ["enzyme-to-json/serializer"],
setupTestFrameworkScriptFile: "<rootDir>/src/setupEnzyme.ts"
};
然后创建初始化文件:
// src/setupEnzyme.ts
import { configure } from "enzyme";
import * as EnzymeAdapter from "enzyme-adapter-react-16";
configure({ adapter: new EnzymeAdapter() });
简单的
import * as React from "react";
export class CheckboxWithLabel extends React.Component<
{
labelOn: string;
labelOff: string;
},
{
isChecked: boolean;
}
> {
constructor(props) {
super(props);
this.state = { isChecked: false };
}
onChange = () => {
this.setState({ isChecked: !this.state.isChecked });
};
render() {
return (
<label>
<input
type="checkbox"
checked={this.state.isChecked}
onChange={this.onChange}
/>
{this.state.isChecked ? this.props.labelOn : this.props.labelOff}
</label>
);
}
}
其对应的测试文件如下:
import * as React from "react";
import { shallow } from "enzyme";
import { CheckboxWithLabel } from "./checkboxWithLabel";
test("CheckboxWithLabel changes the text after click", () => {
const checkbox = shallow(<CheckboxWithLabel labelOn="On" labelOff="Off" />);
// Interaction demo
expect(checkbox.text()).toEqual("Off");
checkbox.find("input").simulate("change");
expect(checkbox.text()).toEqual("On");
// Snapshot demo
expect(checkbox).toMatchSnapshot();
});
测试组件的渲染
对于大部分没有交互的组件,下面的测试用例已经足够
test("render a label", () => {
const wrapper = shallow(<Label>Hello Jest!</Label>);
expect(wrapper).toMatchSnapshot();
});
test("render a small label", () => {
const wrapper = shallow(<Label small>Hello Jest!</Label>);
expect(wrapper).toMatchSnapshot();
});
test("render a grayish label", () => {
const wrapper = shallow(<Label light>Hello Jest!</Label>);
expect(wrapper).toMatchSnapshot();
});
Props 测试
有的时候如果你想测试的更精确和看到真实的值。那样的话需要在
test("render a document title", () => {
const wrapper = shallow(<DocumentTitle title="Events" />);
expect(wrapper.prop("title")).toEqual("Events");
});
test("render a document title and a parent title", () => {
const wrapper = shallow(
<DocumentTitle title="Events" parent="Event Radar" />
);
expect(wrapper.prop("title")).toEqual("Events — Event Radar");
});
有的时候你不能用快照。比如组件里面有随机
test("render a popover with a random ID", () => {
const wrapper = shallow(<Popover>Hello Jest!</Popover>);
expect(wrapper.prop("id")).toMatch(/Popover\d+/);
});
事件测试
我们可以模拟类似 click
或者 change
这样的事件然后把组件和快照做比较:
test("render Markdown in preview mode", () => {
const wrapper = shallow(<MarkdownEditor value="*Hello* Jest!" />);
expect(wrapper).toMatchSnapshot();
wrapper.find('[name="toggle-preview"]').simulate("click");
expect(wrapper).toMatchSnapshot();
});
有的时候你想要测试一个子组件中一个元素是怎样影响组件的。你需要使用
test("open a code editor", () => {
const wrapper = mount(<Playground code={code} />);
expect(wrapper.find(".ReactCodeMirror")).toHaveLength(0);
wrapper.find("button").simulate("click");
expect(wrapper.find(".ReactCodeMirror")).toHaveLength(1);
});
测试事件处理
类似于在事件测试中,由使用快照测试组件的输出呈现替换为使用
test("pass a selected value to the onChange handler", () => {
const value = "2";
const onChange = jest.fn();
const wrapper = shallow(<Select items={ITEMS} onChange={onChange} />);
expect(wrapper).toMatchSnapshot();
wrapper.find("select").simulate("change", {
target: { value }
});
expect(onChange).toBeCalledWith(value);
});