Chromium Code Reviews| Index: LayoutTests/http/tests/serviceworker/clients-matchall.html |
| diff --git a/LayoutTests/http/tests/serviceworker/clients-matchall.html b/LayoutTests/http/tests/serviceworker/clients-matchall.html |
| index b76e6482902d04fa7ad00ca38fcd8a808783d556..bab3e5815ca44086525cc60a9837e15abc40f7d9 100644 |
| --- a/LayoutTests/http/tests/serviceworker/clients-matchall.html |
| +++ b/LayoutTests/http/tests/serviceworker/clients-matchall.html |
| @@ -5,42 +5,58 @@ |
| <script src="resources/test-helpers.js"></script> |
| <script> |
| var scope = 'resources/blank.html?clients-matchAll'; |
| -var t = async_test('Test Clients.matchAll()'); |
| +var expectedFirst = [ |
| + /* visibilityState, focused, url, frameType */ |
| + ['visible', true, new URL(scope + '#1', location).toString(), 'nested'], |
| + ['visible', false, new URL(scope + '#2', location).toString(), 'nested'] |
| +]; |
| +var expectedSecond = [ |
| + /* visibilityState, focused, url, frameType */ |
| + ['visible', true, new URL(scope + '#2', location).toString(), 'nested'], |
| + ['visible', false, new URL(scope + '#1', location).toString(), 'nested'] |
| +]; |
| + |
| var frame1, frame2; |
| -t.step(function() { |
| - service_worker_unregister_and_register( |
| +var worker; |
| +promise_test(function(t) { |
| + return service_worker_unregister_and_register( |
| t, 'resources/clients-matchall-worker.js', scope) |
| .then(function(registration) { |
| - return wait_for_state(t, registration.installing, 'activated'); |
| + worker = registration.installing; |
| + return wait_for_state(t, worker, '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]); |
| + return new Promise(function(resolve) { |
| + frame2 = f; |
|
nhiroki
2015/08/19 09:09:45
nit: Can you move this line to line 33?
|
| + frame1.focus(); |
| + var channel = new MessageChannel(); |
| + channel.port1.onmessage = resolve; |
| + worker.postMessage({port:channel.port2}, [channel.port2]); |
| + }); |
| }) |
| - .catch(unreached_rejection(t)); |
| - }); |
| - |
| -var expected = [ |
| - /* visibilityState, focused, url, frameType */ |
| - ['visible', true, new URL(scope + '#1', location).toString(), 'nested'], |
| - ['visible', false, new URL(scope + '#2', location).toString(), 'nested'] |
| -]; |
| - |
| -function onMessage(e) { |
| - assert_equals(e.data.length, 2); |
| - assert_array_equals(e.data[0], expected[0]); |
| - assert_array_equals(e.data[1], expected[1]); |
| - frame1.remove(); |
| - frame2.remove(); |
| - service_worker_unregister_and_done(t, scope); |
| -} |
| + .then(function(message) { |
| + return new Promise(function(resolve) { |
| + assert_equals(message.data.length, 2); |
| + assert_array_equals(message.data[0], expectedFirst[0]); |
| + assert_array_equals(message.data[1], expectedFirst[1]); |
|
nhiroki
2015/08/19 09:09:45
nit: How about moving these assertions to line 43?
|
| + frame2.focus(); |
| + var channel = new MessageChannel(); |
| + channel.port1.onmessage = resolve; |
| + worker.postMessage({port:channel.port2}, [channel.port2]); |
| + }); |
| + }) |
| + .then(function(message) { |
| + assert_equals(message.data.length, 2); |
| + assert_array_equals(message.data[0], expectedSecond[0]); |
| + assert_array_equals(message.data[1], expectedSecond[1]); |
| + frame1.remove(); |
| + frame2.remove(); |
| + return service_worker_unregister_and_done(t, scope); |
| + }) |
| + }, 'Test Clients.matchAll()'); |
| </script> |