For npm:
npm i --save-dev jest-webextension-mockFor yarn:
yarn add --dev jest-webextension-mockIn your package.json under the jest section add the setupFiles attribute with this module name.
"jest": {
"setupFiles": [
"jest-webextension-mock"
]
}Alternatively you can create a new setup file and require this module.
__setups__/chrome.js
require('jest-webextension-mock');And add that file to your setupFiles:
"jest": {
"setupFiles": [
"./__setups__/chrome.js"
]
}Use this module to check that API calls were made when expected.
describe('your function to test', () => {
it('should have called a webextension API', () => {
yourFunctionToTest();
expect(chrome.tabs.update).toHaveBeenCalled();
});
});Check the API was called with certain parameters.
describe('your function to test', () => {
it('should have called a webextension API', () => {
yourFunctionToTest();
expect(chrome.tabs.update).toHaveBeenCalledWith({
url: 'https://example.com/'
});
});
});And you can reset the API mocks to ensure APIs are only called when needed.
beforeEach(() => {
browser.geckoProfiler.start.mockClear();
browser.geckoProfiler.stop.mockClear();
});
it('should toggle the profiler on from stopped', () => {
const store = mockStore(reducer(undefined, {}));
const expectedActions = [
{ type: 'PROFILER_START', status: 'start' },
{ type: 'PROFILER_START', status: 'done' },
];
return store.dispatch(actions.toggle()).then(() => {
expect(browser.geckoProfiler.start).toHaveBeenCalledTimes(1);
expect(store.getActions()).toEqual(expectedActions);
});
});npm install
npm testnpm run lint
npm run lint:fix # auto-fix
npm run prettier # format codePRs require a changeset entry for changelog tracking. After making your changes:
npx changesetFollow the prompts to describe your change (patch/minor/major). This creates a markdown file in .changeset/ that should be committed with your PR.
For changes that don't affect the published package (CI config, docs, etc.), add an empty changeset:
npx changeset --emptyPublishing is done locally to avoid storing npm credentials in CI.
npm run release # bumps version + updates CHANGELOG.md
git add -A && git commit -m "release: vX.Y.Z"
git push
npm publish # builds dist/ automatically via prepublishOnly
git tag vX.Y.Z && git push --tags # tag the release