Index: LayoutTests/http/tests/serviceworker/postmessage-msgport-to-client.html |
diff --git a/LayoutTests/http/tests/serviceworker/postmessage-msgport-to-client.html b/LayoutTests/http/tests/serviceworker/postmessage-msgport-to-client.html |
index 0f2fd5a3706a7812bec20a8a964f6f3bd7f3e8bb..690c877299aafdd429e24ffe27517d5b8d5cea5e 100644 |
--- a/LayoutTests/http/tests/serviceworker/postmessage-msgport-to-client.html |
+++ b/LayoutTests/http/tests/serviceworker/postmessage-msgport-to-client.html |
@@ -4,26 +4,23 @@ |
<script src="../resources/testharnessreport.js"></script> |
<script src="resources/test-helpers.js"></script> |
<script> |
-var t = async_test('postMessage MessagePorts from ServiceWorker to Client'); |
-t.step(function() { |
- var scope = 'resources/blank.html' |
+async_test(function(t) { |
+ var scope = 'resources/blank.html'; |
service_worker_unregister_and_register( |
- t, 'resources/postmessage-msgport-to-client-worker.js', scope).then(t.step_func(onRegister)); |
- |
- function onRegister(worker) { |
- worker.addEventListener('statechange', t.step_func(function(event) { |
- if (event.target.state == 'activated') |
- onActive(); |
- })); |
- } |
- |
- function onActive() { |
- with_iframe(scope, t.step_func(function(frame) { |
- var w = frame.contentWindow; |
- w.onmessage = t.step_func(onMessage); |
- w.navigator.serviceWorker.controller.postMessage('ping'); |
- })); |
- } |
+ t, 'resources/postmessage-msgport-to-client-worker.js', scope) |
+ .then(function(registration) { |
+ return wait_for_update(t, registration); |
+ }) |
+ .then(function(sw) { |
+ return wait_for_state(t, sw, 'activated'); |
+ }) |
+ .then(function() { return with_iframe(scope); }) |
+ .then(function(frame) { |
+ var w = frame.contentWindow; |
+ w.onmessage = t.step_func(onMessage); |
+ w.navigator.serviceWorker.controller.postMessage('ping'); |
+ }) |
+ .catch(unreached_rejection(t)); |
var result = []; |
var expected = [ |
@@ -32,20 +29,22 @@ t.step(function() { |
]; |
function onMessage(e) { |
- var message = e.data; |
- if ('port' in message) { |
- var port = message.port; |
- port.postMessage({value: 1}); |
- port.postMessage({value: 2}); |
- port.postMessage({done: true}); |
- } else if ('ack' in message) { |
- result.push(message.ack); |
- } else if ('done' in message) { |
- assert_array_equals(result, expected, 'Worker should post back expected values via MessagePort.'); |
- service_worker_unregister_and_done(t, scope); |
- } else { |
- assert_unreached('Got unexpected message from ServiceWorker'); |
- } |
+ var message = e.data; |
+ if ('port' in message) { |
+ var port = message.port; |
+ port.postMessage({value: 1}); |
+ port.postMessage({value: 2}); |
+ port.postMessage({done: true}); |
+ } else if ('ack' in message) { |
+ result.push(message.ack); |
+ } else if ('done' in message) { |
+ assert_array_equals( |
+ result, expected, |
+ 'Worker should post back expected values via MessagePort.'); |
+ service_worker_unregister_and_done(t, scope); |
+ } else { |
+ assert_unreached('Got unexpected message from ServiceWorker'); |
+ } |
} |
-}); |
+ }, 'postMessage MessagePorts from ServiceWorker to Client'); |
</script> |