Service Worker Mock
A mock service worker environment generator.
Why?
Testing service workers is difficult. Each file produces side-effects by calls to self.addEventListener
, and the service worker environment is unlike a normal web or node context. This package makes it easy to turn any environment into a feaux service worker environment. Additionally, it adds some helpful methods for testing integrations.
The service worker mock creates an environment with the following properties, based on the current Mozilla Service Worker Docs.
const env = {
skipWaiting: Function,
caches: CacheStorage,
clients: Clients,
registration: ServiceWorkerRegistration,
addEventListener: Function,
listeners: Object,
trigger: Function,
snapshot: Function,
};
Test Helper | description |
---|
listeners | [Object ] A key/value map of active listeners (install /activate /fetch /etc). |
trigger | [Function ] Used to trigger active listeners (await self.trigger('install') ). |
snapshot | [Function ] Used to generate a snapshot of the service worker internals (see below). |
Snapshot Property | description |
---|
caches | [Object ] A key/value map of current cache contents. |
clients | [Array ] A list of active clients. |
notifications | [Array ] A list of active notifications |
Use
The following is an example snippet derived from tests/basic.js. The test is based on the service worker example provided by Google.
const makeServiceWorkerEnv = require('service-worker-mock');
describe('Service worker', () => {
it('should delete old caches on activate', async () => {
Object.assign(global, makeServiceWorkerEnv());
require('./path/to/sw.js');
await self.caches.open('OLD_CACHE');
expect(self.snapshot().caches.OLD_CACHE).toBeDefined();
await self.trigger('activate');
expect(self.snapshot().caches.OLD_CACHE).toBeUndefined();
});
});
License
MIT