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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
// META: global=window-module
// META: script=/resources/testdriver.js
// META: script=/resources/testdriver-vendor.js
// META: script=/notifications/resources/helpers.js
let registration;
promise_setup(async () => {
await trySettingPermission("granted");
registration = await prepareActiveServiceWorker("push-sw.js");
});
promise_test(async (t) => {
const promise = new Promise(r => {
navigator.serviceWorker.addEventListener("message", r, { once: true })
});
const subscription = await registration.pushManager.subscribe();
t.add_cleanup(() => subscription.unsubscribe());
// https://w3c.github.io/push-api/#security-and-privacy-considerations
// When a permission is revoked, the user agent MAY fire the "pushsubscriptionchange"
// event for subscriptions created with that permission
//
// But Firefox fires pushsubscriptionchange on permission regrant instead of revocation.
// https://github.com/w3c/push-api/issues/236
await trySettingPermission("prompt");
await trySettingPermission("granted");
const pushSubscriptionChangeEvent = await promise;
assert_equals(pushSubscriptionChangeEvent.data.type, "pushsubscriptionchange");
assert_equals(pushSubscriptionChangeEvent.data.constructor, "PushSubscriptionChangeEvent");
assert_object_equals(pushSubscriptionChangeEvent.data.oldSubscription, subscription.toJSON());
}, "Fire pushsubscriptionchange event when permission is revoked");
promise_test(async (t) => {
const promise = new Promise(r => {
navigator.serviceWorker.addEventListener("message", r, { once: true })
});
const subscription = await registration.pushManager.subscribe();
t.add_cleanup(() => subscription.unsubscribe());
await SpecialPowers.spawnChrome([], async () => {
// Bug 1210943: UAID changes should drop existing push subscriptions
const uaid = await Services.prefs.getStringPref("dom.push.userAgentID");
await Services.prefs.setStringPref("dom.push.userAgentID", uaid + "0");
})
const pushSubscriptionChangeEvent = await promise;
assert_equals(pushSubscriptionChangeEvent.data.type, "pushsubscriptionchange");
assert_equals(pushSubscriptionChangeEvent.data.constructor, "PushSubscriptionChangeEvent");
assert_object_equals(pushSubscriptionChangeEvent.data.oldSubscription, subscription.toJSON());
assert_equals(pushSubscriptionChangeEvent.data.newSubscription, undefined);
}, "Fire pushsubscriptionchange event when UAID changes");
|