Bug 1217367 - Add a wpt test that verified coalesced .update() calls resolve properly. r=bkelly

This commit is contained in:
dimi 2015-11-19 15:40:36 +08:00
parent 251af3768d
commit b11276e3a6
2 changed files with 98 additions and 0 deletions

View File

@ -290,6 +290,12 @@
"url": "/_mozilla/service-workers/service-worker/multiple-register.https.html"
}
],
"service-workers/service-worker/multiple-update.https.html": [
{
"path": "service-workers/service-worker/multiple-update.https.html",
"url": "/_mozilla/service-workers/service-worker/multiple-update.https.html"
}
],
"service-workers/service-worker/onactivate-script-error.https.html": [
{
"path": "service-workers/service-worker/onactivate-script-error.https.html",

View File

@ -0,0 +1,92 @@
<!DOCTYPE html>
<!-- In Bug 1217367, we will try to merge update events for same registration
if possible. This testcase is used to make sure the optimization algorithm
doesn't go wrong. -->
<title>Service Worker: Trigger multiple updates</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/test-helpers.sub.js"></script>
<script>
promise_test(function(t) {
var script = 'resources/update-nocookie-worker.py';
var scope = 'resources/scope/update';
var expected_url = normalizeURL(script);
var registration;
return service_worker_unregister_and_register(t, expected_url, scope)
.then(function(r) {
registration = r;
return wait_for_state(t, registration.installing, 'activated');
})
.then(function() {
// Test single update works before triggering multiple update events
return Promise.all([registration.update(),
wait_for_update(t, registration)]);
})
.then(function() {
assert_equals(registration.installing.scriptURL, expected_url,
'new installing should be set after update resolves.');
assert_equals(registration.waiting, null,
'waiting should still be null after update resolves.');
assert_equals(registration.active.scriptURL, expected_url,
'active should still exist after update found.');
return wait_for_state(t, registration.installing, 'installed');
})
.then(function() {
assert_equals(registration.installing, null,
'installing should be null after installing.');
if (registration.waiting) {
assert_equals(registration.waiting.scriptURL, expected_url,
'waiting should be set after installing.');
assert_equals(registration.active.scriptURL, expected_url,
'active should still exist after installing.');
return wait_for_state(t, registration.waiting, 'activated');
}
})
.then(function() {
// Test triggering multiple update events at the same time.
var promiseList = [];
const burstUpdateCount = 10;
for (var i = 0; i < burstUpdateCount; i++) {
promiseList.push(registration.update());
}
promiseList.push(wait_for_update(t, registration));
return Promise.all(promiseList);
})
.then(function() {
assert_equals(registration.installing.scriptURL, expected_url,
'new installing should be set after update resolves.');
assert_equals(registration.waiting, null,
'waiting should still be null after update resolves.');
assert_equals(registration.active.scriptURL, expected_url,
'active should still exist after update found.');
return wait_for_state(t, registration.installing, 'installed');
})
.then(function() {
assert_equals(registration.installing, null,
'installing should be null after installing.');
if (registration.waiting) {
assert_equals(registration.waiting.scriptURL, expected_url,
'waiting should be set after installing.');
assert_equals(registration.active.scriptURL, expected_url,
'active should still exist after installing.');
return wait_for_state(t, registration.waiting, 'activated');
}
})
.then(function() {
// Test update still works after handling update event burst.
return Promise.all([registration.update(),
wait_for_update(t, registration)]);
})
.then(function() {
assert_equals(registration.installing.scriptURL, expected_url,
'new installing should be set after update resolves.');
assert_equals(registration.waiting, null,
'waiting should be null after activated.');
assert_equals(registration.active.scriptURL, expected_url,
'active should still exist after update found.');
return service_worker_unregister_and_done(t, scope);
});
}, 'Trigger multiple updates.');
</script>