separate console
This commit is contained in:
parent
22db12f2a3
commit
541449b1fc
13 changed files with 38 additions and 40 deletions
51
test/console/actions/console.test.js
Normal file
51
test/console/actions/console.test.js
Normal file
|
@ -0,0 +1,51 @@
|
|||
import { expect } from "chai";
|
||||
import actions from 'console/actions';
|
||||
import * as consoleActions from 'console/actions/console';
|
||||
|
||||
describe("console actions", () => {
|
||||
describe("showCommand", () => {
|
||||
it('create CONSOLE_SHOW_COMMAND action', () => {
|
||||
let action = consoleActions.showCommand('hello');
|
||||
expect(action.type).to.equal(actions.CONSOLE_SHOW_COMMAND);
|
||||
expect(action.text).to.equal('hello');
|
||||
});
|
||||
});
|
||||
|
||||
describe("showError", () => {
|
||||
it('create CONSOLE_SHOW_ERROR action', () => {
|
||||
let action = consoleActions.showError('an error');
|
||||
expect(action.type).to.equal(actions.CONSOLE_SHOW_ERROR);
|
||||
expect(action.text).to.equal('an error');
|
||||
});
|
||||
});
|
||||
|
||||
describe("hide", () => {
|
||||
it('create CONSOLE_HIDE action', () => {
|
||||
let action = consoleActions.hide();
|
||||
expect(action.type).to.equal(actions.CONSOLE_HIDE);
|
||||
});
|
||||
});
|
||||
|
||||
describe("setCompletions", () => {
|
||||
it('create CONSOLE_SET_COMPLETIONS action', () => {
|
||||
let action = consoleActions.setCompletions([1,2,3]);
|
||||
expect(action.type).to.equal(actions.CONSOLE_SET_COMPLETIONS);
|
||||
expect(action.completions).to.deep.equal([1, 2, 3]);
|
||||
});
|
||||
});
|
||||
|
||||
describe("completionPrev", () => {
|
||||
it('create CONSOLE_COMPLETION_PREV action', () => {
|
||||
let action = consoleActions.completionPrev();
|
||||
expect(action.type).to.equal(actions.CONSOLE_COMPLETION_PREV);
|
||||
});
|
||||
});
|
||||
|
||||
describe("completionNext", () => {
|
||||
it('create CONSOLE_COMPLETION_NEXT action', () => {
|
||||
let action = consoleActions.completionNext();
|
||||
expect(action.type).to.equal(actions.CONSOLE_COMPLETION_NEXT);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
118
test/console/reducers/console.test.js
Normal file
118
test/console/reducers/console.test.js
Normal file
|
@ -0,0 +1,118 @@
|
|||
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('errorShown', false);
|
||||
expect(state).to.have.property('errorText', '');
|
||||
expect(state).to.have.property('commandShown', false);
|
||||
expect(state).to.have.property('commandText', '');
|
||||
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('commandShown', true);
|
||||
expect(state).to.have.property('commandText', 'open ');
|
||||
expect(state).to.have.property('errorShown', false);
|
||||
});
|
||||
|
||||
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('errorShown', true);
|
||||
expect(state).to.have.property('errorText', 'an error');
|
||||
expect(state).to.have.property('commandShown', false);
|
||||
});
|
||||
|
||||
it('return next state for CONSOLE_HIDE', () => {
|
||||
let action = { type: actions.CONSOLE_HIDE };
|
||||
let state = reducer({}, action);
|
||||
expect(state).to.have.property('errorShown', false);
|
||||
expect(state).to.have.property('commandShown', false);
|
||||
});
|
||||
|
||||
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);
|
||||
});
|
||||
|
||||
});
|
Reference in a new issue