diff options
| author | Shin'ya Ueoka <ueokande@i-beam.org> | 2017-10-01 08:32:55 +0900 | 
|---|---|---|
| committer | Shin'ya Ueoka <ueokande@i-beam.org> | 2017-10-01 08:32:55 +0900 | 
| commit | 40cc5b9175f08f66c9c6a9d6efad59bf47cea307 (patch) | |
| tree | 6336e6681bb5707c94a866129694473a4dfc4924 | |
| parent | 567b696cecbec870c36f5a07dd02fb5d9f9efb9b (diff) | |
add tests for completion and fix
| -rw-r--r-- | src/reducers/completion.js | 11 | ||||
| -rw-r--r-- | test/actions/completion.test.js | 27 | ||||
| -rw-r--r-- | test/reducers/completion.test.js | 90 | 
3 files changed, 126 insertions, 2 deletions
diff --git a/src/reducers/completion.js b/src/reducers/completion.js index a706988..a8a6444 100644 --- a/src/reducers/completion.js +++ b/src/reducers/completion.js @@ -24,7 +24,10 @@ const nextSelection = (state) => {  const prevSelection = (state) => {    if (state.groupSelection < 0) { -    return [0, 0]; +    return [ +      state.groups.length - 1, +      state.groups[state.groups.length - 1].items.length - 1 +    ];    }    if (state.groupSelection === 0 && state.itemSelection === 0) {      return [-1, -1]; @@ -41,7 +44,9 @@ export default function reducer(state = defaultState, action = {}) {    switch (action.type) {    case actions.COMPLETION_SET_ITEMS:      return Object.assign({}, state, { -      groups: action.groups +      groups: action.groups, +      groupSelection: -1, +      itemSelection: -1,      });    case actions.COMPLETION_SELECT_NEXT: {      let next = nextSelection(state); @@ -57,5 +62,7 @@ export default function reducer(state = defaultState, action = {}) {        itemSelection: next[1],      });    } +  default: +    return defaultState;    }  } diff --git a/test/actions/completion.test.js b/test/actions/completion.test.js new file mode 100644 index 0000000..da88f53 --- /dev/null +++ b/test/actions/completion.test.js @@ -0,0 +1,27 @@ +import { expect } from "chai"; +import actions from '../../src/actions'; +import * as completionActions from '../../src/actions/completion'; + +describe("completion actions", () => { +  describe('setItems', () => { +    it('create COMPLETION_SET_ITEMS action', () => { +      let action = completionActions.setItems([1, 2, 3]); +      expect(action.type).to.equal(actions.COMPLETION_SET_ITEMS); +      expect(action.groups).to.deep.equal([1, 2, 3]); +    }); +  }); + +  describe('selectNext', () => { +    it('create COMPLETION_SELECT_NEXT action', () => { +      let action = completionActions.selectNext(); +      expect(action.type).to.equal(actions.COMPLETION_SELECT_NEXT); +    }); +  }); + +  describe('selectPrev', () => { +    it('create COMPLETION_SELECT_PREV action', () => { +      let action = completionActions.selectPrev(); +      expect(action.type).to.equal(actions.COMPLETION_SELECT_PREV); +    }); +  }); +}); diff --git a/test/reducers/completion.test.js b/test/reducers/completion.test.js new file mode 100644 index 0000000..79163bf --- /dev/null +++ b/test/reducers/completion.test.js @@ -0,0 +1,90 @@ +import { expect } from "chai"; +import actions from '../../src/actions'; +import completionReducer from '../../src/reducers/completion'; + +describe("completion reducer", () => { +  it ('return the initial state', () => { +    let state = completionReducer(undefined, {}); +    expect(state).to.have.property('groupSelection', -1); +    expect(state).to.have.property('itemSelection', -1); +    expect(state).to.have.deep.property('groups', []); +  }); + +  it ('return next state for COMPLETION_SET_ITEMS', () => { +    let state = { +      groupSelection: 0, +      itemSelection: 0, +      groups: [], +    } +    let action = { +      type: actions.COMPLETION_SET_ITEMS, +      groups: [{ +        name: 'Apple', +        items: [1, 2, 3] +      }, { +        name: 'Banana', +        items: [4, 5, 6] +      }] +    } +    state = completionReducer(state, action); +    expect(state).to.have.property('groups', action.groups); +    expect(state).to.have.property('groupSelection', -1); +    expect(state).to.have.property('itemSelection', -1); +  }); + +  it ('return next state for COMPLETION_SELECT_NEXT', () => { +    let action = { type: actions.COMPLETION_SELECT_NEXT }; +    let state = { +      groupSelection: -1, +      itemSelection: -1, +      groups: [{ +        name: 'Apple', +        items: [1, 2] +      }, { +        name: 'Banana', +        items: [3] +      }] +    }; + +    state = completionReducer(state, action); +    expect(state).to.have.property('groupSelection', 0); +    expect(state).to.have.property('itemSelection', 0); + +    state = completionReducer(state, action); +    expect(state).to.have.property('groupSelection', 0); +    expect(state).to.have.property('itemSelection', 1); + +    state = completionReducer(state, action); +    state = completionReducer(state, action); +    expect(state).to.have.property('groupSelection', -1); +    expect(state).to.have.property('itemSelection', -1); +  }); + +  it ('return next state for COMPLETION_SELECT_PREV', () => { +    let action = { type: actions.COMPLETION_SELECT_PREV }; +    let state = { +      groupSelection: -1, +      itemSelection: -1, +      groups: [{ +        name: 'Apple', +        items: [1, 2] +      }, { +        name: 'Banana', +        items: [3] +      }] +    }; + +    state = completionReducer(state, action); +    expect(state).to.have.property('groupSelection', 1); +    expect(state).to.have.property('itemSelection', 0); + +    state = completionReducer(state, action); +    expect(state).to.have.property('groupSelection', 0); +    expect(state).to.have.property('itemSelection', 1); + +    state = completionReducer(state, action); +    state = completionReducer(state, action); +    expect(state).to.have.property('groupSelection', -1); +    expect(state).to.have.property('itemSelection', -1); +  }); +});  | 
