aboutsummaryrefslogtreecommitdiff
path: root/test/content/reducers/input.test.ts
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2019-05-07 21:16:47 +0900
committerGitHub <noreply@github.com>2019-05-07 21:16:47 +0900
commit05ef6a8ca35aaa801c11eb6b4896caa3690058af (patch)
tree2c7708ca91ac2b462cc86aa28612e3d3943496f3 /test/content/reducers/input.test.ts
parent457d954e08923b4accd28a919c72d0b61db1bb98 (diff)
parent27d0a7f37d24a0ad68a8ccb7dee18fc1d00eea58 (diff)
Merge pull request #578 from ueokande/move-to-typescript
Move to TypeScript
Diffstat (limited to 'test/content/reducers/input.test.ts')
-rw-r--r--test/content/reducers/input.test.ts25
1 files changed, 25 insertions, 0 deletions
diff --git a/test/content/reducers/input.test.ts b/test/content/reducers/input.test.ts
new file mode 100644
index 0000000..f892201
--- /dev/null
+++ b/test/content/reducers/input.test.ts
@@ -0,0 +1,25 @@
+import * as actions from 'content/actions';
+import inputReducer from 'content/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, key: 'a' };
+ let state = inputReducer(undefined, action);
+ expect(state).to.have.deep.property('keys', ['a']);
+
+ action = { type: actions.INPUT_KEY_PRESS, key: 'b' };
+ state = inputReducer(state, action);
+ expect(state).to.have.deep.property('keys', ['a', 'b']);
+ });
+
+ it('return next state for INPUT_CLEAR_KEYS', () => {
+ let action = { type: actions.INPUT_CLEAR_KEYS };
+ let state = inputReducer({ keys: [1, 2, 3] }, action);
+ expect(state).to.have.deep.property('keys', []);
+ });
+});