| Index: third_party/WebKit/LayoutTests/http/tests/serviceworker/clients-get-client-types.html
|
| diff --git a/third_party/WebKit/LayoutTests/http/tests/serviceworker/clients-get.html b/third_party/WebKit/LayoutTests/http/tests/serviceworker/clients-get-client-types.html
|
| similarity index 62%
|
| copy from third_party/WebKit/LayoutTests/http/tests/serviceworker/clients-get.html
|
| copy to third_party/WebKit/LayoutTests/http/tests/serviceworker/clients-get-client-types.html
|
| index 67110c90b794ac41b11349d3ed69140683f22001..75f54ebe194f344b5c8d9d396249810e862c0262 100644
|
| --- a/third_party/WebKit/LayoutTests/http/tests/serviceworker/clients-get.html
|
| +++ b/third_party/WebKit/LayoutTests/http/tests/serviceworker/clients-get-client-types.html
|
| @@ -1,11 +1,12 @@
|
| <!DOCTYPE html>
|
| -<title>Service Worker: Clients.get</title>
|
| +<title>Service Worker: Clients.get with window and worker clients</title>
|
| <script src="../resources/testharness.js"></script>
|
| <script src="../resources/testharnessreport.js"></script>
|
| -<script src="../resources/get-host-info.js"></script>
|
| <script src="resources/test-helpers.js"></script>
|
| <script>
|
| -var scope = 'resources/clients-get-frame.html';
|
| +var scope = 'resources/clients-get-client-types';
|
| +var frame_url = scope + '-frame.html';
|
| +var shared_worker_url = scope + '-shared-worker.js';
|
| var client_ids = [];
|
| var frame;
|
| promise_test(function(t) {
|
| @@ -16,24 +17,25 @@ promise_test(function(t) {
|
| return wait_for_state(t, registration.installing, 'activated');
|
| })
|
| .then(function() {
|
| - return with_iframe(scope + '#1');
|
| + return with_iframe(frame_url);
|
| })
|
| - .then(function(frame1) {
|
| - add_completion_callback(function() { frame1.remove(); });
|
| - frame1.focus();
|
| + .then(function(f) {
|
| + frame = f;
|
| + add_completion_callback(function() { frame.remove(); });
|
| + frame.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();
|
| + return new Promise(function(resolve) {
|
| + var w = new SharedWorker(shared_worker_url);
|
| + w.port.onmessage = function(e) {
|
| + resolve(e.data.clientId);
|
| + };
|
| + });
|
| })
|
| .then(function(client_id) {
|
| - client_ids.push(client_id, 'invalid-id');
|
| + client_ids.push(client_id);
|
| var channel = new MessageChannel();
|
| var saw_message = new Promise(function(resolve) {
|
| channel.port1.onmessage = resolve;
|
| @@ -43,15 +45,14 @@ promise_test(function(t) {
|
| return saw_message;
|
| })
|
| .then(function(e) {
|
| - assert_equals(e.data.length, 3);
|
| + assert_equals(e.data.length, 2);
|
| 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()');
|
| + }, 'Test Clients.get() with window and worker clients');
|
|
|
| function wait_for_clientId() {
|
| - return new Promise(function(resolve, reject) {
|
| + return new Promise(function(resolve) {
|
| function get_client_id(e) {
|
| window.removeEventListener('message', get_client_id);
|
| resolve(e.data.clientId);
|
| @@ -62,8 +63,7 @@ function wait_for_clientId() {
|
|
|
| var expected = [
|
| /* visibilityState, focused, url, frameType */
|
| - ['visible', true, normalizeURL(scope) + '#1', 'nested'],
|
| - ['visible', false, normalizeURL(scope) + '#2', 'nested'],
|
| - undefined
|
| + ['visible', true, normalizeURL(scope) + '-frame.html', 'nested'],
|
| + [,,normalizeURL(scope) + '-shared-worker.js', 'none']
|
| ];
|
| </script>
|
|
|