Commit 3629f6dc authored by Makoto Shimazu's avatar Makoto Shimazu Committed by Commit Bot

Refine wpt/service-workers/service-worker/clients-get.https.html

Used async functions, arrow functions, and const, and added some comments.

Bug: 778497
Change-Id: I03f23c6adddbb0e317edb197dc8af197597b2381
Reviewed-on: https://chromium-review.googlesource.com/c/1343416
Commit-Queue: Makoto Shimazu <shimazu@chromium.org>
Reviewed-by: default avatarMatt Falkenhagen <falken@chromium.org>
Cr-Commit-Position: refs/heads/master@{#609693}
parent 0b8807b1
......@@ -9,11 +9,13 @@ var frame_url = scope + '-frame.html';
var shared_worker_url = scope + '-shared-worker.js';
var worker_url = scope + '-worker.js';
var client_ids = [];
var registration;
var frame;
promise_test(function(t) {
return service_worker_unregister_and_register(
t, 'resources/clients-get-worker.js', scope)
.then(function(registration) {
.then(function(r) {
registration = r;
add_completion_callback(function() { registration.unregister(); });
return wait_for_state(t, registration.installing, 'activated');
})
......@@ -59,12 +61,10 @@ promise_test(function(t) {
})
.then(function(client_id) {
client_ids.push(client_id);
var channel = new MessageChannel();
var saw_message = new Promise(function(resolve) {
channel.port1.onmessage = resolve;
navigator.serviceWorker.onmessage = resolve;
});
frame.contentWindow.navigator.serviceWorker.controller.postMessage(
{port: channel.port2, clientIds: client_ids}, [channel.port2]);
registration.active.postMessage({clientIds: client_ids});
return saw_message;
})
.then(function(e) {
......
......@@ -38,16 +38,13 @@ window.addEventListener('message', function(e) {
})
.then(function(iframe) {
add_completion_callback(function() { iframe.remove(); });
var channel = new MessageChannel();
channel.port1.onmessage = function(e) {
navigator.serviceWorker.onmessage = function(e) {
registration.unregister();
window.parent.postMessage(
{ type: 'clientId', value: e.data }, host_info['HTTPS_ORIGIN']
);
};
iframe.contentWindow.navigator.serviceWorker.controller.postMessage(
{port:channel.port2, clientIds: cross_origin_client_ids},
[channel.port2]);
registration.active.postMessage({clientIds: cross_origin_client_ids});
});
});
</script>
let savedPort = null;
let savedResultingClientId = null;
async function destroyResultingClient(e) {
const outer = await self.clients.matchAll({ type: 'window', includeUncontrolled: true })
.then((clientList) => {
async function getTestingPage() {
const clientList = await self.clients.matchAll({ type: 'window', includeUncontrolled: true });
for (let c of clientList) {
if (c.url.endsWith('clients-get.https.html')) {
c.focus();
return c;
}
}
});
return null;
}
const p = new Promise(resolve => {
function resultingClientDestroyed(evt) {
if (evt.data.msg == 'resultingClientDestroyed') {
self.removeEventListener('message', resultingClientDestroyed);
resolve(outer);
}
async function destroyResultingClient(testingPage) {
const destroyedPromise = new Promise(resolve => {
self.addEventListener('message', e => {
if (e.data.msg == 'resultingClientDestroyed') {
resolve();
}
self.addEventListener('message', resultingClientDestroyed);
}, {once: true});
});
outer.postMessage({ msg: 'destroyResultingClient' });
return await p;
testingPage.postMessage({ msg: 'destroyResultingClient' });
return destroyedPromise;
}
self.addEventListener('fetch', async (e) => {
......@@ -33,32 +29,32 @@ self.addEventListener('fetch', async (e) => {
savedResultingClientId = resultingClientId;
if (e.request.url.endsWith('simple.html?fail')) {
e.waitUntil(new Promise(async (resolve) => {
let outer = await destroyResultingClient(e);
outer.postMessage({ msg: 'resultingClientDestroyedAck',
e.waitUntil((async () => {
const testingPage = await getTestingPage();
await destroyResultingClient(testingPage);
testingPage.postMessage({ msg: 'resultingClientDestroyedAck',
resultingDestroyedClientId: savedResultingClientId });
resolve();
}));
} else {
e.respondWith(fetch(e.request));
})());
return;
}
e.respondWith(fetch(e.request));
});
self.addEventListener('message', (e) => {
let { msg, port, resultingClientId } = e.data;
savedPort = savedPort || port;
let { msg, resultingClientId } = e.data;
e.waitUntil((async () => {
if (msg == 'getIsResultingClientUndefined') {
self.clients.get(resultingClientId).then((client) => {
const client = await self.clients.get(resultingClientId);
let isUndefined = typeof client == 'undefined';
savedPort.postMessage({ msg: 'getIsResultingClientUndefined',
e.source.postMessage({ msg: 'getIsResultingClientUndefined',
isResultingClientUndefined: isUndefined });
});
return;
}
if (msg == 'getResultingClientId') {
savedPort.postMessage({ msg: 'getResultingClientId',
e.source.postMessage({ msg: 'getResultingClientId',
resultingClientId: savedResultingClientId });
return;
}
})());
});
......@@ -11,7 +11,6 @@ self.onfetch = function(e) {
};
self.onmessage = function(e) {
var port = e.data.port;
var client_ids = e.data.clientIds;
var message = [];
......@@ -23,7 +22,7 @@ self.onmessage = function(e) {
// No matching client for a given id or a matched client is off-origin
// from the service worker.
if (clients.length == 1 && clients[0] == undefined) {
port.postMessage(clients[0]);
e.source.postMessage(clients[0]);
} else {
clients.forEach(function(client) {
if (client instanceof Client) {
......@@ -36,7 +35,7 @@ self.onmessage = function(e) {
message.push(client);
}
});
port.postMessage(message);
e.source.postMessage(message);
}
}));
};
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment