From 0a7ae631cd72100abdc26b84b06006bb5b166cba Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Mon, 2 Oct 2017 21:35:52 +0900 Subject: follow as redux --- test/components/follow.html | 9 +++++++++ test/components/follow.test.js | 25 +++++++++++++++++++++++++ test/content/follow.html | 9 --------- test/content/follow.test.js | 25 ------------------------- 4 files changed, 34 insertions(+), 34 deletions(-) create mode 100644 test/components/follow.html create mode 100644 test/components/follow.test.js delete mode 100644 test/content/follow.html delete mode 100644 test/content/follow.test.js (limited to 'test') diff --git a/test/components/follow.html b/test/components/follow.html new file mode 100644 index 0000000..6bd8f87 --- /dev/null +++ b/test/components/follow.html @@ -0,0 +1,9 @@ + + + + link + invisible 1 + invisible 2 + not link + + diff --git a/test/components/follow.test.js b/test/components/follow.test.js new file mode 100644 index 0000000..f2f870e --- /dev/null +++ b/test/components/follow.test.js @@ -0,0 +1,25 @@ +import { expect } from "chai"; +import FollowComponent from '../../src/components/follow'; + +describe('FollowComponent', () => { + describe('#codeChars', () => { + it('returns a string for key codes', () => { + let chars = [ + KeyboardEvent.DOM_VK_0, KeyboardEvent.DOM_VK_1, + KeyboardEvent.DOM_VK_A, KeyboardEvent.DOM_VK_B]; + expect(FollowComponent.codeChars(chars)).to.equal('01ab'); + expect(FollowComponent.codeChars([])).to.be.equal(''); + }); + }); + + describe('#getTargetElements', () => { + beforeEach(() => { + document.body.innerHTML = __html__['test/components/follow.html']; + }); + + it('returns visible links', () => { + let links = FollowComponent.getTargetElements(window.document); + expect(links).to.have.lengthOf(1); + }); + }); +}); diff --git a/test/content/follow.html b/test/content/follow.html deleted file mode 100644 index 6bd8f87..0000000 --- a/test/content/follow.html +++ /dev/null @@ -1,9 +0,0 @@ - - - - link - invisible 1 - invisible 2 - not link - - diff --git a/test/content/follow.test.js b/test/content/follow.test.js deleted file mode 100644 index fd4f0bc..0000000 --- a/test/content/follow.test.js +++ /dev/null @@ -1,25 +0,0 @@ -import { expect } from "chai"; -import Follow from '../../src/content/follow'; - -describe('Follow class', () => { - describe('#codeChars', () => { - it('returns a string for key codes', () => { - let chars = [ - KeyboardEvent.DOM_VK_0, KeyboardEvent.DOM_VK_1, - KeyboardEvent.DOM_VK_A, KeyboardEvent.DOM_VK_B]; - expect(Follow.codeChars(chars)).to.equal('01ab'); - expect(Follow.codeChars([])).to.be.equal(''); - }); - }); - - describe('#getTargetElements', () => { - beforeEach(() => { - document.body.innerHTML = __html__['test/content/follow.html']; - }); - - it('returns visible links', () => { - let links = Follow.getTargetElements(window.document); - expect(links).to.have.lengthOf(1); - }); - }); -}); -- cgit v1.2.3 From fc36195e79d5d7e59df3a507e05860ae6ca1495a Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Mon, 2 Oct 2017 21:53:12 +0900 Subject: add follow action and reducers test --- test/actions/follow.test.js | 35 +++++++++++++++++++++++++++++++++ test/reducers/follow.test.js | 47 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 82 insertions(+) create mode 100644 test/actions/follow.test.js create mode 100644 test/reducers/follow.test.js (limited to 'test') diff --git a/test/actions/follow.test.js b/test/actions/follow.test.js new file mode 100644 index 0000000..9439de7 --- /dev/null +++ b/test/actions/follow.test.js @@ -0,0 +1,35 @@ +import { expect } from "chai"; +import actions from '../../src/actions'; +import * as followActions from '../../src/actions/follow'; + +describe('follow actions', () => { + describe('enable', () => { + it('creates FOLLOW_ENABLE action', () => { + let action = followActions.enable(true); + expect(action.type).to.equal(actions.FOLLOW_ENABLE); + expect(action.newTab).to.equal(true); + }); + }); + + describe('disable', () => { + it('creates FOLLOW_DISABLE action', () => { + let action = followActions.disable(true); + expect(action.type).to.equal(actions.FOLLOW_DISABLE); + }); + }); + + describe('keyPress', () => { + it('creates FOLLOW_KEY_PRESS action', () => { + let action = followActions.keyPress(100); + expect(action.type).to.equal(actions.FOLLOW_KEY_PRESS); + expect(action.key).to.equal(100); + }); + }); + + describe('backspace', () => { + it('creates FOLLOW_BACKSPACE action', () => { + let action = followActions.backspace(100); + expect(action.type).to.equal(actions.FOLLOW_BACKSPACE); + }); + }); +}); diff --git a/test/reducers/follow.test.js b/test/reducers/follow.test.js new file mode 100644 index 0000000..19a1300 --- /dev/null +++ b/test/reducers/follow.test.js @@ -0,0 +1,47 @@ +import { expect } from "chai"; +import actions from '../../src/actions'; +import followReducer from '../../src/reducers/follow'; + +describe('follow reducer', () => { + it ('returns the initial state', () => { + let state = followReducer(undefined, {}); + expect(state).to.have.property('enabled', false); + expect(state).to.have.property('newTab'); + expect(state).to.have.deep.property('keys', []); + }); + + it ('returns next state for FOLLOW_ENABLE', () => { + let action = { type: actions.FOLLOW_ENABLE, newTab: true }; + let state = followReducer({ enabled: false, newTab: false }, action); + expect(state).to.have.property('enabled', true); + expect(state).to.have.property('newTab', true); + }); + + it ('returns next state for FOLLOW_DISABLE', () => { + let action = { type: actions.FOLLOW_DISABLE }; + let state = followReducer({ enabled: true }, action); + expect(state).to.have.property('enabled', false); + }); + + it ('returns next state for FOLLOW_KEY_PRESS', () => { + let action = { type: actions.FOLLOW_KEY_PRESS, key: 100}; + let state = followReducer({ keys: [] }, action); + expect(state).to.have.deep.property('keys', [100]); + + action = { type: actions.FOLLOW_KEY_PRESS, key: 200}; + state = followReducer(state, action); + expect(state).to.have.deep.property('keys', [100, 200]); + }); + + it ('returns next state for FOLLOW_BACKSPACE', () => { + let action = { type: actions.FOLLOW_BACKSPACE }; + let state = followReducer({ keys: [100, 200] }, action); + expect(state).to.have.deep.property('keys', [100]); + + state = followReducer(state, action); + expect(state).to.have.deep.property('keys', []); + + state = followReducer(state, action); + expect(state).to.have.deep.property('keys', []); + }); +}); -- cgit v1.2.3