You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
1.8 KiB
69 lines
1.8 KiB
8 years ago
|
import { spy } from 'sinon';
|
||
|
import React from 'react';
|
||
|
import { shallow } from 'enzyme';
|
||
|
import { BrowserRouter as Router } from 'react-router-dom';
|
||
|
import renderer from 'react-test-renderer';
|
||
|
import Counter from '../../app/components/Counter';
|
||
|
|
||
|
function setup() {
|
||
|
const actions = {
|
||
|
increment: spy(),
|
||
|
incrementIfOdd: spy(),
|
||
|
incrementAsync: spy(),
|
||
|
decrement: spy()
|
||
|
};
|
||
|
const component = shallow(<Counter counter={1} {...actions} />);
|
||
|
return {
|
||
|
component,
|
||
|
actions,
|
||
|
buttons: component.find('button'),
|
||
|
p: component.find('.counter')
|
||
|
};
|
||
|
}
|
||
|
|
||
|
describe('Counter component', () => {
|
||
|
it('should should display count', () => {
|
||
|
const { p } = setup();
|
||
|
expect(p.text()).toMatch(/^1$/);
|
||
|
});
|
||
|
|
||
|
it('should first button should call increment', () => {
|
||
|
const { buttons, actions } = setup();
|
||
|
buttons.at(0).simulate('click');
|
||
|
expect(actions.increment.called).toBe(true);
|
||
|
});
|
||
|
|
||
|
it('should match exact snapshot', () => {
|
||
|
const { actions } = setup();
|
||
|
const tree = renderer
|
||
|
.create(
|
||
|
<div>
|
||
|
<Router>
|
||
|
<Counter counter={1} {...actions} />
|
||
|
</Router>
|
||
|
</div>
|
||
|
)
|
||
|
.toJSON();
|
||
|
|
||
|
expect(tree).toMatchSnapshot();
|
||
|
});
|
||
|
|
||
|
it('should second button should call decrement', () => {
|
||
|
const { buttons, actions } = setup();
|
||
|
buttons.at(1).simulate('click');
|
||
|
expect(actions.decrement.called).toBe(true);
|
||
|
});
|
||
|
|
||
|
it('should third button should call incrementIfOdd', () => {
|
||
|
const { buttons, actions } = setup();
|
||
|
buttons.at(2).simulate('click');
|
||
|
expect(actions.incrementIfOdd.called).toBe(true);
|
||
|
});
|
||
|
|
||
|
it('should fourth button should call incrementAsync', () => {
|
||
|
const { buttons, actions } = setup();
|
||
|
buttons.at(3).simulate('click');
|
||
|
expect(actions.incrementAsync.called).toBe(true);
|
||
|
});
|
||
|
});
|