-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathtest.js
45 lines (39 loc) · 1.34 KB
/
test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
import Immutable from 'seamless-immutable';
import createReducer from '../../creators/createReducer';
import onLoading from '.';
const initialState = {
target: null,
targetLoading: false,
count: 0
};
const setUp = {
state: null
};
beforeEach(() => {
setUp.state = Immutable(initialState);
});
describe('onLoading', () => {
it('Sets correctly loading target', () => {
const reducer = createReducer(setUp.state, {
'@@ACTION/TYPE': onLoading()
});
const newState = reducer(setUp.state, { type: '@@ACTION/TYPE', target: 'target' });
expect(newState.targetLoading).toBe(true);
});
it('Does not modify other targets', () => {
const reducer = createReducer(setUp.state, {
'@@ACTION/TYPE': onLoading()
});
const newState = reducer(setUp.state, { type: '@@ACTION/TYPE', target: 'target' });
expect(newState.target).toBeNull();
});
it('Sets loading conditionally', () => {
const reducer = createReducer(setUp.state, {
'@@ACTION/TYPE': onLoading((action, state) => !!action.payload || state.count > 0)
});
let newState = reducer(setUp.state, { type: '@@ACTION/TYPE', target: 'target' });
expect(newState.targetLoading).toBe(false);
newState = reducer(setUp.state, { type: '@@ACTION/TYPE', target: 'target', payload: 'payload' });
expect(newState.targetLoading).toBe(true);
});
});