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@next
pnpm add test-keyboard@next
npm install test-keyboard@next
Keyboard.create
- (params: KeyboardConstructorParameter) => Keyboard
import { Keyboard } from 'test-keyboard';
const target = document.getElementById('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.