Index: LayoutTests/media/encrypted-media/encrypted-media-playback-multiple-sessions.html |
diff --git a/LayoutTests/media/encrypted-media/encrypted-media-playback-multiple-sessions.html b/LayoutTests/media/encrypted-media/encrypted-media-playback-multiple-sessions.html |
new file mode 100644 |
index 0000000000000000000000000000000000000000..beec54ed9b40e582b5513726111694e8e586bac2 |
--- /dev/null |
+++ b/LayoutTests/media/encrypted-media/encrypted-media-playback-multiple-sessions.html |
@@ -0,0 +1,121 @@ |
+<!DOCTYPE html> |
+<html> |
+ <head> |
+ <title>Clear Key Playback with Multiple Sessions</title> |
+ <script src="encrypted-media-utils.js"></script> |
+ <script src="../w3c-media-utils.js"></script> |
+ <script src="../../resources/testharness.js"></script> |
+ <script src="../../resources/testharnessreport.js"></script> |
+ </head> |
+ <body> |
+ <video id="testVideo"></video> |
+ <div id="log"></div> |
+ <p>Test playback of encrypted media using Clear Key key system with multiple sessions.</p> |
+ <script> |
+ async_test(function(test) |
+ { |
+ var video = document.getElementById("testVideo"); |
+ var mediaKeys = new MediaKeys("org.w3.clearkey"); |
+ var mediaKeyAudioSession = null; |
+ var mediaKeyVideoSession = null; |
xhwang
2014/03/19 01:22:00
nit: audioMediaKeySession/videoMediaKeySession ?
jrummell
2014/03/20 22:55:33
Done.
|
+ var audioSessionReadyReceived = false; |
+ var videoSessionReadyReceived = false; |
+ |
+ // The 2 streams use different key ids, but the keys are the |
+ // same. |
+ var audioKeyId = "0123456789"; |
+ var audioKey = new Uint8Array([0x7D, 0xE2, 0x6B, 0xE4, 0xD2, 0xC2, 0x2F, 0xD7, |
+ 0xD7, 0x7A, 0x1F, 0x4C, 0xA5, 0xA9, 0x97, 0x0F]); |
+ var videoKeyId = "0123456789012345"; |
+ var videoKey = audioKey; |
+ |
+ function onNeedKey(event) |
+ { |
+ assert_equals(event.target, video); |
+ assert_true(event instanceof window.MediaKeyNeededEvent); |
+ assert_equals(event.type, "needkey"); |
+ |
+ // Ideally we could just look at event.contentType, but it |
+ // is used to specify the encoding format, not the stream |
+ // (and both streams are webm). |
+ var keyId = String.fromCharCode.apply(null, event.initData); |
+ if (keyId == videoKeyId) { |
+ assert_equals(mediaKeyVideoSession, null); |
+ mediaKeyVideoSession = mediaKeys.createSession(event.contentType, event.initData); |
+ waitForEventAndRunStep("message", mediaKeyVideoSession, onVideoMessage, test); |
+ } else { |
+ assert_equals(keyId, audioKeyId); |
+ assert_equals(mediaKeyAudioSession, null); |
+ mediaKeyAudioSession = mediaKeys.createSession(event.contentType, event.initData); |
+ waitForEventAndRunStep("message", mediaKeyAudioSession, onAudioMessage, test); |
+ } |
+ } |
+ |
+ function onAudioMessage(event) |
+ { |
+ assert_true(event instanceof window.MediaKeyMessageEvent); |
+ assert_equals(event.target, mediaKeyAudioSession); |
+ assert_equals(event.type, "message"); |
+ |
+ var keyId = event.message; |
+ assert_equals(String.fromCharCode.apply(null, keyId), audioKeyId); |
+ var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, audioKey))); |
+ mediaKeyAudioSession.update(jwkSet); |
+ waitForEventAndRunStep("ready", mediaKeyAudioSession, onAudioReady, test); |
+ } |
+ |
+ function onVideoMessage(event) |
+ { |
+ assert_true(event instanceof window.MediaKeyMessageEvent); |
+ assert_equals(event.target, mediaKeyVideoSession); |
+ assert_equals(event.type, "message"); |
+ |
+ var keyId = event.message; |
+ assert_equals(String.fromCharCode.apply(null, keyId), videoKeyId); |
+ var jwkSet = stringToUint8Array(createJWKSet(createJWK(keyId, videoKey))); |
+ mediaKeyVideoSession.update(jwkSet); |
+ waitForEventAndRunStep("ready", mediaKeyVideoSession, onVideoReady, test); |
+ } |
xhwang
2014/03/19 01:22:00
It seems we can combine onAudioMessage and onVideo
jrummell
2014/03/20 22:55:33
It doesn't really save that much duplication (most
|
+ |
+ function onAudioReady(event) |
+ { |
+ assert_true(event instanceof window.Event); |
+ assert_equals(event.target, mediaKeyAudioSession); |
+ assert_equals(event.type, "ready"); |
+ audioSessionReadyReceived = true; |
+ } |
+ |
+ function onVideoReady(event) |
+ { |
+ assert_true(event instanceof window.Event); |
+ assert_equals(event.target, mediaKeyVideoSession); |
+ assert_equals(event.type, "ready"); |
+ videoSessionReadyReceived = true; |
+ } |
xhwang
2014/03/19 01:22:00
ditto for combining methods to reduce duplicate co
jrummell
2014/03/20 22:55:33
Done.
|
+ |
+ function onPlaying(event) |
+ { |
+ // Not using waitForEventAndRunStep() to avoid too many EVENT(onTimeUpdate) logs. |
+ video.addEventListener("timeupdate", onTimeUpdate, true); |
+ } |
+ |
+ function onTimeUpdate(event) |
+ { |
+ if (!audioSessionReadyReceived || !videoSessionReadyReceived) |
+ return; |
+ if (event.target.currentTime < 0.2) |
+ return; |
xhwang
2014/03/19 01:22:00
If audio key is provided but video key is not prov
jrummell
2014/03/20 22:55:33
If I change onVideoMessage() to do nothing, the Pl
|
+ |
+ test.done(); |
+ } |
+ |
+ waitForEventAndRunStep("needkey", video, onNeedKey, test); |
+ waitForEventAndRunStep("playing", video, onPlaying, test); |
+ |
+ video.src = "../content/test-encrypted-2-keys.webm"; |
xhwang
2014/03/19 01:22:00
This file is a bit confusing. It's called 2-keys b
jrummell
2014/03/20 22:55:33
Done.
|
+ video.setMediaKeys(mediaKeys); |
+ video.play(); |
+ }, "Playback using Clear Key key system with multiple sessions."); |
+ </script> |
+ </body> |
+</html> |