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

Side by Side Diff: LayoutTests/media/encrypted-media/encrypted-media-waiting-for-a-key.html

Issue 634243005: Improve reliability of EME tests (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>Waiting for a key.</title> 4 <title>Waiting for a key.</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 <script> 12 <script>
13 async_test(function(test) 13 async_test(function(test)
14 { 14 {
15 var video = document.getElementById('testVideo'); 15 var video = document.getElementById('testVideo');
16 var mediaKeySession = null; 16 var mediaKeySession = null;
17 var sessionCreated = false;
18 var sessionReadyReceived = false; 17 var sessionReadyReceived = false;
18 var encryptedEventCount = 0;
19 19
20 var keyId = null; 20 var keyId = null;
21 var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b, 21 var rawKey = new Uint8Array([0xeb, 0xdd, 0x62, 0xf1, 0x68, 0x14, 0xd2, 0x7b,
22 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]); 22 0x68, 0xef, 0x12, 0x2a, 0xfc, 0xe4, 0xae, 0x3c]);
23 23
24 function onEncrypted(event) 24 function onEncrypted(event)
25 { 25 {
26 assert_equals(event.target, video); 26 assert_equals(event.target, video);
27 assert_true(event instanceof window.MediaEncryptedEvent); 27 assert_true(event instanceof window.MediaEncryptedEvent);
28 assert_equals(event.type, 'encrypted'); 28 assert_equals(event.type, 'encrypted');
29 29
30 // The same decryption key is shared by all streams so only 30 // The same decryption key is shared by all streams so only
31 // create a shared session once. 31 // create a shared session once. To avoid timing issues with
32 if (sessionCreated) 32 // the "message" event being received before the second
33 // "encrypted" event, only create the session on the second
34 // event.
35 if (++encryptedEventCount != 2)
33 return; 36 return;
34 sessionCreated = true;
35 37
36 mediaKeySession = video.mediaKeys.createSession(); 38 mediaKeySession = video.mediaKeys.createSession();
37 waitForEventAndRunStep('message', mediaKeySession, onMessage , test); 39 waitForEventAndRunStep('message', mediaKeySession, onMessage , test);
38 mediaKeySession.generateRequest(event.initDataType, event.in itData).catch(function(error) { 40 mediaKeySession.generateRequest(event.initDataType, event.in itData).catch(function(error) {
39 forceTestFailureFromPromise(test, error); 41 forceTestFailureFromPromise(test, error);
40 }); 42 });
41 } 43 }
42 44
43 function onMessage(event) 45 function onMessage(event)
44 { 46 {
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
95 return video.setMediaKeys(mediaKeys); 97 return video.setMediaKeys(mediaKeys);
96 }).then(function(result) { 98 }).then(function(result) {
97 video.play(); 99 video.play();
98 }).catch(function(error) { 100 }).catch(function(error) {
99 forceTestFailureFromPromise(test, error); 101 forceTestFailureFromPromise(test, error);
100 }); 102 });
101 }, 'Waiting for a key.'); 103 }, 'Waiting for a key.');
102 </script> 104 </script>
103 </body> 105 </body>
104 </html> 106 </html>
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698