blob: 3848dc4402b71bed79b5f9662405acd03cf30f1e (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
importScripts('/resources/testharness.js');
importScripts('sw-helpers.js');
async function updateUI(event) {
let updateParams = [];
switch (event.registration.id) {
case 'update-once':
updateParams = [{title: 'Title1'}];
break;
case 'update-twice':
updateParams = [{title: 'Title1'}, {title: 'Title2'}];
break;
}
return Promise.all(updateParams.map(param => event.updateUI(param)))
.then(() => 'update success')
.catch(e => e.name);
}
self.addEventListener('backgroundfetchsuccess', event => {
if (event.registration.id === 'update-inactive') {
// Post an async task before calling updateUI from the inactive event.
// Any async behaviour outside `waitUntil` should mark the event as
// inactive, and subsequent calls to `updateUI` should fail.
new Promise(r => step_timeout(r, 0))
.then(() => event.updateUI({ title: 'New title' }))
.catch(e => sendMessageToDocument({ update: e.name }));
return;
}
event.waitUntil(updateUI(event)
.then(update => sendMessageToDocument({ update })));
});
|