Commit aefdf3f3 authored by Staphany Park's avatar Staphany Park Committed by Commit Bot

Async Cookies: More service worker subscription tests.

Bug: 729800
Change-Id: Ie216054a92e223c29120226b645b2c10b208dde0
Reviewed-on: https://chromium-review.googlesource.com/1073080Reviewed-by: default avatarVictor Costan <pwnall@chromium.org>
Commit-Queue: Victor Costan <pwnall@chromium.org>
Cr-Commit-Position: refs/heads/master@{#569930}
parent 4ab25391
...@@ -796,6 +796,7 @@ Sooho Park <sooho1000@gmail.com> ...@@ -796,6 +796,7 @@ Sooho Park <sooho1000@gmail.com>
Soorya R <soorya.r@samsung.com> Soorya R <soorya.r@samsung.com>
Soren Dreijer <dreijerbit@gmail.com> Soren Dreijer <dreijerbit@gmail.com>
Srirama Chandra Sekhar Mogali <srirama.m@samsung.com> Srirama Chandra Sekhar Mogali <srirama.m@samsung.com>
Staphany Park <stapark008@gmail.com>
Stephen Searles <stephen.searles@gmail.com> Stephen Searles <stephen.searles@gmail.com>
Steve Sanders <steve@zanderz.com> Steve Sanders <steve@zanderz.com>
Steven Pennington <spenn@engr.uvic.ca> Steven Pennington <spenn@engr.uvic.ca>
......
...@@ -40,7 +40,7 @@ promise_test(async testCase => { ...@@ -40,7 +40,7 @@ promise_test(async testCase => {
promise_test(async testCase => { promise_test(async testCase => {
await kServiceWorkerActivatedPromise; await kServiceWorkerActivatedPromise;
cookie_change_received_promise = new Promise((resolve) => { const cookie_change_received_promise = new Promise((resolve) => {
self.addEventListener('cookiechange', (event) => { self.addEventListener('cookiechange', (event) => {
resolve(event); resolve(event);
}); });
......
self.GLOBAL = {
isWindow: function() { return false; },
isWorker: function() { return true; },
};
importScripts("/resources/testharness.js");
self.addEventListener('install', (event) => {
event.waitUntil((async () => {
cookieStore.subscribeToChanges([]);
})());
});
// Workaround because add_cleanup doesn't support async functions yet.
// See https://github.com/w3c/web-platform-tests/issues/6075
async function async_cleanup(cleanup_function) {
try {
await cleanup_function();
} catch (e) {
// Errors in cleanup functions shouldn't result in test failures.
}
}
// Resolves when the service worker receives the 'activate' event.
const kServiceWorkerActivatedPromise = new Promise(resolve => {
self.addEventListener('activate', event => { resolve(); });
});
promise_test(async testCase => {
await kServiceWorkerActivatedPromise;
const subscriptions = await cookieStore.getChangeSubscriptions();
assert_equals(subscriptions.length, 0);
}, 'getChangeSubscriptions returns an empty array when there are no subscriptions');
done();
<!doctype html>
<meta charset="utf-8">
<title>Async Cookies: ServiceWorker without cookie change subscriptions</title>
<link rel="help" href="https://github.com/WICG/cookie-store">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script>
'use strict';
(async () => {
const scope = 'scope';
let registration = await navigator.serviceWorker.getRegistration(scope);
if (registration)
await registration.unregister();
registration = await navigator.serviceWorker.register(
'serviceworker_cookieStore_subscriptions_empty.js', {scope});
fetch_tests_from_worker(registration.installing);
})();
</script>
self.GLOBAL = {
isWindow: function() { return false; },
isWorker: function() { return true; },
};
importScripts("/resources/testharness.js");
self.addEventListener('install', (event) => {
event.waitUntil((async () => {
cookieStore.subscribeToChanges([
{ name: 'cookie-name', matchType: 'equals', url: '/scope/path' }]);
})());
});
// Workaround because add_cleanup doesn't support async functions yet.
// See https://github.com/w3c/web-platform-tests/issues/6075
async function async_cleanup(cleanup_function) {
try {
await cleanup_function();
} catch (e) {
// Errors in cleanup functions shouldn't result in test failures.
}
}
// Resolves when the service worker receives the 'activate' event.
const kServiceWorkerActivatedPromise = new Promise(resolve => {
self.addEventListener('activate', event => { resolve(); });
});
promise_test(async testCase => {
await kServiceWorkerActivatedPromise;
const cookie_change_received_promise = new Promise((resolve) => {
self.addEventListener('cookiechange', (event) => {
resolve(event);
});
});
await cookieStore.set('another-cookie-name', 'cookie-value');
await cookieStore.set('cookie-name', 'cookie-value');
const event = await cookie_change_received_promise;
assert_equals(event.type, 'cookiechange');
assert_equals(event.changed.length, 1);
assert_equals(event.changed[0].name, 'cookie-name');
assert_equals(event.changed[0].value, 'cookie-value');
await async_cleanup(() => {
cookieStore.delete('another-cookie-name');
cookieStore.delete('cookie-name');
});
}, 'cookiechange not dispatched for change that does not match subscription');
done();
<!doctype html>
<meta charset="utf-8">
<title>Async Cookies: ServiceWorker cookiechange event filtering</title>
<link rel="help" href="https://github.com/WICG/cookie-store">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script>
'use strict';
(async () => {
const scope = 'scope';
let registration = await navigator.serviceWorker.getRegistration(scope);
if (registration)
await registration.unregister();
registration = await navigator.serviceWorker.register(
'serviceworker_cookieStore_subscriptions_mismatch.js', {scope});
fetch_tests_from_worker(registration.installing);
})();
</script>
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