Chromium Code Reviews| Index: LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-release.html |
| diff --git a/LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-release.html b/LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-release.html |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..84daaa4de6c3ffed3dfcea03447983ba038c32be |
| --- /dev/null |
| +++ b/LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-release.html |
| @@ -0,0 +1,76 @@ |
| +<!DOCTYPE html> |
| +<html> |
| + <head> |
| + <title>Test MediaKeySession lifetime</title> |
| + <script src="../w3c-media-utils.js"></script> |
| + <script src="../../resources/testharness.js"></script> |
| + <script src="../../resources/testharnessreport.js"></script> |
| + <script src="../../resources/gc.js"></script> |
| + </head> |
| + <body> |
| + <div id="log"></div> |
| + <script> |
| + setup({ timeout: 60000 }); // Timeout for all tests to run. |
| + |
| + // Since MediaKeySession (but not MediaKeys) are ActiveDOMObjects, |
| + // we can determine when they are garbage collected. |
| + // MediaKeySessions remain as long as: |
| + // JavaScript has a reference to it |
| + // OR (MediaKeys is around AND the session has not received a close() event) |
| + async_test(function(test) |
| + { |
| + var startingActiveDOMObjectCount = window.internals.activeDOMObjectCount(document); |
| + |
| + function numActiveDOMObjectsCreated() |
| + { |
| + return window.internals.activeDOMObjectCount(document) - startingActiveDOMObjectCount; |
| + } |
| + |
| + var mediaKeys = new MediaKeys("org.w3.clearkey"); |
| + var mediaKeySession1 = null; |
| + var mediaKeySession2 = null; |
| + var sessionsCreated = 0; |
| + |
| + function onClose(event) |
| + { |
| + --sessionsCreated; |
| + if (sessionsCreated > 0) |
| + return; |
| + |
| + // Delay to give time for close to complete since |
| + // event.target is a reference to the MediaKeySession. |
|
xhwang
2014/03/27 00:46:40
So really it's used so that finish() is called asy
jrummell
2014/03/27 01:22:23
Done. If we get flakiness on ASAN tests, I'll know
xhwang
2014/03/27 17:07:00
:) well, then at least we know something isn't wor
|
| + setTimeout(finish, 250); |
| + } |
| + |
| + function finish() |
| + { |
| + // Since both sessions have been released, dropping the |
| + // reference to them from JS will result in the session |
| + // being garbage-collected. |
| + consoleWrite("Finish"); |
| + assert_not_equals(mediaKeys, null); |
| + assert_equals(numActiveDOMObjectsCreated(), 2); |
| + |
| + mediaKeySession1 = null; |
| + gc(); |
| + assert_equals(numActiveDOMObjectsCreated(), 1, "mediaKeySession1 not collected"); |
| + |
| + mediaKeySession2 = null; |
| + gc(); |
| + assert_equals(numActiveDOMObjectsCreated(), 0, "mediaKeySession2 not collected"); |
| + |
| + test.done(); |
| + } |
| + |
| + // Create 2 sessions. |
| + mediaKeySession1 = mediaKeys.createSession('video/webm', new Uint8Array([1, 2, 3])); |
| + mediaKeySession1.release(); |
| + waitForEventAndRunStep("close", mediaKeySession1, onClose, test); |
| + mediaKeySession2 = mediaKeys.createSession('video/webm', new Uint8Array([4, 5])); |
| + mediaKeySession2.release(); |
| + waitForEventAndRunStep("close", mediaKeySession2, onClose, test); |
|
xhwang
2014/03/27 00:46:40
Can we move these up to replace l.30-31 to be cons
jrummell
2014/03/27 01:22:23
Done.
|
| + sessionsCreated = 2; |
| + }, "MediaKeySession lifetime after release()", { timeout: 60000 }); |
| + </script> |
| + </body> |
| +</html> |