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

Side by Side Diff: LayoutTests/http/tests/serviceworker/service-worker-gc.html

Issue 330173003: Make ServiceWorker an ActiveDOMObject (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: fix hasPendingActivity Created 6 years, 6 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 <!DOCTYPE html>
2 <script src="../resources/testharness.js"></script>
dominicc (has gone to gerrit) 2014/06/12 22:23:38 This should use the Blink test harness. GC is an i
falken 2014/06/13 19:22:59 Done.
3 <script src="../resources/testharnessreport.js"></script>
4 <script src="resources/test-helpers.js"></script>
5 <script src="resources/gc.js"></script>
6 <body>
7 <script>
8 (function() {
9 var t = async_test('A registered Service Worker with an event handler is not garbage collected');
dominicc (has gone to gerrit) 2014/06/12 22:23:38 FYI I have started doing async_test(function(t) {
10 var worker = 'resources/empty-worker.js'
11 var scope = 'gc';
12 var swObservation = null;
13 service_worker_unregister_and_register(t, worker, scope, onRegister);
14
15 function collectGarbage(shouldBeCollected, description) {
16 gc();
17 if (swObservation)
18 assert_equals(swObservation.wasCollected, shouldBeCollected, descrip tion);
19 }
20
21 function onUnregister() {
22 // FIXME: The expectation should be reversed, but our implementation cur rently fails it.
dominicc (has gone to gerrit) 2014/06/12 22:23:38 I think you want to rephrase this as a "leak test"
falken 2014/06/13 19:22:59 OK, the idea being that the test would succeed on
23 // When properly implemented, the SW should be garbage collected here.
24 t.step(collectGarbage.bind(undefined, false, 'Service Worker should be g c\'d after unregistration'));
25 t.done();
26 }
27
28 function onRegister(sw) {
dominicc (has gone to gerrit) 2014/06/12 22:23:38 FYI I am moving to using promises instead of callb
falken 2014/06/13 19:22:59 Done. Yes, I think that's a good idea. Our test-he
29 sw.addEventListener('statechange', t.step_func(onStateChange));
30 if (window.internals)
31 swObservation = internals.observeGC(sw);
32 setTimeout(t.step_func(collectGarbage.bind(undefined, false, 'Service Wo rker should not be gc\'d after registration')), 0);
33 }
34
35 function onStateChange(event) {
36 t.step(collectGarbage.bind(undefined, false, 'Service Worker should not be gc\'d inside onStateChange handler'));
37 if (event.target.state != 'active')
38 return;
39 navigator.serviceWorker.unregister(scope).then(t.step_func(onUnregister) );
40 }
41 }());
42 </script>
43 </body>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698