Add test case.

pull/23/head
jaywcjlove 7 years ago
parent f35fdc52c4
commit 81974256a4

@ -7,6 +7,8 @@
"build": "node scripts/build.js",
"watch": "node scripts/watch.js",
"pretest": "npm run build",
"test": "jest --coverage",
"test:watch": "jest --watch",
"doc:dev": "NODE_ENV=development parcel website/index.html --out-dir build/website --no-cache",
"doc:build": "NODE_ENV=production parcel build website/index.html --out-dir build/website --public-url ./ --no-cache"
},
@ -34,10 +36,12 @@
"classnames": "^2.2.5",
"colors-cli": "^1.0.13",
"highlight.js": "^9.12.0",
"jest": "^22.4.2",
"less": "^3.0.1",
"parcel-bundler": "^1.6.2",
"parcel-plugin-markdown-string": "^1.3.1",
"postcss-modules": "^1.1.0",
"puppeteer": "^1.2.0",
"react": "^16.2.0",
"react-dom": "^16.2.0",
"react-markdown": "^3.3.0",

@ -1,15 +1,12 @@
<html>
<head>
<meta charset="UTF-8">
<title>hotkeys.js - A robust Javascript library for capturing keyboard input.</title>
<title>hotkeys.js</title>
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<meta name="description" content="A robust Javascript library for capturing keyboard input and key combinations entered. It has no dependencies. Try to press your keyboard, The following button will highlight.">
</head>
<body>
<div id="root"></div>
<script src="../dist/index.js"></script>
<div id="root">hotkeys</div>
</body>
</html>

