| OLD | NEW |
| 1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
| 2 <title>Service Worker: registration end-to-end</title> | 2 <title>Service Worker: registration end-to-end</title> |
| 3 <script src="../resources/testharness.js"></script> | 3 <script src="../resources/testharness.js"></script> |
| 4 <script src="../resources/testharnessreport.js"></script> | 4 <script src="../resources/testharnessreport.js"></script> |
| 5 <script src="resources/test-helpers.js"></script> | 5 <script src="resources/test-helpers.js"></script> |
| 6 <script> | 6 <script> |
| 7 var t = async_test('Registration: end-to-end'); | 7 var t = async_test('Registration: end-to-end'); |
| 8 t.step(function() { | 8 t.step(function() { |
| 9 | 9 |
| 10 var scope = '/in-scope/*'; | 10 var scope = '/in-scope/*'; |
| 11 var serviceWorkerStates = []; | 11 var serviceWorkerStates = []; |
| 12 var lastServiceWorkerState = ''; | 12 var lastServiceWorkerState = ''; |
| 13 var receivedMessageFromPort = ''; | 13 var receivedMessageFromPort = ''; |
| 14 var currentChangeCount = 0; | 14 var currentChangeCount = 0; |
| 15 | 15 |
| 16 assert_true(navigator.serviceWorker instanceof ServiceWorkerContainer); | 16 assert_true(navigator.serviceWorker instanceof ServiceWorkerContainer); |
| 17 assert_equals(typeof navigator.serviceWorker.register, 'function'); | 17 assert_equals(typeof navigator.serviceWorker.register, 'function'); |
| 18 assert_equals(typeof navigator.serviceWorker.unregister, 'function'); | 18 assert_equals(typeof navigator.serviceWorker.unregister, 'function'); |
| 19 | 19 |
| 20 navigator.serviceWorker.oncurrentchange = function() { | 20 navigator.serviceWorker.oncurrentchange = function() { |
| 21 ++currentChangeCount; | 21 ++currentChangeCount; |
| 22 }; | 22 }; |
| 23 | 23 |
| 24 service_worker_unregister_and_register( | 24 service_worker_unregister_and_register( |
| 25 t, 'resources/end-to-end-worker.js', scope, onRegister); | 25 t, 'resources/end-to-end-worker.js', scope).then(t.step_func(onRegister)
); |
| 26 | 26 |
| 27 function sendMessagePort(worker, from) { | 27 function sendMessagePort(worker, from) { |
| 28 var messageChannel = new MessageChannel(); | 28 var messageChannel = new MessageChannel(); |
| 29 worker.postMessage({from:from, port:messageChannel.port2}, [messageChann
el.port2]); | 29 worker.postMessage({from:from, port:messageChannel.port2}, [messageChann
el.port2]); |
| 30 return messageChannel.port1; | 30 return messageChannel.port1; |
| 31 } | 31 } |
| 32 | 32 |
| 33 | 33 |
| 34 var sawMessage, sawActive; | 34 var sawMessage, sawActive; |
| 35 var messagePromise = new Promise(function(resolve) { sawMessage = resolve; }
); | 35 var messagePromise = new Promise(function(resolve) { sawMessage = resolve; }
); |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 81 assert_equals(currentChangeCount, 0, | 81 assert_equals(currentChangeCount, 0, |
| 82 'Should not see current changes since document is out
of scope'); | 82 'Should not see current changes since document is out
of scope'); |
| 83 | 83 |
| 84 assert_equals(receivedMessageFromPort, 'Ack for: registering doc'); | 84 assert_equals(receivedMessageFromPort, 'Ack for: registering doc'); |
| 85 | 85 |
| 86 service_worker_unregister_and_done(t, scope); | 86 service_worker_unregister_and_done(t, scope); |
| 87 })); | 87 })); |
| 88 } | 88 } |
| 89 }); | 89 }); |
| 90 </script> | 90 </script> |
| OLD | NEW |