Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hustcc/jest-canvas-mock
:last_quarter_moon: A module used to mock canvas in Jest.
https://github.com/hustcc/jest-canvas-mock
canvas ci echarts jest jest-test mock
Last synced: 4 days ago
JSON representation
:last_quarter_moon: A module used to mock canvas in Jest.
- Host: GitHub
- URL: https://github.com/hustcc/jest-canvas-mock
- Owner: hustcc
- Created: 2017-12-24T10:40:47.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2024-08-12T05:42:36.000Z (5 months ago)
- Last Synced: 2024-12-25T22:07:06.597Z (18 days ago)
- Topics: canvas, ci, echarts, jest, jest-test, mock
- Language: JavaScript
- Homepage: https://github.com/hustcc/jest-canvas-mock
- Size: 271 KB
- Stars: 308
- Watchers: 4
- Forks: 56
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-jest - jest-canvas-mock
README
# jest-canvas-mock
> Mock `canvas` when run unit test cases with jest. For more browser environment.
> - [jest-random-mock](https://github.com/hustcc/jest-random-mock) Mock `Math.random` in jest, with deterministic random generator.
> - [jest-date-mock](https://github.com/hustcc/jest-date-mock) Mock `Date` when run unit test with jest, test `Date` easily.[![Build Status](https://github.com/hustcc/jest-canvas-mock/workflows/build/badge.svg)](https://github.com/hustcc/jest-canvas-mock/actions/workflows/build.yml)
[![Coverage Status](https://coveralls.io/repos/github/hustcc/jest-canvas-mock/badge.svg?branch=master)](https://coveralls.io/github/hustcc/jest-canvas-mock)
[![npm](https://img.shields.io/npm/v/jest-canvas-mock.svg)](https://www.npmjs.com/package/jest-canvas-mock)
[![npm](https://img.shields.io/npm/dm/jest-canvas-mock.svg)](https://www.npmjs.com/package/jest-canvas-mock)
[![Mentioned in Awesome Jest](https://awesome.re/mentioned-badge.svg)](https://github.com/jest-community/awesome-jest)## Install
This should only be installed as a development dependency (`devDependencies`) as it is only designed for testing.
```bash
npm i --save-dev jest-canvas-mock
```## Setup
In your `package.json` under the `jest`, create a `setupFiles` array and add `jest-canvas-mock` to the array.
```json
{
"jest": {
"setupFiles": ["jest-canvas-mock"]
}
}
```If you already have a `setupFiles` attribute you can also append `jest-canvas-mock` to the array.
```json
{
"jest": {
"setupFiles": ["./__setups__/other.js", "jest-canvas-mock"]
}
}
```More about in [configuration section](https://facebook.github.io/jest/docs/en/configuration.html#content).
## Setup file
Alternatively you can create a new setup file which then requires this module or
add the `require` statement to an existing setup file.`__setups__/canvas.js`
```js
import 'jest-canvas-mock';
// or
require('jest-canvas-mock');
```Add that file to your `setupFiles` array:
```json
"jest": {
"setupFiles": [
"./__setups__/canvas.js"
]
}
```## Reset
If you reset the jest mocks (for example, with `jest.resetAllMocks()`), you can
call `setupJestCanvasMock()` to re-create it.```
import { setupJestCanvasMock } from 'jest-canvas-mock';beforeEach(() => {
jest.resetAllMocks();
setupJestCanvasMock();
});
```## Mock Strategy
This mock strategy implements all the canvas functions and actually verifies the parameters. If a
known condition would cause the browser to throw a `TypeError` or a `DOMException`, it emulates the
error. For instance, the `CanvasRenderingContext2D#arc` function will throw a `TypeError` if the
radius is negative, or if it was not provided with enough parameters.```ts
// arc throws a TypeError when the argument length is less than 5
expect(() => ctx.arc(1, 2, 3, 4)).toThrow(TypeError);// when radius is negative, arc throws a dom exception when all parameters are finite
expect(() => ctx.arc(0, 0, -10, 0, Math.PI * 2)).toThrow(DOMException);
```The function will do `Number` type coercion and verify the inputs exactly like the browser does. So
this is valid input.```ts
expect(() => ctx.arc('10', '10', '20', '0', '6.14')).not.toThrow();
```Another part of the strategy is to validate input types. When using the
`CanvasRenderingContext2D#fill` function, if you pass it an invalid `fillRule` it will throw a
`TypeError` just like the browser does.```ts
expect(() => ctx.fill('invalid!')).toThrow(TypeError);
expect(() => ctx.fill(new Path2D(), 'invalid!')).toThrow(TypeError);
```We try to follow the ECMAScript specification as closely as possible.
## Snapshots
There are multiple ways to validate canvas state using snapshots. There are currently three methods
attached to the `CanvasRenderingContext2D` class. The first way to use this feature is by using the
`__getEvents` method.```ts
/**
* In order to see which functions and properties were used for the test, you can use `__getEvents`
* to gather this information.
*/
const events = ctx.__getEvents();expect(events).toMatchSnapshot(); // jest will assert the events match the snapshot
```The second way is to inspect the current path associated with the context.
```ts
ctx.beginPath();
ctx.arc(1, 2, 3, 4, 5);
ctx.moveTo(6, 7);
ctx.rect(6, 7, 8, 9);
ctx.closePath();/**
* Any method that modifies the current path (and subpath) will be pushed to an event array. When
* using the `__getPath` method, that array will sliced and usable for snapshots.
*/
const path = ctx.__getPath();
expect(path).toMatchSnapshot();
```The third way is to inspect all of the successful draw calls submitted to the context.
```ts
ctx.drawImage(img, 0, 0);/**
* Every drawImage, fill, stroke, fillText, or strokeText function call will be logged in an event
* array. This method will return those events here for inspection.
*/
const calls = ctx.__getDrawCalls();
expect(calls).toMatchSnapshot();
```In some cases it may be useful to clear the events or draw calls that have already been logged.
```ts
// Clear events
ctx.__clearEvents();// Clear draw calls
ctx.__clearDrawCalls();
```Finally, it's possible to inspect the clipping region calls by using the `__getClippingRegion`
function.```ts
const clippingRegion = ctx.__getClippingRegion();
expect(clippingRegion).toMatchSnapshot();
```The clipping region cannot be cleared because it's based on the stack values and when the `.clip()`
function is called.## Override default mock return value
You can override the default mock return value in your test to suit your need. For example, to override return value of `toDataURL`:
```ts
canvas.toDataURL.mockReturnValueOnce(
'data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg=='
);
```## Contributors
- [@hustcc](https://github.com/hustcc)
- [@jtenner](https://github.com/jtenner)
- [@evanoc0](https://github.com/evanoc0)
- [@lekha](https://github.com/lekha)
- [@yonatankra](https://github.com/yonatankra)
- [@LitoMore](https://github.com/LitoMore)
- [@hrd543](https://github.com/hrd543)
- [@danielrentz](https://github.com/danielrentz)
- [@pedroordep](https://github.com/pedroordep)## License
MIT@[hustcc](https://github.com/hustcc).