gecko-dev/dom/workers/test/notification_permission_worker.js
Nikhil Marathe 091eef6ff6 Bug 916893 - Patch 1 - Notification on workers. r=khuey,wchen
Does not implement the Service Worker API - https://notifications.spec.whatwg.org/#service-worker-api
***
Folded:
Bug 916893 - Better ownership model. r=khuey
Fix for bug found by ASan where we were touching the NotificationFeature after releasing it.

--HG--
extra : transplant_source : %3C%09F%99%CASF%1A%25%89X%D9%8C%0B%FAu%9D%27%E8w
2015-06-25 18:53:02 -07:00

57 lines
1.5 KiB
JavaScript

function info(message) {
dump("INFO: " + message + "\n");
}
function ok(test, message) {
postMessage({ type: 'ok', test: test, message: message });
}
function is(a, b, message) {
postMessage({ type: 'is', test1: a, test2: b, message: message });
}
if (self.Notification) {
var steps = [
function (done) {
info("Test notification permission");
ok(typeof Notification === "function", "Notification constructor exists");
ok(Notification.permission === "denied", "Notification.permission is denied.");
var n = new Notification("Hello");
n.onerror = function(e) {
ok(true, "error called due to permission denied.");
done();
}
},
];
onmessage = function(e) {
var context = {};
(function executeRemainingTests(remainingTests) {
if (!remainingTests.length) {
postMessage({type: 'finish'});
return;
}
var nextTest = remainingTests.shift();
var finishTest = executeRemainingTests.bind(null, remainingTests);
var startTest = nextTest.call.bind(nextTest, context, finishTest);
try {
startTest();
// if no callback was defined for test function,
// we must manually invoke finish to continue
if (nextTest.length === 0) {
finishTest();
}
} catch (e) {
ok(false, "Test threw exception! " + nextTest + " " + e);
finishTest();
}
})(steps);
}
} else {
ok(true, "Notifications are not enabled in workers on the platform.");
postMessage({ type: 'finish' });
}