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

Side by Side Diff: LayoutTests/media/encrypted-media/encrypted-media-playback-setmediakeys-after-src.html

Issue 655603003: Reland: Remove "needkey" event and add its replacement, "encrypted". (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 6 years, 2 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
OLDNEW
1 <!DOCTYPE html> 1 <!DOCTYPE html>
2 <html> 2 <html>
3 <head> 3 <head>
4 <title>Clear Key Playback</title> 4 <title>Clear Key Playback</title>
5 <script src="encrypted-media-utils.js"></script> 5 <script src="encrypted-media-utils.js"></script>
6 <script src="../../resources/testharness.js"></script> 6 <script src="../../resources/testharness.js"></script>
7 <script src="../../resources/testharnessreport.js"></script> 7 <script src="../../resources/testharnessreport.js"></script>
8 </head> 8 </head>
9 <body> 9 <body>
10 <video id="testVideo"></video> 10 <video id="testVideo"></video>
11 <div id="log"></div> 11 <div id="log"></div>
12 <p>Test playback of encrypted media using Clear Key key system.</p> 12 <p>Test playback of encrypted media using Clear Key key system.</p>
13 <script> 13 <script>
14 async_test(function(test) 14 async_test(function(test)
15 { 15 {
16 var video = document.getElementById('testVideo'); 16 var video = document.getElementById('testVideo');
17 var isSessionCreated = false; 17 var isSessionCreated = false;
18 var isUpdatePromiseResolved = false; 18 var isUpdatePromiseResolved = false;
19 19
20 var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b, 20 var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
21 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]); 21 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
22 22
23 function onNeedKey(event) 23 function onEncrypted(event)
24 { 24 {
25 assert_equals(event.target, video); 25 assert_equals(event.target, video);
26 assert_true(event instanceof window.MediaKeyNeededEvent); 26 assert_true(event instanceof window.MediaEncryptedEvent);
27 assert_equals(event.type, 'needkey'); 27 assert_equals(event.type, 'encrypted');
28 28
29 // The same decryption key is shared by all streams so 29 // The same decryption key is shared by all streams so
30 // only create a shared session once. 30 // only create a shared session once.
31 if (isSessionCreated) 31 if (isSessionCreated)
32 return; 32 return;
33 isSessionCreated = true; 33 isSessionCreated = true;
34 34
35 var mediaKeySession = video.mediaKeys.createSession(); 35 var mediaKeySession = video.mediaKeys.createSession();
36 waitForEventAndRunStep('message', mediaKeySession, onMessage , test); 36 waitForEventAndRunStep('message', mediaKeySession, onMessage , test);
37 mediaKeySession.generateRequest(event.contentType, event.ini tData).catch(function(error) { 37 mediaKeySession.generateRequest(event.initDataType, event.in itData).catch(function(error) {
38 forceTestFailureFromPromise(test, error); 38 forceTestFailureFromPromise(test, error);
39 }); 39 });
40 } 40 }
41 41
42 function onMessage(event) 42 function onMessage(event)
43 { 43 {
44 assert_true(event instanceof window.MediaKeyMessageEvent); 44 assert_true(event instanceof window.MediaKeyMessageEvent);
45 assert_equals(event.type, 'message'); 45 assert_equals(event.type, 'message');
46 46
47 var keyId = extractSingleKeyIdFromMessage(event.message); 47 var keyId = extractSingleKeyIdFromMessage(event.message);
(...skipping 15 matching lines...) Expand all
63 function onTimeUpdate(event) 63 function onTimeUpdate(event)
64 { 64 {
65 if (event.target.currentTime < 0.2 || !isUpdatePromiseResolv ed) 65 if (event.target.currentTime < 0.2 || !isUpdatePromiseResolv ed)
66 return; 66 return;
67 67
68 test.done(); 68 test.done();
69 } 69 }
70 70
71 MediaKeys.create('org.w3.clearkey').then(function(mediaKeys) { 71 MediaKeys.create('org.w3.clearkey').then(function(mediaKeys) {
72 72
73 waitForEventAndRunStep('needkey', video, onNeedKey, test); 73 waitForEventAndRunStep('encrypted', video, onEncrypted, test );
74 waitForEventAndRunStep('playing', video, onPlaying, test); 74 waitForEventAndRunStep('playing', video, onPlaying, test);
75 75
76 video.src = '../content/test-encrypted.webm'; 76 video.src = '../content/test-encrypted.webm';
77 return video.setMediaKeys(mediaKeys); 77 return video.setMediaKeys(mediaKeys);
78 }).then(function(result) { 78 }).then(function(result) {
79 video.play(); 79 video.play();
80 }).catch(function(error) { 80 }).catch(function(error) {
81 forceTestFailureFromPromise(test, error); 81 forceTestFailureFromPromise(test, error);
82 }); 82 });
83 }, 'Playback using Clear Key key system, calling setMediaKeys() afte r setting src attribute.'); 83 }, 'Playback using Clear Key key system, calling setMediaKeys() afte r setting src attribute.');
84 </script> 84 </script>
85 </body> 85 </body>
86 </html> 86 </html>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698