OLD | NEW |
1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
2 <html> | 2 <title>Test that cues are being matched properly by the lang attribute and :lang
() pseudo class.</title> |
3 <head> | 3 <script src="../media-file.js"></script> |
4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> | 4 <script src="../media-controls.js"></script> |
| 5 <script src="../../resources/testharness.js"></script> |
| 6 <script src="../../resources/testharnessreport.js"></script> |
| 7 <style> |
| 8 ::cue(:lang(ru)) { color: lime; } |
| 9 ::cue(lang[lang="en"]) { color: purple; } |
| 10 ::cue(c[lang="ru"]) { color: red; } /* Shouldn't work, no attribute 'lang' for '
c'. */ |
| 11 </style> |
| 12 <video></video> |
| 13 <script> |
| 14 async_test(function(t) { |
| 15 var video = document.querySelector('video'); |
| 16 video.src = findMediaFile('video', '../content/test'); |
| 17 |
| 18 var track = document.createElement('track'); |
| 19 track.src = 'captions-webvtt/styling-lang.vtt'; |
| 20 track.kind = 'captions'; |
| 21 track.default = true; |
| 22 video.appendChild(track); |
5 | 23 |
6 <script src=../media-file.js></script> | 24 video.onseeked = t.step_func_done(function() { |
7 <!-- TODO(philipj): Convert test to testharness.js. crbug.com/588956 | 25 var cueNode = textTrackDisplayElement(video, 'cue').firstElementChild.fi
rstElementChild; |
8 (Please avoid writing new tests using video-test.js) --> | 26 assert_equals(getComputedStyle(cueNode).color, 'rgb(128, 0, 128)'); |
9 <script src=../video-test.js></script> | 27 cueNode = cueNode.firstElementChild.firstElementChild; |
10 <script src=../media-controls.js></script> | 28 assert_equals(getComputedStyle(cueNode).color, 'rgb(0, 255, 0)'); |
11 | 29 cueNode = cueNode.firstElementChild.firstElementChild; |
12 <style> | 30 assert_equals(getComputedStyle(cueNode).color, 'rgb(128, 0, 128)'); |
13 ::cue(:lang(ru)) { color: lime; } | 31 }); |
14 ::cue(lang[lang="en"]) { color: purple; } | 32 |
15 ::cue(c[lang="ru"]) { color: red; } /* Shouldn't work, no attribute 'lan
g' for 'c'. */ | 33 video.currentTime = 0.1; |
16 </style> | 34 }); |
17 | 35 </script> |
18 <script> | |
19 | |
20 var cueNode; | |
21 var seekedCount = 0; | |
22 var seekTimes = [0.1]; | |
23 | |
24 var info = [["rgb(128, 0, 128)", "rgb(0, 255, 0)", "rgb(128, 0, 128)"]]; | |
25 | |
26 function seeked() | |
27 { | |
28 if (testEnded) | |
29 return; | |
30 | |
31 cueNode = textTrackDisplayElement(video, 'cue').firstElementChild.fi
rstElementChild; | |
32 testExpected("getComputedStyle(cueNode).color", info[seekedCount][0]
); | |
33 cueNode = cueNode.firstElementChild.firstElementChild; | |
34 testExpected("getComputedStyle(cueNode).color", info[seekedCount][1]
); | |
35 cueNode = cueNode.firstElementChild.firstElementChild; | |
36 testExpected("getComputedStyle(cueNode).color", info[seekedCount][2]
); | |
37 | |
38 if (++seekedCount == info.length) | |
39 endTest(); | |
40 else { | |
41 consoleWrite(""); | |
42 run("video.currentTime = " + seekTimes[seekedCount]); | |
43 } | |
44 } | |
45 | |
46 function loaded() | |
47 { | |
48 consoleWrite("Test that cues are being matched properly by the lang
attribute and :lang() pseudo class."); | |
49 findMediaElement(); | |
50 video.src = findMediaFile('video', '../content/test'); | |
51 video.id = "testvideo"; | |
52 waitForEvent('seeked', seeked); | |
53 waitForEvent('canplaythrough', function() { video.currentTime = seek
Times[0]; }); | |
54 } | |
55 | |
56 </script> | |
57 </head> | |
58 <body onload="loaded()"> | |
59 <video controls > | |
60 <track src="captions-webvtt/styling-lang.vtt" kind="captions" defaul
t> | |
61 </video> | |
62 </body> | |
63 </html> | |
OLD | NEW |