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> |