Here is the unit test solution:
index.jsx
:
import React, { Component } from 'react';
class SomeComponent extends Component {
constructor() {
this.state = {};
}
handleSubmit = (event) => {
event && event.preventDefault();
this.formValidation() ? this.login() : this.handleErrors(this.state);
};
formValidation() {}
handleErrors(state) {}
login() {}
render() {
return (
<div>
<form onSubmit={this.handleSubmit}></form>
</div>
);
}
}
export default SomeComponent;
index.test.jsx
:
import React from 'react';
import { shallow } from 'enzyme';
import SomeComponent from '.';
describe('59741487', () => {
let wrapper;
const mFormValidation = jest.fn();
const mLogin = jest.fn();
const mHandleErrors = jest.fn();
beforeEach(() => {
SomeComponent.prototype.formValidation = mFormValidation;
SomeComponent.prototype.login = mLogin;
SomeComponent.prototype.handleErrors = mHandleErrors;
wrapper = shallow(<SomeComponent></SomeComponent>);
});
afterEach(() => {
jest.clearAllMocks();
});
it('should render', () => {
expect(wrapper.find('form')).toBeTruthy();
});
describe('#handleSubmit', () => {
it('should login', () => {
mFormValidation.mockReturnValueOnce(true);
const mEvent = { preventDefault: jest.fn() };
wrapper.find('form').simulate('submit', mEvent);
expect(mEvent.preventDefault).toBeCalledTimes(1);
expect(mLogin).toHaveBeenCalledTimes(1);
});
it('should handle error', () => {
mFormValidation.mockReturnValueOnce(false);
const mEvent = { preventDefault: jest.fn() };
wrapper.find('form').simulate('submit', mEvent);
expect(mEvent.preventDefault).toBeCalledTimes(1);
expect(mHandleErrors).toBeCalledWith({});
});
});
});
Unit test results with coverage report:
PASS src/stackoverflow/59741487/index.test.jsx (13.687s)
59741487
✓ should render (12ms)
#handleSubmit
✓ should login (2ms)
✓ should handle error (3ms)
-----------|----------|----------|----------|----------|-------------------|
File | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s |
-----------|----------|----------|----------|----------|-------------------|
All files | 100 | 100 | 57.14 | 100 | |
index.jsx | 100 | 100 | 57.14 | 100 | |
-----------|----------|----------|----------|----------|-------------------|
Test Suites: 1 passed, 1 total
Tests: 3 passed, 3 total
Snapshots: 0 total
Time: 15.854s
Source code: https://github.com/mrdulin/jest-codelab/tree/master/src/stackoverflow/59741487