зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1377193 - Add the m3u8 and media contents into gecko and add one general test case run only on Fennec for testing HLS. r=jwwang
MozReview-Commit-ID: 8cwQlcah2H8 --HG-- extra : rebase_source : 29398ab3557ad6f2ed6c4aafc7be6dbd8eca8cc8
This commit is contained in:
Родитель
95274c9f77
Коммит
759a5057e8
|
@ -0,0 +1,10 @@
|
|||
#EXTM3U
|
||||
#EXT-X-TARGETDURATION:10
|
||||
#EXT-X-VERSION:3
|
||||
#EXT-X-MEDIA-SEQUENCE:0
|
||||
#EXT-X-PLAYLIST-TYPE:VOD
|
||||
#EXTINF:9.97667,
|
||||
400x300_seg0.ts
|
||||
#EXTINF:9.97667,
|
||||
400x300_seg1.ts
|
||||
#EXT-X-ENDLIST
|
Двоичный файл не отображается.
Двоичный файл не отображается.
|
@ -0,0 +1,10 @@
|
|||
#EXTM3U
|
||||
#EXT-X-TARGETDURATION:10
|
||||
#EXT-X-VERSION:3
|
||||
#EXT-X-MEDIA-SEQUENCE:0
|
||||
#EXT-X-PLAYLIST-TYPE:VOD
|
||||
#EXTINF:9.97667,
|
||||
640x480_seg0.ts
|
||||
#EXTINF:9.97667,
|
||||
640x480_seg1.ts
|
||||
#EXT-X-ENDLIST
|
Двоичный файл не отображается.
Двоичный файл не отображается.
|
@ -0,0 +1,10 @@
|
|||
#EXTM3U
|
||||
#EXT-X-TARGETDURATION:10
|
||||
#EXT-X-VERSION:3
|
||||
#EXT-X-MEDIA-SEQUENCE:0
|
||||
#EXT-X-PLAYLIST-TYPE:VOD
|
||||
#EXTINF:9.97667,
|
||||
960x720_seg0.ts
|
||||
#EXTINF:9.97667,
|
||||
960x720_seg1.ts
|
||||
#EXT-X-ENDLIST
|
Двоичный файл не отображается.
Двоичный файл не отображается.
|
@ -0,0 +1,10 @@
|
|||
#EXTM3U
|
||||
|
||||
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=232370,CODECS="mp4a.40.2, avc1.4d4015"
|
||||
400x300_prog_index.m3u8
|
||||
|
||||
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=649879,CODECS="mp4a.40.2, avc1.4d401e"
|
||||
640x480_prog_index.m3u8
|
||||
|
||||
#EXT-X-STREAM-INF:PROGRAM-ID=1,BANDWIDTH=649879,CODECS="mp4a.40.2, avc1.4d401e"
|
||||
960x720_prog_index.m3u8
|
|
@ -22,6 +22,14 @@ function manifestVideo() {
|
|||
return gManifestNavigatorSource.contentDocument.createElement('video');
|
||||
}
|
||||
|
||||
// Need to get the server url composed with ip:port instead of mochi.test.
|
||||
// Since we will provide the url to Exoplayer which cannot recognize the domain
|
||||
// name "mochi.test".
|
||||
let serverUrl = SpecialPowers.Services.prefs.getCharPref("media.hls.server.url");
|
||||
var gHLSTests = [
|
||||
{ name: serverUrl + "/bipbop_4x3_variant.m3u8", type:"audio/x-mpegurl", duration:19.95334 }
|
||||
];
|
||||
|
||||
// These are small test files, good for just seeing if something loads. We
|
||||
// really only need one test file per backend here.
|
||||
var gSmallTests = [
|
||||
|
|
|
@ -644,6 +644,16 @@ support-files =
|
|||
wavedata_ulaw.wav^headers^
|
||||
!/dom/canvas/test/captureStream_common.js
|
||||
!/dom/html/test/reflect.js
|
||||
hls/bipbop_4x3_variant.m3u8
|
||||
hls/400x300_prog_index.m3u8
|
||||
hls/640x480_prog_index.m3u8
|
||||
hls/960x720_prog_index.m3u8
|
||||
hls/400x300_seg0.ts
|
||||
hls/400x300_seg1.ts
|
||||
hls/640x480_seg0.ts
|
||||
hls/640x480_seg1.ts
|
||||
hls/960x720_seg0.ts
|
||||
hls/960x720_seg1.ts
|
||||
|
||||
[test_access_control.html]
|
||||
skip-if = android_version == '15' || android_version == '17' # bug 1292836, android(bug 1232305)
|
||||
|
@ -1188,3 +1198,10 @@ tags = suspend
|
|||
skip-if = toolkit == 'android' # android(bug 1232305)
|
||||
|
||||
[test_video_gzip_encoding.html]
|
||||
|
||||
[test_playback_hls.html]
|
||||
# HLS is only supported on Fennec with API level >= 16
|
||||
# TODO: This test is similar to test_playback.html, will remove the
|
||||
# redundant code once test_playback.html is enabled on Fennec.
|
||||
skip-if = toolkit != 'android' || android_version < '16'
|
||||
tags = hls
|
|
@ -0,0 +1,105 @@
|
|||
<!DOCTYPE HTML>
|
||||
<html>
|
||||
<head>
|
||||
<title>Test playback of HLS with simple m3u8 that should play OK</title>
|
||||
<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
|
||||
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
|
||||
<script type="text/javascript" src="manifest.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<pre id="test">
|
||||
<script class="testbody" type="text/javascript">
|
||||
|
||||
var manager = new MediaTestManager;
|
||||
|
||||
function startTest(test, token) {
|
||||
var v = document.createElement('video');
|
||||
v.preload = "metadata";
|
||||
v.token = token;
|
||||
v.prevTime = 0;
|
||||
v.seenEnded = false;
|
||||
|
||||
var handler = {
|
||||
"ontimeout": function() {
|
||||
Log(token, "timed out: ended=" + v.seenEnded);
|
||||
}
|
||||
};
|
||||
manager.started(token, handler);
|
||||
|
||||
v.src = test.name;
|
||||
v.name = test.name;
|
||||
|
||||
var check = function(test, v) { return function() {
|
||||
is(test.name, v.name, test.name + ": Name should match #1");
|
||||
checkMetadata(test.name, v, test);
|
||||
}}(test, v);
|
||||
|
||||
var noLoad = function(test, v) { return function() {
|
||||
ok(false, test.name + " should not fire 'load' event");
|
||||
}}(test, v);
|
||||
|
||||
var finish = function() {
|
||||
v.finished = true;
|
||||
v.removeEventListener("timeupdate", timeUpdate);
|
||||
removeNodeAndSource(v);
|
||||
manager.finished(v.token);
|
||||
}
|
||||
|
||||
// We should get "ended" events to finish the test.
|
||||
var mayFinish = function() {
|
||||
if (v.seenEnded) {
|
||||
finish();
|
||||
}
|
||||
}
|
||||
|
||||
var checkEnded = function(test, v) { return function() {
|
||||
is(test.name, v.name, test.name + ": Name should match #2");
|
||||
checkMetadata(test.name, v, test);
|
||||
is(v.readyState, v.HAVE_CURRENT_DATA, test.name + " checking readyState");
|
||||
ok(v.ended, test.name + " checking playback has ended");
|
||||
ok(!v.finished, test.name + " shouldn't be finished");
|
||||
ok(!v.seenEnded, test.name + " shouldn't be ended");
|
||||
|
||||
v.seenEnded = true;
|
||||
mayFinish();
|
||||
}}(test, v);
|
||||
|
||||
var timeUpdate = function(test, v) { return function() {
|
||||
if (v.prevTime > v.currentTime) {
|
||||
ok(false, test.name + " time should run forwards: p=" +
|
||||
v.prevTime + " c=" + v.currentTime);
|
||||
}
|
||||
v.prevTime = v.currentTime;
|
||||
}}(test, v);
|
||||
|
||||
v.addEventListener("load", noLoad);
|
||||
v.addEventListener("loadedmetadata", check);
|
||||
v.addEventListener("timeupdate", timeUpdate);
|
||||
|
||||
// We should get "ended" events for the hls resource
|
||||
v.addEventListener("ended", checkEnded);
|
||||
|
||||
document.body.appendChild(v);
|
||||
v.play();
|
||||
|
||||
// Log the event on android devices or emulator for debugging.
|
||||
if (isSlowPlatform()) {
|
||||
var events = ["suspend", "play", "canplay", "canplaythrough", "loadstart","loadedmetadata",
|
||||
"loadeddata", "playing", "ended", "error", "stalled", "emptied", "abort",
|
||||
"waiting", "pause"];
|
||||
function logEvent(e) {
|
||||
var v = e.target;
|
||||
Log(e.target.token, "got " + e.type);
|
||||
}
|
||||
events.forEach(function(e) {
|
||||
v.addEventListener(e, logEvent);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
manager.runTests(gHLSTests, startTest);
|
||||
|
||||
</script>
|
||||
</pre>
|
||||
</body>
|
||||
</html>
|
|
@ -59,6 +59,7 @@ user_pref("app.update.url.android", "");
|
|||
// Make sure GMPInstallManager won't hit the network.
|
||||
user_pref("media.gmp-manager.url.override", "http://%(server)s/dummy-gmp-manager.xml");
|
||||
user_pref("media.gmp-manager.updateEnabled", false);
|
||||
user_pref("media.hls.server.url", "http://%(server)s/tests/dom/media/test/hls");
|
||||
user_pref("dom.w3c_touch_events.enabled", 1);
|
||||
user_pref("layout.accessiblecaret.enabled_on_touch", false);
|
||||
user_pref("dom.webcomponents.enabled", true);
|
||||
|
|
Загрузка…
Ссылка в новой задаче