inula/scripts/__tests__/EventTest/KeyboardEvent.test.js

181 lines
4.2 KiB
JavaScript

import * as Horizon from '@cloudsop/horizon/index.ts';
import { getLogUtils } from '../jest/testUtils';
describe('Keyboard Event', () => {
const LogUtils = getLogUtils();
it('keydown,keypress,keyup的keycode,charcode', () => {
const node = Horizon.render(
<input
onKeyUp={(e) => {
LogUtils.log('onKeyUp: keycode: ' + e.keyCode + ',charcode: ' + e.charCode);
}}
onKeyDown={(e) => {
LogUtils.log('onKeyDown: keycode: ' + e.keyCode + ',charcode: ' + e.charCode);
}}
/>,
container,
);
node.dispatchEvent(
new KeyboardEvent('keydown', {
keyCode: 50,
code: 'Digit2',
bubbles: true,
cancelable: true,
}),
);
node.dispatchEvent(
new KeyboardEvent('keyup', {
keyCode: 50,
code: 'Digit2',
bubbles: true,
cancelable: true,
}),
);
expect(LogUtils.getAndClear()).toEqual([
'onKeyDown: keycode: 50,charcode: 0',
'onKeyUp: keycode: 50,charcode: 0'
]);
});
it('keypress的keycode,charcode', () => {
const node = Horizon.render(
<input
onKeyPress={(e) => {
LogUtils.log('onKeyPress: keycode: ' + e.keyCode + ',charcode: ' + e.charCode);
}}
/>,
container,
);
node.dispatchEvent(
new KeyboardEvent('keypress', {
charCode: 50,
code: 'Digit2',
bubbles: true,
cancelable: true,
}),
);
expect(LogUtils.getAndClear()).toEqual([
'onKeyPress: keycode: 0,charcode: 50'
]);
});
it('当charcode为13,且不设置keycode的时候', () => {
const node = Horizon.render(
<input
onKeyPress={(e) => {
LogUtils.log('onKeyPress: keycode: ' + e.keyCode + ',charcode: ' + e.charCode);
}}
/>,
container,
);
node.dispatchEvent(
new KeyboardEvent('keypress', {
charCode: 13,
bubbles: true,
cancelable: true,
}),
);
expect(LogUtils.getAndClear()).toEqual([
'onKeyPress: keycode: 0,charcode: 13'
]);
});
it('keydown,keypress,keyup的code', () => {
const node = Horizon.render(
<input
onKeyUp={(e) => {
LogUtils.log('onKeyUp: code: ' + e.code);
}}
onKeyPress={(e) => {
LogUtils.log('onKeyPress: code: ' + e.code);
}}
onKeyDown={(e) => {
LogUtils.log('onKeyDown: code: ' + e.code);
}}
/>,
container,
);
node.dispatchEvent(
new KeyboardEvent('keydown', {
code: 'Digit2',
bubbles: true,
cancelable: true,
}),
);
node.dispatchEvent(
new KeyboardEvent('keypress', {
keyCode: 50,
code: 'Digit2',
bubbles: true,
cancelable: true,
}),
);
node.dispatchEvent(
new KeyboardEvent('keyup', {
code: 'Digit2',
bubbles: true,
cancelable: true,
}),
);
expect(LogUtils.getAndClear()).toEqual([
'onKeyDown: code: Digit2',
'onKeyPress: code: Digit2',
'onKeyUp: code: Digit2'
]);
});
it('可以执行preventDefault和 stopPropagation', () => {
const keyboardProcessing = e => {
expect(e.isDefaultPrevented()).toBe(false);
e.preventDefault();
expect(e.isDefaultPrevented()).toBe(true);
expect(e.isPropagationStopped()).toBe(false);
e.stopPropagation();
expect(e.isPropagationStopped()).toBe(true);
LogUtils.log(e.type + ' handle');
};
const div = Horizon.render(
<div
onKeyDown={keyboardProcessing}
onKeyUp={keyboardProcessing}
onKeyPress={keyboardProcessing}
/>,
container,
);
div.dispatchEvent(
new KeyboardEvent('keydown', {
keyCode: 40,
bubbles: true,
cancelable: true,
}),
);
div.dispatchEvent(
new KeyboardEvent('keyup', {
keyCode: 40,
bubbles: true,
cancelable: true,
}),
);
div.dispatchEvent(
new KeyboardEvent('keypress', {
charCode: 40,
bubbles: true,
cancelable: true,
}),
);
expect(LogUtils.getAndClear()).toEqual([
'keydown handle',
'keyup handle',
'keypress handle'
]);
});
});