test-keyboard
A test keyboard for dispatching events to the dom which mimics keyboard actions from the user.
The problem
You want to write tests for code that makes heavy usage of the keyboard and you're finding it hard to compose these keyboard events together.
This solution
test-keyboard
is an elegant way of composing keyboard events together as if a user was typing.
It is primarily designed for dom-test environments but could be extracted out into something that can be used in your front-end code.
Installation
yarn add test-keyboard
pnpm add test-keyboard
npm install test-keyboard
Keyboard.create
- (params: KeyboardConstructorParameter) => Keyboard
import { Keyboard } from 'test-keyboard';
const target = document.querySelector('#editor');
Keyboard.create({
target,
})
.start()
.mod({ text: 'Ctrl-Shift-Enter' })
.end();
KeyboardConstructorParameter
Property | Type | Default | Description |
---|
target | Element | REQUIRED | The target of our events. |
defaultOptions | KeyboardEventInit | {} | The target of our events. |
isMac | boolean | false | Whether to simulate a mac. |
batch | boolean | false | Whether to wait until end is called before running all accumulated actions. |
onEventDispatch | (event: KeyboardEvent) => void | () => {} | Called whenever an event is dispatched with the keyboard event as a parameter. |
Acknowledgements
- Puppeteer for providing the US Keyboard information.