我有以下React组件:
export default class SignUpForm extends React.Component {
...
doSignupForm(event) {
// Some API call...
}
render() {
return (
<div>
<form action="/" onSubmit={this.doSignupForm.bind(this)} id="register-form">
<button type="submit" id="register_button">Sign Up</button>
</form>
</div>
);
}
};
我想测试按钮触发doSignupForm
功能 - 我该怎么做(理想情况下使用Mocha / Chai / Enzyme / Sinon)?
此外,正如您所看到的,doSignupForm
函数会触发API调用 - 是否应使用集成测试(?)单独测试此API调用。
答案 0 :(得分:5)
您可以使用React Utils模拟表单提交:
var rendered = TestUtils.renderIntoDocument(SignupForm);
var form = TestUtils.findRenderedDOMComponentWithTag(rendered, 'form');
TestUtils.Simulate.submit(form);
另外,测试对实际API的调用是不可靠的,你应该使用你期望的响应模拟API调用,一个想法是将API调用提取到它自己的模块,并设置一个间谍来测试具有特定响应的组件的行为(使用Jasmine的示例间谍):
spyOn(apiModule, "requestProjects").and.callFake(function() {
return { ...someProjects };
});
参考:
https://facebook.github.io/react/docs/test-utils.html https://volaresystems.com/blog/post/2014/12/10/Mocking-calls-with-Jasmine
答案 1 :(得分:1)
由于您使用的是Enzyme
和Sinon
import sinon from 'sinon';
import {mount} from 'enzyme';
import expect from 'expect';
it('fires form submit', () => {
const doSignupForm = sinon.stub(SignUpForm.prototype, 'doSignupForm').returns(true);
const wrapper = mount(<SignUpForm />);
wrapper.find('button').simulate('click');
expect(doSignupForm.called).to.be.true;
doSignupForm.restore();
});
答案 2 :(得分:0)
如上所述here,酶不支持事件冒泡。因此,找到了以下解决方法:
import sinon from 'sinon';
import {mount} from 'enzyme';
import chai from 'chai';
var expect = chai.expect;
it('fires form submit', () => {
const doSignupForm = sinon.stub(SignUpForm.prototype, 'doSignupForm').returns(true);
const wrapper = mount(<SignUpForm />);
wrapper.find('#register_button').get(0).click();
expect(doSignupForm).to.have.been.called;
doSignupForm.restore();
});