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) {
......
...@@ -4,221 +4,151 @@ ...@@ -4,221 +4,151 @@
<script src="/resources/testharnessreport.js"></script> <script src="/resources/testharnessreport.js"></script>
<script src="resources/test-helpers.sub.js"></script> <script src="resources/test-helpers.sub.js"></script>
<script> <script>
var scope = 'resources/clients-get-frame.html';
var client_ids = [];
var frame;
promise_test(function(t) {
return service_worker_unregister_and_register(
t, 'resources/clients-get-worker.js', scope)
.then(function(registration) {
add_completion_callback(function() { registration.unregister(); });
return wait_for_state(t, registration.installing, 'activated');
})
.then(function() {
return with_iframe(scope + '#1');
})
.then(function(frame1) {
add_completion_callback(function() { frame1.remove(); });
frame1.focus();
return wait_for_clientId();
})
.then(function(client_id) {
client_ids.push(client_id);
return with_iframe(scope + '#2');
})
.then(function(frame2) {
frame = frame2;
add_completion_callback(function() { frame2.remove(); });
return wait_for_clientId();
})
.then(function(client_id) {
client_ids.push(client_id, 'invalid-id');
var channel = new MessageChannel();
var saw_message = new Promise(function(resolve) {
channel.port1.onmessage = resolve;
});
frame.contentWindow.navigator.serviceWorker.controller.postMessage(
{port: channel.port2, clientIds: client_ids}, [channel.port2]);
return saw_message;
})
.then(function(e) {
assert_equals(e.data.length, 3);
assert_array_equals(e.data[0], expected[0]);
assert_array_equals(e.data[1], expected[1]);
assert_equals(e.data[2], expected[2]);
});
}, 'Test Clients.get()');
promise_test((t) => {
let frame = null;
const scope = 'resources/simple.html';
const outerSwContainer = navigator.serviceWorker;
let innerSwReg = null;
let innerSw = null;
return service_worker_unregister_and_register(
t, 'resources/clients-get-resultingClientId-worker.js', scope)
.then((registration) => {
innerSwReg = registration;
add_completion_callback(function() { registration.unregister(); });
return wait_for_state(t, registration.installing, 'activated');
})
.then(() => {
// load frame and get resulting client id
let channel = new MessageChannel();
innerSw = innerSwReg.active;
let p = new Promise(resolve => {
function getResultingClientId(e) {
if (e.data.msg == 'getResultingClientId') {
const { resultingClientId } = e.data;
channel.port1.removeEventListener('message', getResultingClientId);
resolve({ resultingClientId, port: channel.port1 });
}
}
channel.port1.onmessage = getResultingClientId;
});
return with_iframe(scope).then((iframe) => {
innerSw.postMessage(
{ port: channel.port2, msg: 'getResultingClientId' },
[channel.port2],
);
frame = iframe;
frame.focus();
add_completion_callback(() => iframe.remove());
return p;
});
})
.then(({ resultingClientId, port }) => {
// query service worker for clients.get(resultingClientId)
let channel = new MessageChannel();
let p = new Promise(resolve => {
function getIsResultingClientUndefined(e) {
if (e.data.msg == 'getIsResultingClientUndefined') {
let { isResultingClientUndefined } = e.data;
port.removeEventListener('message', getIsResultingClientUndefined);
resolve(isResultingClientUndefined);
}
}
port.onmessage = getIsResultingClientUndefined;
});
innerSw.postMessage(
{ port: channel.port2, msg: 'getIsResultingClientUndefined', resultingClientId },
[channel.port2],
);
return p;
})
.then((isResultingClientUndefined) => {
assert_false(isResultingClientUndefined, 'Clients.get(FetchEvent.resultingClientId) resolved with a Client');
});
}, 'Test successful Clients.get(FetchEvent.resultingClientId)');
promise_test((t) => {
const scope = 'resources/simple.html?fail';
const outerSwContainer = navigator.serviceWorker;
let innerSwReg = null;
let innerSw = null;
return service_worker_unregister_and_register(
t, 'resources/clients-get-resultingClientId-worker.js', scope)
.then((registration) => {
innerSwReg = registration;
add_completion_callback(function() { registration.unregister(); });
return wait_for_state(t, registration.installing, 'activated');
})
.then(() => {
// load frame, destroying it while loading, and get resulting client id
innerSw = innerSwReg.active;
let iframe = document.createElement('iframe');
iframe.className = 'test-iframe';
iframe.src = scope;
function destroyIframe(e) {
if (e.data.msg == 'destroyResultingClient') {
iframe.remove();
iframe = null;
innerSw.postMessage({ msg: 'resultingClientDestroyed' });
}
}
outerSwContainer.addEventListener('message', destroyIframe);
let p = new Promise(resolve => {
function resultingClientDestroyedAck(e) {
if (e.data.msg == 'resultingClientDestroyedAck') {
let { resultingDestroyedClientId } = e.data;
outerSwContainer.removeEventListener('message', resultingClientDestroyedAck);
resolve(resultingDestroyedClientId);
}
}
outerSwContainer.addEventListener('message', resultingClientDestroyedAck);
});
document.body.appendChild(iframe);
return p;
})
.then((resultingDestroyedClientId) => {
// query service worker for clients.get(resultingDestroyedClientId)
let channel = new MessageChannel();
let p = new Promise((resolve, reject) => {
function getIsResultingClientUndefined(e) {
if (e.data.msg == 'getIsResultingClientUndefined') {
let { isResultingClientUndefined } = e.data;
channel.port1.removeEventListener('message', getIsResultingClientUndefined);
resolve(isResultingClientUndefined);
}
}
channel.port1.onmessage = getIsResultingClientUndefined;
});
innerSw.postMessage(
{ port: channel.port2, msg: 'getIsResultingClientUndefined', resultingClientId: resultingDestroyedClientId },
[channel.port2],
);
return p;
})
.then((isResultingClientUndefined) => {
assert_true(isResultingClientUndefined, 'Clients.get(FetchEvent.resultingClientId) resolved with `undefined`');
});
}, 'Test unsuccessful Clients.get(FetchEvent.resultingClientId)');
function wait_for_clientId() { function wait_for_clientId() {
return new Promise(function(resolve, reject) { return new Promise(function(resolve, reject) {
function get_client_id(e) { window.onmessage = e => {
window.removeEventListener('message', get_client_id); resolve(e.data.clientId);
resolve(e.data.clientId); };
} });
window.addEventListener('message', get_client_id, false);
});
} }
var expected = [ promise_test(async t => {
// Register service worker.
const scope = 'resources/clients-get-frame.html';
const client_ids = [];
const registration = await service_worker_unregister_and_register(
t, 'resources/clients-get-worker.js', scope);
t.add_cleanup(() => registration.unregister());
await wait_for_state(t, registration.installing, 'activated');
// Prepare for test cases.
// Case 1: frame1 which is focused.
const frame1 = await with_iframe(scope + '#1');
t.add_cleanup(() => frame1.remove());
frame1.focus();
client_ids.push(await wait_for_clientId());
// Case 2: frame2 which is not focused.
const frame2 = await with_iframe(scope + '#2');
t.add_cleanup(() => frame2.remove());
client_ids.push(await wait_for_clientId());
// Case 3: invalid id.
client_ids.push('invalid-id');
// Call clients.get() for each id on the service worker.
const message_event = await new Promise(resolve => {
navigator.serviceWorker.onmessage = resolve;
registration.active.postMessage({clientIds: client_ids});
});
const expected = [
// visibilityState, focused, url, type, frameType // visibilityState, focused, url, type, frameType
['visible', true, normalizeURL(scope) + '#1', 'window', 'nested'], ['visible', true, normalizeURL(scope) + '#1', 'window', 'nested'],
['visible', false, normalizeURL(scope) + '#2', 'window', 'nested'], ['visible', false, normalizeURL(scope) + '#2', 'window', 'nested'],
undefined undefined
]; ];
assert_equals(message_event.data.length, 3);
assert_array_equals(message_event.data[0], expected[0]);
assert_array_equals(message_event.data[1], expected[1]);
assert_equals(message_event.data[2], expected[2]);
}, 'Test Clients.get()');
promise_test(async t => {
// Register service worker.
const scope = 'resources/simple.html';
const registration = await service_worker_unregister_and_register(
t, 'resources/clients-get-resultingClientId-worker.js', scope)
t.add_cleanup(() => registration.unregister());
await wait_for_state(t, registration.installing, 'activated');
const worker = registration.active;
// Load frame within the scope.
const frame = await with_iframe(scope);
t.add_cleanup(() => frame.remove());
frame.focus();
// Get resulting client id.
const resultingClientId = await new Promise(resolve => {
navigator.serviceWorker.onmessage = e => {
if (e.data.msg == 'getResultingClientId') {
resolve(e.data.resultingClientId);
}
};
worker.postMessage({msg: 'getResultingClientId'});
});
// Query service worker for clients.get(resultingClientId).
const isResultingClientUndefined = await new Promise(resolve => {
navigator.serviceWorker.onmessage = e => {
if (e.data.msg == 'getIsResultingClientUndefined') {
resolve(e.data.isResultingClientUndefined);
}
};
worker.postMessage({msg: 'getIsResultingClientUndefined',
resultingClientId});
});
assert_false(
isResultingClientUndefined,
'Clients.get(FetchEvent.resultingClientId) resolved with a Client');
}, 'Test successful Clients.get(FetchEvent.resultingClientId)');
promise_test(async t => {
// Register service worker.
const scope = 'resources/simple.html?fail';
const registration = await service_worker_unregister_and_register(
t, 'resources/clients-get-resultingClientId-worker.js', scope);
t.add_cleanup(() => registration.unregister());
await wait_for_state(t, registration.installing, 'activated');
// Load frame, and destroy it while loading.
const worker = registration.active;
let frame = document.createElement('iframe');
frame.src = scope;
t.add_cleanup(() => {
if (frame) {
frame.remove();
}
});
await new Promise(resolve => {
navigator.serviceWorker.onmessage = e => {
// The service worker posts a message to remove the iframe during fetch
// event.
if (e.data.msg == 'destroyResultingClient') {
frame.remove();
frame = null;
worker.postMessage({msg: 'resultingClientDestroyed'});
resolve();
}
};
document.body.appendChild(frame);
});
resultingDestroyedClientId = await new Promise(resolve => {
navigator.serviceWorker.onmessage = e => {
// The worker sends a message back when it receives the message
// 'resultingClientDestroyed' with the resultingClientId.
if (e.data.msg == 'resultingClientDestroyedAck') {
assert_equals(frame, null, 'Frame should be destroyed at this point.');
resolve(e.data.resultingDestroyedClientId);
}
};
});
// Query service worker for clients.get(resultingDestroyedClientId).
const isResultingClientUndefined = await new Promise(resolve => {
navigator.serviceWorker.onmessage = e => {
if (e.data.msg == 'getIsResultingClientUndefined') {
resolve(e.data.isResultingClientUndefined);
}
};
worker.postMessage({msg: 'getIsResultingClientUndefined',
resultingClientId: resultingDestroyedClientId });
});
assert_true(
isResultingClientUndefined,
'Clients.get(FetchEvent.resultingClientId) resolved with `undefined`');
}, 'Test unsuccessful Clients.get(FetchEvent.resultingClientId)');
</script> </script>
...@@ -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