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.
134 lines
4.2 KiB
134 lines
4.2 KiB
import { expect } from "chai"; |
|
import actions from 'console/actions'; |
|
import reducer from 'console/reducers'; |
|
|
|
describe("console reducer", () => { |
|
it('return the initial state', () => { |
|
let state = reducer(undefined, {}); |
|
expect(state).to.have.property('mode', ''); |
|
expect(state).to.have.property('messageText', ''); |
|
expect(state).to.have.property('consoleText', ''); |
|
expect(state).to.have.deep.property('completions', []); |
|
expect(state).to.have.property('groupSelection', -1); |
|
expect(state).to.have.property('itemSelection', -1); |
|
}); |
|
|
|
it('return next state for CONSOLE_SHOW_COMMAND', () => { |
|
let action = { type: actions.CONSOLE_SHOW_COMMAND, text: 'open ' }; |
|
let state = reducer({}, action); |
|
expect(state).to.have.property('mode', 'command'); |
|
expect(state).to.have.property('consoleText', 'open '); |
|
}); |
|
|
|
it('return next state for CONSOLE_SHOW_INFO', () => { |
|
let action = { type: actions.CONSOLE_SHOW_INFO, text: 'an info' }; |
|
let state = reducer({}, action); |
|
expect(state).to.have.property('mode', 'info'); |
|
expect(state).to.have.property('messageText', 'an info'); |
|
}); |
|
|
|
it('return next state for CONSOLE_SHOW_ERROR', () => { |
|
let action = { type: actions.CONSOLE_SHOW_ERROR, text: 'an error' }; |
|
let state = reducer({}, action); |
|
expect(state).to.have.property('mode', 'error'); |
|
expect(state).to.have.property('messageText', 'an error'); |
|
}); |
|
|
|
it('return next state for CONSOLE_HIDE_COMMAND', () => { |
|
let action = { type: actions.CONSOLE_HIDE_COMMAND }; |
|
let state = reducer({ mode: 'command' }, action); |
|
expect(state).to.have.property('mode', ''); |
|
|
|
state = reducer({ mode: 'error' }, action); |
|
expect(state).to.have.property('mode', 'error'); |
|
}); |
|
|
|
it('return next state for CONSOLE_SET_CONSOLE_TEXT', () => { |
|
let action = { |
|
type: actions.CONSOLE_SET_CONSOLE_TEXT, |
|
consoleText: 'hello world' |
|
} |
|
let state = reducer({}, action) |
|
|
|
expect(state).to.have.property('consoleText', 'hello world'); |
|
}); |
|
|
|
it ('return next state for CONSOLE_SET_COMPLETIONS', () => { |
|
let state = { |
|
groupSelection: 0, |
|
itemSelection: 0, |
|
completions: [], |
|
} |
|
let action = { |
|
type: actions.CONSOLE_SET_COMPLETIONS, |
|
completions: [{ |
|
name: 'Apple', |
|
items: [1, 2, 3] |
|
}, { |
|
name: 'Banana', |
|
items: [4, 5, 6] |
|
}] |
|
} |
|
state = reducer(state, action); |
|
expect(state).to.have.property('completions', action.completions); |
|
expect(state).to.have.property('groupSelection', -1); |
|
expect(state).to.have.property('itemSelection', -1); |
|
}); |
|
|
|
it ('return next state for CONSOLE_COMPLETION_NEXT', () => { |
|
let action = { type: actions.CONSOLE_COMPLETION_NEXT }; |
|
let state = { |
|
groupSelection: -1, |
|
itemSelection: -1, |
|
completions: [{ |
|
name: 'Apple', |
|
items: [1, 2] |
|
}, { |
|
name: 'Banana', |
|
items: [3] |
|
}] |
|
}; |
|
|
|
state = reducer(state, action); |
|
expect(state).to.have.property('groupSelection', 0); |
|
expect(state).to.have.property('itemSelection', 0); |
|
|
|
state = reducer(state, action); |
|
expect(state).to.have.property('groupSelection', 0); |
|
expect(state).to.have.property('itemSelection', 1); |
|
|
|
state = reducer(state, action); |
|
state = reducer(state, action); |
|
expect(state).to.have.property('groupSelection', -1); |
|
expect(state).to.have.property('itemSelection', -1); |
|
}); |
|
|
|
it ('return next state for CONSOLE_COMPLETION_PREV', () => { |
|
let action = { type: actions.CONSOLE_COMPLETION_PREV }; |
|
let state = { |
|
groupSelection: -1, |
|
itemSelection: -1, |
|
completions: [{ |
|
name: 'Apple', |
|
items: [1, 2] |
|
}, { |
|
name: 'Banana', |
|
items: [3] |
|
}] |
|
}; |
|
|
|
state = reducer(state, action); |
|
expect(state).to.have.property('groupSelection', 1); |
|
expect(state).to.have.property('itemSelection', 0); |
|
|
|
state = reducer(state, action); |
|
expect(state).to.have.property('groupSelection', 0); |
|
expect(state).to.have.property('itemSelection', 1); |
|
|
|
state = reducer(state, action); |
|
state = reducer(state, action); |
|
expect(state).to.have.property('groupSelection', -1); |
|
expect(state).to.have.property('itemSelection', -1); |
|
}); |
|
|
|
});
|
|
|