Index: third_party/WebKit/LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-reference.html |
diff --git a/third_party/WebKit/LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-reference.html b/third_party/WebKit/LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-reference.html |
index b1235fb99fb4eb600b4cb195d8fef256044d6017..7e86dc5f399378d115389a91877c5e35cc493f64 100644 |
--- a/third_party/WebKit/LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-reference.html |
+++ b/third_party/WebKit/LayoutTests/media/encrypted-media/encrypted-media-lifetime-mediakeysession-reference.html |
@@ -13,71 +13,57 @@ |
// OR (MediaKeys is around |
// AND the session has not received a close() event) |
- async_test(function(test) |
+ promise_test(function(test) |
{ |
- gc(); |
var mediaKeys; |
var mediaKeySession1; |
var mediaKeySession2; |
var mediaKeySession3; |
var initDataType; |
var initData; |
- var startingMediaKeysCount = window.internals.mediaKeysCount(); |
- var startingMediaKeySessionCount = window.internals.mediaKeySessionCount(); |
- function numMediaKeysCreated() |
- { |
- return window.internals.mediaKeysCount() - startingMediaKeysCount; |
- } |
+ // Even though there should be no existing objects, start by |
+ // running gc() and verifying that none exist. This also |
+ // allows the failures to be reported from inside a promise |
+ // so that the test fails properly. |
+ return createGCPromise().then(function() { |
+ verifyMediaKeyAndMediaKeySessionCount(0, 0, 'After initial gc()'); |
- function numMediaKeySessionCreated() |
- { |
- return window.internals.mediaKeySessionCount() - startingMediaKeySessionCount; |
- } |
- |
- navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()).then(function(access) { |
+ return navigator.requestMediaKeySystemAccess('org.w3.clearkey', getSimpleConfiguration()); |
+ }).then(function(access) { |
initDataType = access.getConfiguration().initDataTypes[0]; |
initData = getInitData(initDataType); |
return access.createMediaKeys(); |
}).then(function(result) { |
mediaKeys = result; |
assert_equals(typeof mediaKeys.createSession, 'function'); |
- |
- assert_equals(numMediaKeysCreated(), 1, 'MediaKeys.create()'); |
- assert_equals(numMediaKeySessionCreated(), 0, 'After final gc()'); |
+ verifyMediaKeyAndMediaKeySessionCount(1, 0, 'MediaKeys.create()'); |
// Create 3 sessions. |
mediaKeySession1 = mediaKeys.createSession(); |
return mediaKeySession1.generateRequest(initDataType, initData); |
}).then(function() { |
assert_true(mediaKeySession1.sessionId && mediaKeySession1.sessionId.length > 0); |
- |
- assert_equals(numMediaKeysCreated(), 1, 'MediaKeys.createSession(1)'); |
- assert_equals(numMediaKeySessionCreated(), 1, 'MediaKeys.createSession(1)'); |
+ verifyMediaKeyAndMediaKeySessionCount(1, 1, 'MediaKeys.createSession(1)'); |
mediaKeySession2 = mediaKeys.createSession(); |
return mediaKeySession2.generateRequest(initDataType, initData); |
}).then(function() { |
assert_true(mediaKeySession2.sessionId && mediaKeySession2.sessionId.length > 0); |
- |
- assert_equals(numMediaKeysCreated(), 1, 'mediaKeys.createSession(2)'); |
- assert_equals(numMediaKeySessionCreated(), 2, 'mediaKeys.createSession(2)'); |
+ verifyMediaKeyAndMediaKeySessionCount(1, 2, 'mediaKeys.createSession(2)'); |
mediaKeySession3 = mediaKeys.createSession(); |
return mediaKeySession3.generateRequest(initDataType, initData); |
}).then(function() { |
assert_true(mediaKeySession3.sessionId && mediaKeySession3.sessionId.length > 0); |
- |
- assert_equals(numMediaKeysCreated(), 1, 'mediaKeys.createSession(3)'); |
- assert_equals(numMediaKeySessionCreated(), 3, 'mediaKeys.createSession(3)'); |
+ verifyMediaKeyAndMediaKeySessionCount(1, 3, 'mediaKeys.createSession(3)'); |
// Run gc(). All sessions should remain as we have a |
// reference to each one. However, running gc() |
// asynchronously should free up the last PromiseResolver. |
return createGCPromise(); |
}).then(function(result) { |
- assert_equals(numMediaKeysCreated(), 1, 'After gc()'); |
- assert_equals(numMediaKeySessionCreated(), 3, 'After gc()'); |
+ verifyMediaKeyAndMediaKeySessionCount(1, 3, 'After gc()'); |
// Now drop references to 2 of the sessions. Even though we |
// don't have a reference, MediaKeys is still around (and |
@@ -89,8 +75,7 @@ |
}).then(function(result) { |
return createGCPromise(); |
}).then(function(result) { |
- assert_equals(numMediaKeysCreated(), 1, 'After second gc()'); |
- assert_equals(numMediaKeySessionCreated(), 3, 'After second gc()'); |
+ verifyMediaKeyAndMediaKeySessionCount(1, 3, 'After second gc()'); |
// Now drop the reference to MediaKeys. It and the 2 |
// unreferenced sessions should be collected. Since |
@@ -105,20 +90,14 @@ |
}).then(function(result) { |
return createGCPromise(); |
}).then(function(result) { |
- assert_equals(numMediaKeysCreated(), 0, 'After mediaKeys = null'); |
- assert_equals(numMediaKeySessionCreated(), 1, 'After mediaKeys = null'); |
+ verifyMediaKeyAndMediaKeySessionCount(0, 1, 'After mediaKeys = null'); |
// Drop the reference to the last session. It should get |
// collected now since MediaKeys is gone. |
mediaKeySession3 = null; |
return createGCPromise(); |
}).then(function(result) { |
- assert_equals(numMediaKeysCreated(), 0, 'After final gc()'); |
- assert_equals(numMediaKeySessionCreated(), 0, 'After final gc()'); |
- |
- test.done(); |
- }).catch(function(error) { |
- forceTestFailureFromPromise(test, error); |
+ verifyMediaKeyAndMediaKeySessionCount(0, 0, 'After final gc()'); |
}); |
}, 'MediaKeySession lifetime without release()'); |
</script> |