зеркало из https://github.com/mozilla/gecko-dev.git
Backed out changeset 2c423ac723b6 (bug 1263304
)
This commit is contained in:
Родитель
1a5d1d94ab
Коммит
933a225285
|
@ -1,46 +0,0 @@
|
|||
var keepAlivePromise;
|
||||
var resolvePromise;
|
||||
var result = "Failed";
|
||||
|
||||
onactivate = function(event) {
|
||||
event.waitUntil(clients.claim());
|
||||
}
|
||||
|
||||
onmessage = function(event) {
|
||||
if (event.data === "Start") {
|
||||
event.waitUntil(Promise.reject());
|
||||
|
||||
keepAlivePromise = new Promise(function(resolve, reject) {
|
||||
resolvePromise = resolve;
|
||||
});
|
||||
|
||||
result = "Success";
|
||||
event.waitUntil(keepAlivePromise);
|
||||
event.source.postMessage("Started");
|
||||
} else if (event.data === "Result") {
|
||||
event.source.postMessage(result);
|
||||
if (resolvePromise !== undefined) {
|
||||
resolvePromise();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
addEventListener('fetch', e => {
|
||||
let respondWithPromise = new Promise(function(res, rej) {
|
||||
setTimeout(() => {
|
||||
res(new Response("ok"));
|
||||
}, 0);
|
||||
});
|
||||
e.respondWith(respondWithPromise);
|
||||
// Test that waitUntil can be called in the promise handler of the existing
|
||||
// lifetime extension promise.
|
||||
respondWithPromise.then(() => {
|
||||
e.waitUntil(clients.matchAll().then((cls) => {
|
||||
if (cls.length != 1) {
|
||||
dump("ERROR: no controlled clients.\n");
|
||||
}
|
||||
client = cls[0];
|
||||
client.postMessage("Done");
|
||||
}));
|
||||
});
|
||||
});
|
|
@ -212,7 +212,6 @@ support-files =
|
|||
hello.html
|
||||
create_another_sharedWorker.html
|
||||
sharedWorker_fetch.js
|
||||
async_waituntil_worker.js
|
||||
|
||||
[test_bug1151916.html]
|
||||
[test_bug1240436.html]
|
||||
|
@ -316,4 +315,3 @@ tags = openwindow
|
|||
[test_workerUpdate.html]
|
||||
[test_workerupdatefoundevent.html]
|
||||
[test_xslt.html]
|
||||
[test_async_waituntil.html]
|
||||
|
|
|
@ -1,97 +0,0 @@
|
|||
<!DOCTYPE HTML>
|
||||
<html>
|
||||
<!--
|
||||
Test that:
|
||||
1. waitUntil() waits for each individual promise separately, even if
|
||||
one of them was rejected.
|
||||
2. waitUntil() can be called asynchronously as long as there is still
|
||||
a pending extension promise.
|
||||
-->
|
||||
<head>
|
||||
<title>Test for Bug 1263304</title>
|
||||
<script src="/tests/SimpleTest/SimpleTest.js"></script>
|
||||
<script src="/tests/SimpleTest/SpawnTask.js"></script>
|
||||
<script src="error_reporting_helpers.js"></script>
|
||||
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
|
||||
<meta http-equiv="Content-type" content="text/html;charset=UTF-8">
|
||||
</head>
|
||||
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1263304">Mozilla Bug 1263304</a>
|
||||
<p id="display"></p>
|
||||
<div id="content" style="display: none">
|
||||
|
||||
</div>
|
||||
<pre id="test">
|
||||
</pre>
|
||||
|
||||
<script class="testbody" type="text/javascript">
|
||||
add_task(function setupPrefs() {
|
||||
return SpecialPowers.pushPrefEnv({"set": [
|
||||
["dom.serviceWorkers.enabled", true],
|
||||
["dom.serviceWorkers.testing.enabled", true],
|
||||
]});
|
||||
});
|
||||
|
||||
function wait_for_message(expected_message) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
navigator.serviceWorker.onmessage = function(event) {
|
||||
navigator.serviceWorker.onmessage = null;
|
||||
ok(event.data === expected_message, "Received expected message event: " + event.data);
|
||||
resolve();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
add_task(function* async_wait_until() {
|
||||
var worker;
|
||||
let registration = yield navigator.serviceWorker.register(
|
||||
"async_waituntil_worker.js", { scope: "./"} )
|
||||
.then(function(registration) {
|
||||
worker = registration.installing;
|
||||
return new Promise(function(resolve) {
|
||||
worker.addEventListener('statechange', function() {
|
||||
if (worker.state === 'activated') {
|
||||
resolve(registration);
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
// The service worker will claim us when it becomes active.
|
||||
ok(navigator.serviceWorker.controller, "Controlled");
|
||||
|
||||
// This will make the service worker die immediately if there are no pending
|
||||
// waitUntil promises to keep it alive.
|
||||
yield SpecialPowers.pushPrefEnv({"set": [
|
||||
["dom.serviceWorkers.idle_timeout", 0],
|
||||
["dom.serviceWorkers.idle_extended_timeout", 299999]]});
|
||||
|
||||
// The service worker will wait on two promises, one of which
|
||||
// will be rejected. We check whether the SW is killed using
|
||||
// the value of a global variable.
|
||||
let waitForStart = wait_for_message("Started");
|
||||
worker.postMessage("Start");
|
||||
yield waitForStart;
|
||||
|
||||
yield new Promise((res, rej) => {
|
||||
setTimeout(res, 0);
|
||||
});
|
||||
|
||||
let waitResult = wait_for_message("Success");
|
||||
worker.postMessage("Result");
|
||||
yield waitResult;
|
||||
|
||||
// Test the behaviour of calling waitUntil asynchronously. The important
|
||||
// part is that we receive the message event.
|
||||
let waitForMessage = wait_for_message("Done");
|
||||
yield fetch("doesnt_exist.html").then(() => {
|
||||
ok(true, "Fetch was successful.");
|
||||
});
|
||||
yield waitForMessage;
|
||||
|
||||
yield SpecialPowers.popPrefEnv();
|
||||
yield SpecialPowers.popPrefEnv();
|
||||
yield registration.unregister();
|
||||
});
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
Загрузка…
Ссылка в новой задаче