@ -0,0 +1,323 @@
const puppeteer = require('puppeteer')
const path = require('path')
const hotkeys = require('../dist/hotkeys');
let browser
let page
// expect().toEqual() :判断结果是否和预期等价。
// expect().toBeFalsy() :判断结果是否为假。
// expect().toBeTruthy() :判断结果是否为真。
var isff = navigator.userAgent.toLowerCase().indexOf('firefox') > 0;
// 模拟键盘摁键
// http://output.jsbin.com/awenaq/3
function __triggerKeyboardEvent(el, keyCode, opt) {
var eventObj = document.createEventObject ?
document.createEventObject() : document.createEvent("Events");
if (eventObj.initEvent) {
eventObj.initEvent("keydown", true, true);
}
eventObj.keyCode = keyCode;
eventObj.which = keyCode;
if (opt) {
for (var a in opt) {
eventObj[a] = opt[a];
}
}
el.dispatchEvent ? el.dispatchEvent(eventObj) : el.fireEvent("onkeydown", eventObj);
}
beforeAll(async () => {
browser = await puppeteer.launch()
page = await browser.newPage()
})
describe('Alibaba Search', () => {
test('HTML loader', async () => {
await page.setViewport({ width: 1280, height: 800 });
await page.goto('file://' + path.resolve('./test/index.html'), { waitUntil: 'networkidle2' });
}, 10000);
test('Test HTML load', async () => {
const title = await page.title();
expect(title).toBe('hotkeys.js');
const text = await page.$eval('#root', el => el.textContent);
expect(text).toBe('hotkeys');
})
test('HotKeys Test Case', async () => {
hotkeys('w', (e) => {
expect(e.keyCode).toBe(87);
});
__triggerKeyboardEvent(document.body, 87);
hotkeys('enter', function (e) {
expect(e.keyCode).toBe(13);
});
hotkeys('return', function (e) {
expect(e.keyCode).toBe(13);
});
__triggerKeyboardEvent(document.body, 13);
hotkeys('space', function (e) {
expect(e.keyCode).toBe(32);
});
__triggerKeyboardEvent(document.body, 32);
hotkeys('backspace', function (e) {
expect(e.keyCode).toBe(8);
});
__triggerKeyboardEvent(document.body, 8);
hotkeys('tab', function (e) {
expect(e.keyCode).toBe(9);
});
__triggerKeyboardEvent(document.body, 9);
hotkeys('clear', function (e) {
expect(e.keyCode).toBe(12);
});
__triggerKeyboardEvent(document.body, 12);
hotkeys(',', function (e) {
expect(e.keyCode).toBe(188);
});
__triggerKeyboardEvent(document.body, 188);
hotkeys('.', function (e) {
expect(e.keyCode).toBe(190);
});
__triggerKeyboardEvent(document.body, 190);
hotkeys('/', function (e) {
expect(e.keyCode).toBe(191);
});
__triggerKeyboardEvent(document.body, 191);
hotkeys('`', function (e) {
expect(e.keyCode).toBe(192);
});
__triggerKeyboardEvent(document.body, 192);
hotkeys('-', function (e) {
expect(e.keyCode).toBe(isff ? 173 : 189);
});
__triggerKeyboardEvent(document.body, isff ? 173 : 189);
hotkeys('=', function (e) {
expect(e.keyCode).toBe(isff ? 61 : 187);
});
__triggerKeyboardEvent(document.body, isff ? 61 : 187);
hotkeys(';', function (e) {
expect(e.keyCode).toBe(isff ? 59 : 186);
});
__triggerKeyboardEvent(document.body, isff ? 59 : 186);
hotkeys("\'".toString(), function (e) {
expect(e.keyCode).toBe(222);
});
__triggerKeyboardEvent(document.body, 222);
hotkeys("\\".toString(), function (e) {
expect(e.keyCode).toBe(220);
});
__triggerKeyboardEvent(document.body, 220);
hotkeys("[".toString(), function (e) {
expect(e.keyCode).toBe(219);
});
__triggerKeyboardEvent(document.body, 219);
hotkeys("]".toString(), function (e) {
expect(e.keyCode).toBe(221);
});
__triggerKeyboardEvent(document.body, 221);
hotkeys('left', function (e) {
expect(e.keyCode).toBe(37);
});
__triggerKeyboardEvent(document.body, 37);
hotkeys('up', function (e) {
expect(e.keyCode).toBe(38);
});
__triggerKeyboardEvent(document.body, 38);
hotkeys('del', function (e) {
expect(e.keyCode).toBe(46);
});
hotkeys('delete', function (e) {
expect(e.keyCode).toBe(46);
});
__triggerKeyboardEvent(document.body, 46);
hotkeys('home', function (e) {
expect(e.keyCode).toBe(36);
});
__triggerKeyboardEvent(document.body, 36);
hotkeys('pageup', function (e) {
expect(e.keyCode).toBe(33);
});
__triggerKeyboardEvent(document.body, 33);
hotkeys('pagedown', function (e) {
expect(e.keyCode).toBe(34);
});
__triggerKeyboardEvent(document.body, 34);
hotkeys('end', function (e) {
expect(e.keyCode).toBe(35);
});
__triggerKeyboardEvent(document.body, 35);
hotkeys('right', function (e) {
expect(e.keyCode).toBe(39);
});
__triggerKeyboardEvent(document.body, 39);
hotkeys('down', function (e) {
expect(e.keyCode).toBe(40);
});
__triggerKeyboardEvent(document.body, 40);
hotkeys('esc', function (e) {
expect(e.keyCode).toBe(27);
});
hotkeys('escape', function (e) {
expect(e.keyCode).toBe(27);
});
__triggerKeyboardEvent(document.body, 27);
hotkeys('CapsLock', function (e) {
expect(e.keyCode).toBe(20);
});
hotkeys('⇪', function (e) {
expect(e.keyCode).toBe(20);
});
__triggerKeyboardEvent(document.body, 20);
})
test('HotKeys Key combination Test Case', async () => {
hotkeys('⌘+d', function (e) {
expect(e.keyCode).toBe(82);
expect(e.metaKey).toBeTruthy();
return false;
});
__triggerKeyboardEvent(document.body, 82, {
metaKey: true
});
hotkeys('alt+d', function (e) {
expect(e.keyCode).toBe(68);
expect(e.altKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 68, {
altKey: true
});
hotkeys('shift+a', function (e) {
expect(e.keyCode).toBe(65);
expect(e.shiftKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 65, {
shiftKey: true
});
hotkeys('⇧+a', function (e) {
expect(e.keyCode).toBe(65);
expect(e.shiftKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 65, {
shiftKey: true
});
hotkeys('⌘+a', function (e) {
expect(e.keyCode).toBe(65);
expect(e.metaKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 65, {
metaKey: true
});
hotkeys('⌃+a', function (e) {
expect(e.keyCode).toBe(65);
expect(e.ctrlKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 65, {
ctrlKey: true
});
hotkeys.unbind("⌃+a")
hotkeys('⌥+a', function (e) {
expect(e.keyCode).toBe(65);
expect(e.altKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 65, {
altKey: true
});
hotkeys('ctrl+,,ctrl+d', function (e) {
expect(e.keyCode).toBe(188);
expect(e.ctrlKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 188, {
ctrlKey: true
});
hotkeys.unbind("ctrl+,,ctrl+d")
hotkeys('Ctrl+A', function (e) {
expect(e.keyCode).toBe(65);
expect(e.ctrlKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 65, {
ctrlKey: true
});
hotkeys.unbind("Ctrl+A")
hotkeys('CTRL+A', function (e) {
expect(e.keyCode).toBe(65);
expect(e.ctrlKey).toBeTruthy();
});
__triggerKeyboardEvent(document.body, 65, {
ctrlKey: true
});
hotkeys.unbind("CTRL+A")
hotkeys('⌃+a', function (e) {
expect(e.keyCode).toBe(65);
expect(hotkeys.getScope()).toBe('all');
});
__triggerKeyboardEvent(document.body, 65, {
ctrlKey: true
});
hotkeys.unbind("⌃+a")
hotkeys('⌃+a', 'scope1', function (e) {
expect(e.keyCode).toBe(65);
expect(hotkeys.getScope()).toBe('scope1');
});
hotkeys.setScope('scope1');
__triggerKeyboardEvent(document.body, 65, {
ctrlKey: true
});
hotkeys('⌃+a', 'scope2', function (e) {
expect(e.keyCode).toBe(65);
expect(hotkeys.getScope()).toBe('scope2');
});
hotkeys.setScope('scope2');
__triggerKeyboardEvent(document.body, 65, {
ctrlKey: true
});
})
afterAll(async () => {
await browser.close()
})
})
Loading…
Cancel
Save