Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(88)

Unified Diff: LayoutTests/http/tests/serviceworker/client-id.html

Issue 1209493002: Service Worker: Surface Client.id attribute. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: LayoutTests/http/tests/serviceworker/client-id.html
diff --git a/LayoutTests/http/tests/serviceworker/client-id.html b/LayoutTests/http/tests/serviceworker/client-id.html
new file mode 100644
index 0000000000000000000000000000000000000000..3e66867707758536aabc133b8f2bff059fcdb4ef
--- /dev/null
+++ b/LayoutTests/http/tests/serviceworker/client-id.html
@@ -0,0 +1,59 @@
+<!DOCTYPE html>
+<title>Service Worker: Client.id</title>
+<script src="../resources/testharness.js"></script>
+<script src="../resources/testharnessreport.js"></script>
+<script src="resources/test-helpers.js"></script>
+<script>
+var scope = 'resources/blank.html?client-id';
+var t = async_test('Test Client.id');
+var frame1, frame2;
+t.step(function() {
+ service_worker_unregister_and_register(
+ t, 'resources/client-id-worker.js', scope)
+ .then(function(registration) {
+ return wait_for_state(t, registration.installing, 'activated');
+ })
+ .then(function() { return with_iframe(scope + '#1'); })
+ .then(function(f) {
+ frame1 = f;
+ f.focus();
+ return with_iframe(scope + '#2');
+ })
+ .then(function(f) {
+ frame2 = f;
+ var channel = new MessageChannel();
+ channel.port1.onmessage = t.step_func(onMessage);
+ f.contentWindow.navigator.serviceWorker.controller.postMessage(
+ {port:channel.port2}, [channel.port2]);
+ })
+ .catch(unreached_rejection(t));
+ });
+
+// A regex object for UUID validation
kinuko 2015/06/25 02:23:04 nit: end comments with period. Also it might be ni
+var pattern = new RegExp (['^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0',
lgombos 2015/06/25 01:04:21 Not sure if this regexp is general enough. Does th
lgombos 2015/06/25 01:10:34 Sorry I missed the 'i' at the end, but why [1-5] i
jungkees 2015/06/25 01:51:36 According to RFC4122, that byte can hold the value
+ '-9a-f]{3}-[0-9a-f]{12}$'].join(''), 'i');
+function validateUUID(id) {
+ return id.match(pattern) ? true : false;
+}
+
+function onMessage(e) {
+ // The result of two sequential clients.matchAll() calls in the SW.
+ // 1st matchAll() results in e.data[0], e.data[1].
+ // 2nd matchAll() results in e.data[2], e.data[3].
+ assert_equals(e.data.length, 4);
+ // All should be valid UUIDs.
+ assert_true(validateUUID(e.data[0]));
+ assert_true(validateUUID(e.data[1]));
+ assert_true(validateUUID(e.data[2]));
+ assert_true(validateUUID(e.data[3]));
+ // Different clients should have different ids.
+ assert_not_equals(e.data[0], e.data[1]);
+ assert_not_equals(e.data[2], e.data[3]);
+ // Same clients should have an identical id.
+ assert_equals(e.data[0], e.data[2]);
+ assert_equals(e.data[1], e.data[3]);
+ frame1.remove();
+ frame2.remove();
+ service_worker_unregister_and_done(t, scope);
+}
+</script>
« no previous file with comments | « no previous file | LayoutTests/http/tests/serviceworker/clients-matchall.html » ('j') | Source/modules/serviceworkers/Client.idl » ('J')

Powered by Google App Engine
This is Rietveld 408576698