Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(251)

Side by Side Diff: LayoutTests/http/tests/serviceworker/multiple-register.html

Issue 1311103002: ServiceWorker: Make APIs that return ServiceWorkerRegistration coin a new JS object (3/3) (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 <!DOCTYPE html> 1 <!DOCTYPE html>
2 <script src="../resources/testharness.js"></script> 2 <script src="../resources/testharness.js"></script>
3 <script src="../resources/testharnessreport.js"></script> 3 <script src="../resources/testharnessreport.js"></script>
4 <script src="resources/test-helpers.js"></script> 4 <script src="resources/test-helpers.js"></script>
5 <script> 5 <script>
6 var worker_url = 'resources/empty-worker.js'; 6 var worker_url = 'resources/empty-worker.js';
7 7
8 async_test(function(t) { 8 async_test(function(t) {
9 var scope = 'resources/scope/subsequent-register-from-same-window'; 9 var scope = 'resources/scope/subsequent-register-from-same-window';
10 var registration; 10 var registration;
11 11
12 service_worker_unregister_and_register(t, worker_url, scope) 12 service_worker_unregister_and_register(t, worker_url, scope)
13 .then(function(r) { 13 .then(function(r) {
14 registration = r; 14 registration = r;
15 return wait_for_state(t, r.installing, 'activated'); 15 return wait_for_state(t, r.installing, 'activated');
16 }) 16 })
17 .then(function() { 17 .then(function() {
18 return navigator.serviceWorker.register(worker_url, { scope: scope }); 18 return navigator.serviceWorker.register(worker_url, { scope: scope });
19 }) 19 })
20 .then(function(new_registration) { 20 .then(function(new_registration) {
21 assert_equals(new_registration, registration, 21 assert_registration_equals(new_registration, registration);
22 'register should resolve to the same registration'); 22 assert_not_equals(
23 new_registration, registration,
24 'register should resolve to the new registration object');
falken 2015/08/25 03:28:29 (sorry for grammar nit) "the new" -> "a new" "the
nhiroki 2015/08/25 06:28:07 Thanks! Grammar correction is really helpful :)
23 assert_equals(new_registration.active, registration.active, 25 assert_equals(new_registration.active, registration.active,
24 'register should resolve to the same worker'); 26 'register should resolve to the same worker');
25 assert_equals(new_registration.active.state, 'activated', 27 assert_equals(new_registration.active.state, 'activated',
26 'the worker should be in state "activated"'); 28 'the worker should be in state "activated"');
27 return registration.unregister(); 29 return registration.unregister();
28 }) 30 })
29 .then(function() { t.done(); }) 31 .then(function() { t.done(); })
30 .catch(unreached_rejection(t)); 32 .catch(unreached_rejection(t));
31 }, 'Subsequent registrations resolve to the same registration object'); 33 }, 'Subsequent registrations resolve to the different registration object ' +
34 'but they refer to the same registration and workers');
32 35
33 async_test(function(t) { 36 async_test(function(t) {
34 var scope = 'resources/scope/subsequent-register-from-different-iframe'; 37 var scope = 'resources/scope/subsequent-register-from-different-iframe';
35 var frame; 38 var frame;
36 var registration; 39 var registration;
37 40
38 service_worker_unregister_and_register(t, worker_url, scope) 41 service_worker_unregister_and_register(t, worker_url, scope)
39 .then(function(r) { 42 .then(function(r) {
40 registration = r; 43 registration = r;
41 return wait_for_state(t, r.installing, 'activated'); 44 return wait_for_state(t, r.installing, 'activated');
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after
94 service_worker_unregister(t, scope) 97 service_worker_unregister(t, scope)
95 .then(function() { 98 .then(function() {
96 var promises = []; 99 var promises = [];
97 for (var i = 0; i < 10; ++i) { 100 for (var i = 0; i < 10; ++i) {
98 promises.push(navigator.serviceWorker.register(worker_url, 101 promises.push(navigator.serviceWorker.register(worker_url,
99 { scope: scope })); 102 { scope: scope }));
100 } 103 }
101 return Promise.all(promises); 104 return Promise.all(promises);
102 }) 105 })
103 .then(function(registrations) { 106 .then(function(registrations) {
107 for (var i = 1; i < 10; ++i) {
falken 2015/08/25 03:28:29 can you make 10 a named variable?
nhiroki 2015/08/25 06:28:07 Done.
108 assert_registration_equals(registrations[i], registrations[0]);
109 assert_not_equals(
110 registrations[i], registrations[0],
111 'register should resolve to the new registration object');
112 }
104 registrations.forEach(function(registration) { 113 registrations.forEach(function(registration) {
105 assert_equals(registration, registrations[0],
106 'register should resolve to the same registration');
107 }); 114 });
108 return registrations[0].unregister(); 115 return registrations[0].unregister();
109 }) 116 })
110 .then(function() { t.done(); }) 117 .then(function() { t.done(); })
111 .catch(unreached_rejection(t)); 118 .catch(unreached_rejection(t));
112 }, 'Concurrent registrations resolve to the same registration object'); 119 }, 'Concurrent registrations resolve to the different registration object ' +
120 'but they refer to the same registration and workers');
113 121
114 </script> 122 </script>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698