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'; ...@@ -9,11 +9,13 @@ var frame_url = scope + '-frame.html';
var shared_worker_url = scope + '-shared-worker.js'; var shared_worker_url = scope + '-shared-worker.js';
var worker_url = scope + '-worker.js'; var worker_url = scope + '-worker.js';
var client_ids = []; var client_ids = [];
var registration;
var frame; var frame;
promise_test(function(t) { promise_test(function(t) {
return service_worker_unregister_and_register( return service_worker_unregister_and_register(
t, 'resources/clients-get-worker.js', scope) t, 'resources/clients-get-worker.js', scope)
.then(function(registration) { .then(function(r) {
registration = r;
add_completion_callback(function() { registration.unregister(); }); add_completion_callback(function() { registration.unregister(); });
return wait_for_state(t, registration.installing, 'activated'); return wait_for_state(t, registration.installing, 'activated');
}) })
...@@ -59,12 +61,10 @@ promise_test(function(t) { ...@@ -59,12 +61,10 @@ promise_test(function(t) {
}) })
.then(function(client_id) { .then(function(client_id) {
client_ids.push(client_id); client_ids.push(client_id);
var channel = new MessageChannel();
var saw_message = new Promise(function(resolve) { var saw_message = new Promise(function(resolve) {
channel.port1.onmessage = resolve; navigator.serviceWorker.onmessage = resolve;
}); });
frame.contentWindow.navigator.serviceWorker.controller.postMessage( registration.active.postMessage({clientIds: client_ids});
{port: channel.port2, clientIds: client_ids}, [channel.port2]);
return saw_message; return saw_message;
}) })
.then(function(e) { .then(function(e) {
......
...@@ -38,16 +38,13 @@ window.addEventListener('message', function(e) { ...@@ -38,16 +38,13 @@ window.addEventListener('message', function(e) {
}) })
.then(function(iframe) { .then(function(iframe) {
add_completion_callback(function() { iframe.remove(); }); add_completion_callback(function() { iframe.remove(); });
var channel = new MessageChannel(); navigator.serviceWorker.onmessage = function(e) {
channel.port1.onmessage = function(e) {
registration.unregister(); registration.unregister();
window.parent.postMessage( window.parent.postMessage(
{ type: 'clientId', value: e.data }, host_info['HTTPS_ORIGIN'] { type: 'clientId', value: e.data }, host_info['HTTPS_ORIGIN']
); );
}; };
iframe.contentWindow.navigator.serviceWorker.controller.postMessage( registration.active.postMessage({clientIds: cross_origin_client_ids});
{port:channel.port2, clientIds: cross_origin_client_ids},
[channel.port2]);
}); });
}); });
</script> </script>
let savedPort = null; let savedPort = null;
let savedResultingClientId = null; let savedResultingClientId = null;
async function destroyResultingClient(e) { async function getTestingPage() {
const outer = await self.clients.matchAll({ type: 'window', includeUncontrolled: true }) const clientList = await self.clients.matchAll({ type: 'window', includeUncontrolled: true });
.then((clientList) => { for (let c of clientList) {
for (let c of clientList) { if (c.url.endsWith('clients-get.https.html')) {
if (c.url.endsWith('clients-get.https.html')) { c.focus();
c.focus(); return c;
return c;
}
} }
}); }
return null;
}
const p = new Promise(resolve => { async function destroyResultingClient(testingPage) {
function resultingClientDestroyed(evt) { const destroyedPromise = new Promise(resolve => {
if (evt.data.msg == 'resultingClientDestroyed') { self.addEventListener('message', e => {
self.removeEventListener('message', resultingClientDestroyed); if (e.data.msg == 'resultingClientDestroyed') {
resolve(outer); resolve();
} }
} }, {once: true});
self.addEventListener('message', resultingClientDestroyed);
}); });
testingPage.postMessage({ msg: 'destroyResultingClient' });
outer.postMessage({ msg: 'destroyResultingClient' }); return destroyedPromise;
return await p;
} }
self.addEventListener('fetch', async (e) => { self.addEventListener('fetch', async (e) => {
...@@ -33,32 +29,32 @@ self.addEventListener('fetch', async (e) => { ...@@ -33,32 +29,32 @@ self.addEventListener('fetch', async (e) => {
savedResultingClientId = resultingClientId; savedResultingClientId = resultingClientId;
if (e.request.url.endsWith('simple.html?fail')) { if (e.request.url.endsWith('simple.html?fail')) {
e.waitUntil(new Promise(async (resolve) => { e.waitUntil((async () => {
let outer = await destroyResultingClient(e); const testingPage = await getTestingPage();
await destroyResultingClient(testingPage);
outer.postMessage({ msg: 'resultingClientDestroyedAck', testingPage.postMessage({ msg: 'resultingClientDestroyedAck',
resultingDestroyedClientId: savedResultingClientId }); resultingDestroyedClientId: savedResultingClientId });
resolve(); })());
})); return;
} else {
e.respondWith(fetch(e.request));
} }
e.respondWith(fetch(e.request));
}); });
self.addEventListener('message', (e) => { self.addEventListener('message', (e) => {
let { msg, port, resultingClientId } = e.data; let { msg, resultingClientId } = e.data;
savedPort = savedPort || port; e.waitUntil((async () => {
if (msg == 'getIsResultingClientUndefined') {
if (msg == 'getIsResultingClientUndefined') { const client = await self.clients.get(resultingClientId);
self.clients.get(resultingClientId).then((client) => {
let isUndefined = typeof client == 'undefined'; let isUndefined = typeof client == 'undefined';
savedPort.postMessage({ msg: 'getIsResultingClientUndefined', e.source.postMessage({ msg: 'getIsResultingClientUndefined',
isResultingClientUndefined: isUndefined }); isResultingClientUndefined: isUndefined });
}); return;
} }
if (msg == 'getResultingClientId') {
if (msg == 'getResultingClientId') { e.source.postMessage({ msg: 'getResultingClientId',
savedPort.postMessage({ msg: 'getResultingClientId', resultingClientId: savedResultingClientId });
resultingClientId: savedResultingClientId }); return;
} }
})());
}); });
...@@ -11,7 +11,6 @@ self.onfetch = function(e) { ...@@ -11,7 +11,6 @@ self.onfetch = function(e) {
}; };
self.onmessage = function(e) { self.onmessage = function(e) {
var port = e.data.port;
var client_ids = e.data.clientIds; var client_ids = e.data.clientIds;
var message = []; var message = [];
...@@ -23,7 +22,7 @@ self.onmessage = function(e) { ...@@ -23,7 +22,7 @@ self.onmessage = function(e) {
// No matching client for a given id or a matched client is off-origin // No matching client for a given id or a matched client is off-origin
// from the service worker. // from the service worker.
if (clients.length == 1 && clients[0] == undefined) { if (clients.length == 1 && clients[0] == undefined) {
port.postMessage(clients[0]); e.source.postMessage(clients[0]);
} else { } else {
clients.forEach(function(client) { clients.forEach(function(client) {
if (client instanceof Client) { if (client instanceof Client) {
...@@ -36,7 +35,7 @@ self.onmessage = function(e) { ...@@ -36,7 +35,7 @@ self.onmessage = function(e) {
message.push(client); 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