| OLD | NEW |
| 1 <!DOCTYPE html> | 1 <!DOCTYPE html> |
| 2 <html> | 2 <title>Tests cues with class markup <c>.</title> |
| 3 <head> | 3 <script src="track-helpers.js"></script> |
| 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> | 4 <script src="../../resources/testharness.js"></script> |
| 5 <script src="../../resources/testharnessreport.js"></script> |
| 6 <script> |
| 7 check_cues_from_track("captions-webvtt/tc025-class.vtt", function(track) { |
| 8 assert_equals(track.cues.length, 3); |
| 5 | 9 |
| 6 <script src=../media-file.js></script> | 10 var children = [ |
| 7 <!-- TODO(foolip): Convert test to testharness.js. crbug.com/588956 | 11 { |
| 8 (Please avoid writing new tests using video-test.js) --> | 12 type: "span", |
| 9 <script src=../video-test.js></script> | 13 value: |
| 10 <script> | 14 [ |
| 15 { type: "text", value: "Bear is Coming!!!!!" }, |
| 16 { type: "style", value: { className: "black" } } |
| 17 ] |
| 18 } |
| 19 ]; |
| 20 assert_cue_fragment(track.cues[0], children); |
| 11 | 21 |
| 12 var numberOfTrackTests = 2; | 22 children = [ |
| 23 { |
| 24 type: "span", |
| 25 value: |
| 26 [ |
| 27 { type: "text", value: "I said Bear is coming!!!!" }, |
| 28 { type: "style", value: { className: "green" } } |
| 29 ] |
| 30 } |
| 31 ]; |
| 32 assert_cue_fragment(track.cues[1], children, { className: "green" }); |
| 13 | 33 |
| 14 function trackLoaded() | 34 children = [ |
| 15 { | 35 { type: "text", value: "I said " }, |
| 16 numberOfTracksLoaded++; | 36 { |
| 17 if (numberOfTracksLoaded == numberOfTrackTests) { | 37 type: "span", |
| 18 testTrack(0); | 38 value: |
| 19 testTrackError(1); | 39 [ |
| 20 } | 40 { type: "text", value: "Bear is coming now" }, |
| 21 } | 41 { type: "style", value: { className: "red uppercase" } } |
| 42 ] |
| 43 }, |
| 44 { type: "text", value: "!!!!" } |
| 45 ]; |
| 46 assert_cue_fragment(track.cues[2], children, { className: "red uppercase" })
; |
| 47 }); |
| 22 | 48 |
| 23 function testTrack(i) | 49 check_cues_from_track("captions-webvtt/tc025-class-bad.vtt", function(track) { |
| 24 { | 50 assert_equals(track.cues.length, 3); |
| 25 findMediaElement(); | |
| 26 testExpected("video.textTracks[" + i + "].cues.length", "3"); | |
| 27 | 51 |
| 28 var fragment = document.createDocumentFragment(); | 52 var children = [ |
| 29 var cspan = document.createElement("span"); | 53 { type: "span", value: [ { type: "text", value: "Bear is Coming!!!!!" }
] }, |
| 30 cspan.className = "black"; | 54 { type: "text", value: "\nThe space signified an annotation start." } |
| 31 cspan.appendChild(document.createTextNode("Bear is Coming!!!!!")
); | 55 ]; |
| 32 fragment.appendChild(cspan); | 56 assert_cue_fragment(track.cues[0], children); |
| 33 | 57 |
| 34 testExpected(fragment.isEqualNode(video.textTracks[i].cues[0].ge
tCueAsHTML()), true); | 58 children = [ |
| 59 { |
| 60 type: "span", |
| 61 value: |
| 62 [ |
| 63 { type: "text", value: "I said Bear is coming!!!!" }, |
| 64 { type: "style", value: { className: "red&large" } } |
| 65 ] |
| 66 }, |
| 67 { type: "text", value: "\nProbably should only allow characters that CSS
allows in class names." } |
| 68 ]; |
| 69 assert_cue_fragment(track.cues[1], children, { className: "red&large" }); |
| 35 | 70 |
| 36 fragment = document.createDocumentFragment(); | 71 children = [ |
| 37 cspan = document.createElement("span"); | 72 { type: "text", value: "I said " }, |
| 38 cspan.className = "green"; | 73 { |
| 39 cspan.appendChild(document.createTextNode("I said Bear is coming
!!!!")); | 74 type: "span", |
| 40 fragment.appendChild(cspan); | 75 value: |
| 41 | 76 [ |
| 42 testExpected(fragment.isEqualNode(video.textTracks[i].cues[1].ge
tCueAsHTML()), true); | 77 { type: "text", value: "Bear is coming now" }, |
| 43 | 78 { type: "style", value: { className: "9red upper+case" } } |
| 44 fragment = document.createDocumentFragment(); | 79 ] |
| 45 fragment.appendChild(document.createTextNode("I said ")); | 80 }, |
| 46 cspan = document.createElement("span"); | 81 { type: "text", value: "!!!!\nProbably should only allow characters that
CSS allows in class names." } |
| 47 cspan.className = "red uppercase"; | 82 ]; |
| 48 cspan.appendChild(document.createTextNode("Bear is coming now"))
; | 83 assert_cue_fragment(track.cues[2], children, { className: "9red upper+case"
}); |
| 49 fragment.appendChild(cspan); | 84 }); |
| 50 fragment.appendChild(document.createTextNode("!!!!")); | 85 </script> |
| 51 | |
| 52 testExpected(fragment.isEqualNode(video.textTracks[i].cues[2].ge
tCueAsHTML()), true); | |
| 53 | |
| 54 allTestsEnded(); | |
| 55 } | |
| 56 | |
| 57 function testTrackError(i) | |
| 58 { | |
| 59 findMediaElement(); | |
| 60 testExpected("video.textTracks[" + i + "].cues.length", "3"); | |
| 61 | |
| 62 var fragment = document.createDocumentFragment(); | |
| 63 var cspan = document.createElement("span"); | |
| 64 cspan.appendChild(document.createTextNode("Bear is Coming!!!!!")
); | |
| 65 fragment.appendChild(cspan); | |
| 66 fragment.appendChild(document.createTextNode("\nThe space signif
ied an annotation start.")); | |
| 67 | |
| 68 testExpected(fragment.isEqualNode(video.textTracks[i].cues[0].ge
tCueAsHTML()), true); | |
| 69 | |
| 70 fragment = document.createDocumentFragment(); | |
| 71 cspan = document.createElement("span"); | |
| 72 cspan.className = "red&large"; | |
| 73 cspan.appendChild(document.createTextNode("I said Bear is coming
!!!!")); | |
| 74 fragment.appendChild(cspan); | |
| 75 fragment.appendChild(document.createTextNode("\nProbably should
only allow characters that CSS allows in class names.")); | |
| 76 | |
| 77 testExpected(fragment.isEqualNode(video.textTracks[i].cues[1].ge
tCueAsHTML()), true); | |
| 78 | |
| 79 fragment = document.createDocumentFragment(); | |
| 80 fragment.appendChild(document.createTextNode("I said ")); | |
| 81 cspan = document.createElement("span"); | |
| 82 cspan.className = "9red upper+case"; | |
| 83 cspan.appendChild(document.createTextNode("Bear is coming now"))
; | |
| 84 fragment.appendChild(cspan); | |
| 85 fragment.appendChild(document.createTextNode("!!!!\nProbably sho
uld only allow characters that CSS allows in class names.")); | |
| 86 | |
| 87 testExpected(fragment.isEqualNode(video.textTracks[i].cues[2].ge
tCueAsHTML()), true); | |
| 88 | |
| 89 allTestsEnded(); | |
| 90 } | |
| 91 </script> | |
| 92 </head> | |
| 93 <body onload="enableAllTextTracks()"> | |
| 94 <p>Tests cues with class markup <c>.</p> | |
| 95 <video> | |
| 96 <track src="captions-webvtt/tc025-class.vtt" onload="trackLoaded()"> | |
| 97 <track src="captions-webvtt/tc025-class-bad.vtt" onload="trackLoaded
()"> | |
| 98 </video> | |
| 99 </body> | |
| 100 </html> | |
| OLD | NEW |