A fork of https://github.com/ueokande/vim-vixen
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.
48 lines
1.9 KiB
48 lines
1.9 KiB
7 years ago
|
import actions from 'content/actions';
|
||
|
import followControllerReducer from 'content/reducers/follow-controller';
|
||
|
|
||
|
describe('follow-controller reducer', () => {
|
||
|
it ('returns the initial state', () => {
|
||
|
let state = followControllerReducer(undefined, {});
|
||
|
expect(state).to.have.property('enabled', false);
|
||
|
expect(state).to.have.property('newTab');
|
||
|
expect(state).to.have.deep.property('keys', '');
|
||
|
});
|
||
|
|
||
|
it ('returns next state for FOLLOW_CONTROLLER_ENABLE', () => {
|
||
|
let action = { type: actions.FOLLOW_CONTROLLER_ENABLE, newTab: true };
|
||
|
let state = followControllerReducer({ enabled: false, newTab: false }, action);
|
||
|
expect(state).to.have.property('enabled', true);
|
||
|
expect(state).to.have.property('newTab', true);
|
||
|
expect(state).to.have.property('keys', '');
|
||
|
});
|
||
|
|
||
|
it ('returns next state for FOLLOW_CONTROLLER_DISABLE', () => {
|
||
|
let action = { type: actions.FOLLOW_CONTROLLER_DISABLE };
|
||
|
let state = followControllerReducer({ enabled: true }, action);
|
||
|
expect(state).to.have.property('enabled', false);
|
||
|
});
|
||
|
|
||
|
it ('returns next state for FOLLOW_CONTROLLER_KEY_PRESS', () => {
|
||
|
let action = { type: actions.FOLLOW_CONTROLLER_KEY_PRESS, key: 'a'};
|
||
|
let state = followControllerReducer({ keys: '' }, action);
|
||
|
expect(state).to.have.deep.property('keys', 'a');
|
||
|
|
||
|
action = { type: actions.FOLLOW_CONTROLLER_KEY_PRESS, key: 'b'};
|
||
|
state = followControllerReducer(state, action);
|
||
|
expect(state).to.have.deep.property('keys', 'ab');
|
||
|
});
|
||
|
|
||
|
it ('returns next state for FOLLOW_CONTROLLER_BACKSPACE', () => {
|
||
|
let action = { type: actions.FOLLOW_CONTROLLER_BACKSPACE };
|
||
|
let state = followControllerReducer({ keys: 'ab' }, action);
|
||
|
expect(state).to.have.deep.property('keys', 'a');
|
||
|
|
||
|
state = followControllerReducer(state, action);
|
||
|
expect(state).to.have.deep.property('keys', '');
|
||
|
|
||
|
state = followControllerReducer(state, action);
|
||
|
expect(state).to.have.deep.property('keys', '');
|
||
|
});
|
||
|
});
|