diff options
author | Shin'ya Ueoka <ueokande@i-beam.org> | 2017-10-21 21:17:27 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-21 21:17:27 +0900 |
commit | 7639e99b755e372712dca36e077a85d9a025cd9f (patch) | |
tree | 177a523e5996e302d647853cf4b11767e669de3c /test/content/components/common | |
parent | 941073404b534d7f79e90f29b514a5f06fb8080d (diff) | |
parent | 6ad143d294df0a0cc2dfb775ecab9f8b12ee7be5 (diff) |
Merge pull request #86 from ueokande/10-disable-temporary
Disable add-on temporary
Diffstat (limited to 'test/content/components/common')
-rw-r--r-- | test/content/components/common/input.test.js | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/test/content/components/common/input.test.js b/test/content/components/common/input.test.js new file mode 100644 index 0000000..912ac34 --- /dev/null +++ b/test/content/components/common/input.test.js @@ -0,0 +1,102 @@ +import InputComponent from 'content/components/common/input'; +import { expect } from "chai"; + +describe('InputComponent', () => { + it('register callbacks', () => { + let component = new InputComponent(window.document); + component.onKey((key) => { + expect(key).is.equals('a'); + }); + component.onKeyDown({ key: 'a' }); + }); + + it('invoke callback once', () => { + let component = new InputComponent(window.document); + let a = 0, b = 0; + component.onKey((key) => { + if (key == 'a') { + ++a; + } else { + key == 'b' + ++b; + } + }); + component.onKeyDown({ key: 'a' }); + component.onKeyDown({ key: 'b' }); + component.onKeyPress({ key: 'a' }); + component.onKeyUp({ key: 'a' }); + component.onKeyPress({ key: 'b' }); + component.onKeyUp({ key: 'b' }); + + expect(a).is.equals(1); + expect(b).is.equals(1); + }) + + it('add prefix when ctrl pressed', () => { + let component = new InputComponent(window.document); + component.onKey((key) => { + expect(key).is.equals('<C-A>'); + }); + component.onKeyDown({ key: 'a', ctrlKey: true }); + }) + + it('press X', () => { + let component = new InputComponent(window.document); + component.onKey((key) => { + expect(key).is.equals('X'); + }); + component.onKeyDown({ key: 'X', shiftKey: true }); + }) + + it('press <Shift> + <Esc>', () => { + let component = new InputComponent(window.document); + component.onKey((key) => { + expect(key).is.equals('<S-Esc>'); + }); + component.onKeyDown({ key: 'Escape', shiftKey: true }); + }) + + it('press <Ctrl> + <Esc>', () => { + let component = new InputComponent(window.document); + component.onKey((key) => { + expect(key).is.equals('<C-Esc>'); + }); + component.onKeyDown({ key: 'Escape', ctrlKey: true }); + }) + + it('does not invoke only meta keys', () => { + let component = new InputComponent(window.document); + component.onKey((key) => { + expect.fail(); + }); + component.onKeyDown({ key: 'Shift' }); + component.onKeyDown({ key: 'Control' }); + component.onKeyDown({ key: 'Alt' }); + component.onKeyDown({ key: 'OS' }); + }) + + it('ignores events from input elements', () => { + ['input', 'textarea', 'select'].forEach((name) => { + let target = window.document.createElement(name); + let component = new InputComponent(target); + component.onKey((key) => { + expect.fail(); + }); + component.onKeyDown({ key: 'x', target }); + }); + }); + + it('ignores events from contenteditable elements', () => { + let target = window.document.createElement('div'); + let component = new InputComponent(target); + component.onKey((key) => { + expect.fail(); + }); + + target.setAttribute('contenteditable', ''); + component.onKeyDown({ key: 'x', target }); + + target.setAttribute('contenteditable', 'true'); + component.onKeyDown({ key: 'x', target }); + }) +}); |