blob: ca44e32f7f4921011226b9647bc4ba5d76495980 (
plain)
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
34
35
|
function unregisterAllServiceWorker() {
return navigator.serviceWorker.getRegistrations().then(registrations => {
return Promise.all(registrations.map(r => r.unregister()));
});
}
async function getActiveServiceWorker(script) {
await unregisterAllServiceWorker();
const reg = await navigator.serviceWorker.register(script);
add_completion_callback(() => reg.unregister());
await navigator.serviceWorker.ready;
return reg;
}
async function closeAllNotifications() {
for (const n of await registration.getNotifications()) {
n.close();
}
}
async function trySettingPermission(perm) {
try {
await test_driver.set_permission({ name: "notifications" }, perm);
} catch {
// Not all implementations support this yet, but the permission may already be set to be able to continue
}
// Using Notification.permission instead of permissions.query() as
// some implementation without set_permission support overrides
// Notification.permission.
const permission = Notification.permission === "default" ? "prompt" : Notification.permission;
if (permission !== perm) {
throw new Error(`Should have the permission ${perm} to continue`);
}
}
|