|
1 |
|
2 <!DOCTYPE HTML> |
|
3 <html> |
|
4 <head> |
|
5 <title>Test for Bug 893309 - Implement TrackEvent</title> |
|
6 <script type="text/javascript" src="/MochiKit/MochiKit.js"></script> |
|
7 <script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> |
|
8 <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/> |
|
9 </head> |
|
10 <body> |
|
11 <p id="display"></p> |
|
12 <div id="content" style="display: none"> |
|
13 </div> |
|
14 <pre id="test"> |
|
15 <script class="testbody" type="text/javascript"> |
|
16 SimpleTest.waitForExplicitFinish(); |
|
17 SpecialPowers.pushPrefEnv({"set": [["media.webvtt.enabled", true]]}, |
|
18 function() { |
|
19 var video = document.createElement("video"); |
|
20 isnot(video.textTracks, undefined, "HTMLMediaElement::TextTrack() property should be available.") |
|
21 ok(typeof video.addTextTrack == "function", "HTMLMediaElement::AddTextTrack() function should be available.") |
|
22 |
|
23 var trackList = video.textTracks; |
|
24 is(trackList.length, 0, "Length should be 0."); |
|
25 |
|
26 var evtTextTrack, numOfCalls = 0, tt; |
|
27 trackList.onaddtrack = function(event) { |
|
28 ok(event instanceof TrackEvent, "Fired event from onaddtrack should be a TrackEvent"); |
|
29 is(event.type, "addtrack", "Event type should be addtrack"); |
|
30 ok(event.isTrusted, "Event should be trusted!"); |
|
31 ok(!event.bubbles, "Event shouldn't bubble!"); |
|
32 ok(!event.cancelable, "Event shouldn't be cancelable!"); |
|
33 |
|
34 evtTextTrack = event.track; |
|
35 tt = textTrack[numOfCalls].track || textTrack[numOfCalls]; |
|
36 |
|
37 ok(tt === evtTextTrack, "Text tracks should be the same"); |
|
38 is(evtTextTrack.label, label[numOfCalls], "Label should be set to "+ label[numOfCalls]); |
|
39 is(evtTextTrack.language, language[numOfCalls], "Language should be " + language[numOfCalls]); |
|
40 is(evtTextTrack.kind, kind[numOfCalls], "Kind should be " + kind[numOfCalls]); |
|
41 |
|
42 if (++numOfCalls == 4) { |
|
43 SimpleTest.finish(); |
|
44 } |
|
45 }; |
|
46 |
|
47 var label = ["Oasis", "Coldplay", "t.A.T.u", ""]; |
|
48 language = ["en-CA", "en-GB", "ru", ""]; |
|
49 kind = ["subtitles", "captions", "chapters", "subtitles"]; |
|
50 |
|
51 var textTrack = new Array(4); |
|
52 for (var i = 0; i < 3; ++i) { |
|
53 textTrack[i] = video.addTextTrack(kind[i], label[i], language[i]); |
|
54 is(trackList.length, i + 1, "Length should be " + (i+1)); |
|
55 } |
|
56 |
|
57 video.src = "seek.webm"; |
|
58 video.preload = "auto"; |
|
59 var trackElement = document.createElement("track"); |
|
60 trackElement.src = "basic.vtt"; |
|
61 textTrack[3] = trackElement; |
|
62 |
|
63 document.getElementById("content").appendChild(video); |
|
64 video.appendChild(trackElement); |
|
65 |
|
66 //TODO: Tests for removetrack event to be added along with bug 882677 |
|
67 } |
|
68 ); |
|
69 </script> |
|
70 </pre> |
|
71 </body> |
|
72 </html> |
|
73 |