diff options
author | Shin'ya Ueoka <ueokande@i-beam.org> | 2017-10-08 15:19:25 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-08 15:19:25 +0900 |
commit | 0183161145d36cbafb7dbd86ca3a1aac6faca43f (patch) | |
tree | aed757bfb5f8789156439d1e1fdff4e221376aaa /test/content | |
parent | 0f54a203dba38acdd080a928cee95f875fe84706 (diff) | |
parent | 57f798044d32ba7f9dc10a34ac31ad5dbdbf56ae (diff) |
Merge pull request #22 from ueokande/separate-domains
Refactor: Separate domains
Diffstat (limited to 'test/content')
-rw-r--r-- | test/content/actions/follow.test.js | 35 | ||||
-rw-r--r-- | test/content/actions/input.test.js | 26 | ||||
-rw-r--r-- | test/content/components/follow.html | 9 | ||||
-rw-r--r-- | test/content/components/follow.test.js | 15 | ||||
-rw-r--r-- | test/content/reducers/follow.test.js | 48 | ||||
-rw-r--r-- | test/content/reducers/input.test.js | 26 |
6 files changed, 159 insertions, 0 deletions
diff --git a/test/content/actions/follow.test.js b/test/content/actions/follow.test.js new file mode 100644 index 0000000..3ac844c --- /dev/null +++ b/test/content/actions/follow.test.js @@ -0,0 +1,35 @@ +import { expect } from "chai"; +import actions from 'content/actions'; +import * as followActions from 'content/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/content/actions/input.test.js b/test/content/actions/input.test.js new file mode 100644 index 0000000..6031829 --- /dev/null +++ b/test/content/actions/input.test.js @@ -0,0 +1,26 @@ +import { expect } from "chai"; +import actions from 'content/actions'; +import * as inputActions from 'content/actions/input'; + +describe("input actions", () => { + describe("keyPress", () => { + it('create INPUT_KEY_PRESS action', () => { + let action = inputActions.keyPress('a', false); + expect(action.type).to.equal(actions.INPUT_KEY_PRESS); + expect(action.key).to.equal('a'); + }); + + it('create INPUT_KEY_PRESS action from key with ctrl', () => { + let action = inputActions.keyPress('b', true); + expect(action.type).to.equal(actions.INPUT_KEY_PRESS); + expect(action.key).to.equal('<C-B>'); + }); + }); + + describe("clearKeys", () => { + it('create INPUT_CLEAR_KEYSaction', () => { + let action = inputActions.clearKeys(); + expect(action.type).to.equal(actions.INPUT_CLEAR_KEYS); + }); + }); +}); diff --git a/test/content/components/follow.html b/test/content/components/follow.html new file mode 100644 index 0000000..6bd8f87 --- /dev/null +++ b/test/content/components/follow.html @@ -0,0 +1,9 @@ +<!DOCTYPE html> +<html> + <body> + <a href='#' >link</a> + <a href='#' style='display:none'>invisible 1</a> + <a href='#' style='visibility:hidden'>invisible 2</a> + <i>not link<i> + </body> +</html> diff --git a/test/content/components/follow.test.js b/test/content/components/follow.test.js new file mode 100644 index 0000000..9c00c79 --- /dev/null +++ b/test/content/components/follow.test.js @@ -0,0 +1,15 @@ +import { expect } from "chai"; +import FollowComponent from 'content/components/follow'; + +describe('FollowComponent', () => { + describe('#getTargetElements', () => { + beforeEach(() => { + document.body.innerHTML = __html__['test/content/components/follow.html']; + }); + + it('returns visible links', () => { + let links = FollowComponent.getTargetElements(window.document); + expect(links).to.have.lengthOf(1); + }); + }); +}); diff --git a/test/content/reducers/follow.test.js b/test/content/reducers/follow.test.js new file mode 100644 index 0000000..e2b3445 --- /dev/null +++ b/test/content/reducers/follow.test.js @@ -0,0 +1,48 @@ +import { expect } from "chai"; +import actions from 'content/actions'; +import followReducer from 'content/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); + expect(state).to.have.property('keys', ''); + }); + + 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: 'a'}; + let state = followReducer({ keys: '' }, action); + expect(state).to.have.deep.property('keys', 'a'); + + action = { type: actions.FOLLOW_KEY_PRESS, key: 'b'}; + state = followReducer(state, action); + expect(state).to.have.deep.property('keys', 'ab'); + }); + + it ('returns next state for FOLLOW_BACKSPACE', () => { + let action = { type: actions.FOLLOW_BACKSPACE }; + let state = followReducer({ keys: 'ab' }, action); + expect(state).to.have.deep.property('keys', 'a'); + + state = followReducer(state, action); + expect(state).to.have.deep.property('keys', ''); + + state = followReducer(state, action); + expect(state).to.have.deep.property('keys', ''); + }); +}); 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', ''); + }); +}); |