aboutsummaryrefslogtreecommitdiff
path: root/test/content/reducers/input.test.js
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2017-10-08 15:19:25 +0900
committerGitHub <noreply@github.com>2017-10-08 15:19:25 +0900
commit0183161145d36cbafb7dbd86ca3a1aac6faca43f (patch)
treeaed757bfb5f8789156439d1e1fdff4e221376aaa /test/content/reducers/input.test.js
parent0f54a203dba38acdd080a928cee95f875fe84706 (diff)
parent57f798044d32ba7f9dc10a34ac31ad5dbdbf56ae (diff)
Merge pull request #22 from ueokande/separate-domains
Refactor: Separate domains
Diffstat (limited to 'test/content/reducers/input.test.js')
-rw-r--r--test/content/reducers/input.test.js26
1 files changed, 26 insertions, 0 deletions
diff --git a/test/content/reducers/input.test.js b/test/content/reducers/input.test.js
new file mode 100644
index 0000000..d5e5f6b
--- /dev/null
+++ b/test/content/reducers/input.test.js
@@ -0,0 +1,26 @@
+import { expect } from "chai";
+import 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: '<C-B>' };
+ state = inputReducer(state, action);
+ expect(state).to.have.deep.property('keys', 'a<C-B>');
+ });
+
+ it('return next state for INPUT_CLEAR_KEYS', () => {
+ let action = { type: actions.INPUT_CLEAR_KEYS };
+ let state = inputReducer({ keys: 'abc' }, action);
+ expect(state).to.have.deep.property('keys', '');
+ });
+});