Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 <!DOCTYPE html> | |
| 2 <title>Tests that postMessage works during and after terminating a service worke r</title> | |
| 3 <script src="../../resources/testharness.js"></script> | |
| 4 <script src="../../resources/testharnessreport.js"></script> | |
| 5 <script src="../../resources/testharness-helpers.js"></script> | |
| 6 <script src="../resources/test-helpers.js"></script> | |
| 7 <script> | |
| 8 var properties = {timeout: 2500}; | |
| 9 | |
| 10 function sendPing(worker) { | |
| 11 return new Promise(function(resolve) { | |
| 12 var channel = new MessageChannel(); | |
|
dominicc (has gone to gerrit)
2014/11/17 02:25:26
Could you indent this slightly differently, follow
Marijn Kruisselbrink
2014/11/17 23:18:44
Done (at least I think so).
| |
| 13 channel.port1.onmessage = function(message) { | |
| 14 resolve(message.data); | |
| 15 }; | |
| 16 worker.postMessage({port: channel.port2}, [channel.port2]); | |
| 17 }); | |
| 18 } | |
| 19 | |
| 20 function delay(ms) { | |
| 21 return new Promise(function(resolve) { | |
| 22 window.setTimeout(resolve, ms); | |
| 23 }); | |
| 24 } | |
| 25 | |
| 26 promise_test(function(test) { | |
| 27 var worker = 'resources/ping-worker.js'; | |
| 28 var scope = 'resources/blank.html'; | |
| 29 var sw; | |
| 30 return service_worker_unregister_and_register(test, worker, scope) | |
| 31 .then(function(registration) { | |
| 32 return wait_for_update(test, registration); | |
| 33 }).then(function(worker) { | |
| 34 sw = worker; | |
| 35 return sendPing(sw); | |
| 36 }).then(function(reply) { | |
| 37 assert_equals(reply, 1); | |
| 38 return internals.terminateServiceWorker(sw); | |
|
dominicc (has gone to gerrit)
2014/11/17 02:25:25
What if the Service Worker terminated itself, perh
Marijn Kruisselbrink
2014/11/17 23:18:44
I suppose I could change the test to have the work
| |
| 39 }).then(function() { | |
| 40 //return delay(500); | |
|
Marijn Kruisselbrink
2014/11/04 23:11:54
This test currently only passes when this delay is
dominicc (has gone to gerrit)
2014/11/17 02:25:25
Let's not add a test that is known to be broken. O
Marijn Kruisselbrink
2014/11/17 23:18:44
Well, the test is not broken, it just doesn't curr
| |
| 41 }).then(function() { | |
| 42 return sendPing(sw); | |
| 43 }).then(function(reply) { | |
| 44 assert_equals(reply, 1); | |
| 45 return sendPing(sw); | |
|
dominicc (has gone to gerrit)
2014/11/17 02:25:25
Are two subsequent pings necessary?
Marijn Kruisselbrink
2014/11/17 23:18:44
Not really, just a simple sanity check to make sur
| |
| 46 }).then(function(reply) { | |
| 47 assert_equals(reply, 2); | |
| 48 return service_worker_unregister_and_done(test, scope); | |
| 49 }); | |
| 50 }, 'Terminate terminates the worker.', properties); | |
|
dominicc (has gone to gerrit)
2014/11/17 02:25:25
Is the test really about that? It's about postMess
Marijn Kruisselbrink
2014/11/17 23:18:44
Well, it's more about both. I started writing this
| |
| 51 | |
| 52 </script> | |
| OLD | NEW |