aboutsummaryrefslogtreecommitdiff
path: root/test/reducers/input.test.js
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2017-09-11 21:45:48 +0900
committerShin'ya Ueoka <ueokande@i-beam.org>2017-09-11 21:45:48 +0900
commitb2cddcd69b4ae06770d66808624fc43f3dcbcb0e (patch)
tree548eb65f678cfa1dca36773f01c635ec6c0e2066 /test/reducers/input.test.js
parent15d39a479aa7f2c4b804bac8c4352dd0a120bc75 (diff)
parent7bc569eac745b97137e1db8b9271493b3e5c8a20 (diff)
Merge branch 'message-passing-refactoring'
Diffstat (limited to 'test/reducers/input.test.js')
-rw-r--r--test/reducers/input.test.js34
1 files changed, 34 insertions, 0 deletions
diff --git a/test/reducers/input.test.js b/test/reducers/input.test.js
new file mode 100644
index 0000000..d7a0855
--- /dev/null
+++ b/test/reducers/input.test.js
@@ -0,0 +1,34 @@
+import { expect } from "chai";
+import actions from '../../src/actions';
+import inputReducer from '../../src/reducers/input';
+
+describe("input reducer", () => {
+ it('return the initial state', () => {
+ let state = inputReducer(undefined, {});
+ expect(state).to.have.deep.property('keys', []);
+ });
+
+ it('return next state for INPUT_KEY_PRESS', () => {
+ let action = { type: actions.INPUT_KEY_PRESS, code: 123, ctrl: true };
+ let state = inputReducer(undefined, action);
+ expect(state).to.have.deep.property('keys', [{ code: 123, ctrl: true }]);
+
+ action = { type: actions.INPUT_KEY_PRESS, code: 456, ctrl: false };
+ state = inputReducer(state, action);
+ expect(state).to.have.deep.property('keys', [
+ { code: 123, ctrl: true },
+ { code: 456, ctrl: false }
+ ]);
+ });
+
+ it('return next state for INPUT_CLEAR_KEYS', () => {
+ let action = { type: actions.INPUT_CLEAR_KEYS };
+ let state = inputReducer({
+ keys: [
+ { code: 123, ctrl: true },
+ { code: 456, ctrl: false }
+ ]
+ }, action);
+ expect(state).to.have.deep.property('keys', []);
+ });
+});