aboutsummaryrefslogtreecommitdiff
path: root/test/console
diff options
context:
space:
mode:
Diffstat (limited to 'test/console')
-rw-r--r--test/console/actions/console.test.js51
-rw-r--r--test/console/reducers/console.test.js118
2 files changed, 169 insertions, 0 deletions
diff --git a/test/console/actions/console.test.js b/test/console/actions/console.test.js
new file mode 100644
index 0000000..dd04c85
--- /dev/null
+++ b/test/console/actions/console.test.js
@@ -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);
+ });
+ });
+});
+
diff --git a/test/console/reducers/console.test.js b/test/console/reducers/console.test.js
new file mode 100644
index 0000000..95ac993
--- /dev/null
+++ b/test/console/reducers/console.test.js
@@ -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);
+ });
+
+});