diff options
| author | Shin'ya Ueoka <ueokande@i-beam.org> | 2019-04-30 14:00:07 +0900 | 
|---|---|---|
| committer | Shin'ya Ueoka <ueokande@i-beam.org> | 2019-05-02 11:14:19 +0900 | 
| commit | c60d0e7392fc708e961614d6b756a045de74f458 (patch) | |
| tree | 0b9a5fce1879e38a92d5dbb2915779aee0ad22d6 /test/content/reducers/follow-controller.test.ts | |
| parent | 257162e5b6b4993e1dff0d705ffa6f0d809033eb (diff) | |
Rename .js/.jsx to .ts/.tsx
Diffstat (limited to 'test/content/reducers/follow-controller.test.ts')
| -rw-r--r-- | test/content/reducers/follow-controller.test.ts | 47 | 
1 files changed, 47 insertions, 0 deletions
diff --git a/test/content/reducers/follow-controller.test.ts b/test/content/reducers/follow-controller.test.ts new file mode 100644 index 0000000..8a4c2d4 --- /dev/null +++ b/test/content/reducers/follow-controller.test.ts @@ -0,0 +1,47 @@ +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', ''); +  }); +});  | 
