Bug 1361655 - Add new reftest to verify the first and last frame for short.mp4. r=jwwang

Since the ref-sample made by linux, the mac and windows platforms need fuzzy.
And on windows platform, the first frame is different to other platform, skip it first.
Android platform somehow can not load the video src.

MozReview-Commit-ID: A0VbEcNSmck

--HG--
extra : rebase_source : 266f0012d460b8fd6b62ac1d2878dc9aa686f9a8
This commit is contained in:
bechen 2017-05-17 16:54:16 +08:00
parent a12765de8f
commit 97ab63e82a
7 changed files with 154 additions and 0 deletions

View File

@ -0,0 +1,80 @@
<!DOCTYPE HTML>
<html>
<head>
<script type="application/javascript">
</script>
</head>
<body>
<video id="v1" style="position:absolute; left:0; top:0"></video>
<canvas id="canvas"></canvas>
<script type="application/javascript">
/* READ ME first.
The script is trying to make a reftest sample for reftest.
HOW TO USE:
1. Choose the first or last frame you want to generate. And set
window.onload function to dumpFirstFrameToConsole/dumpLastFrameToConsole.
2. Set the video.src in dumpFirstFrameToConsole/dumpLastFrameToConsole.
3. Run the script on browser.
4. Open console (ctrl+shift+k) to get the first/last frame.
5. Copy the url to your xxx-ref.html(short.mp4.firstframe-ref.html).
You might hit security error if the video.src cross origin.
Enable "media.seekToNextFrame.enabled" for the seekToNextFrame function
or using nightly, the seekToNextFrame() ensure the ended event fired.
*/
//window.onload = function() { setTimeout(dumpFirstFrameToConsole, 0); };
window.onload = function() { setTimeout(dumpLastFrameToConsole, 0); };
function drawVideoToConsole(v) {
var canvas = document.getElementById("canvas");
canvas.width = v.videoWidth;
canvas.height = v.videoHeight;
var ctx = canvas.getContext("2d");
ctx.drawImage(v, 0, 0, v.videoWidth, v.videoHeight);
var dataURL = canvas.toDataURL();
console.log(dataURL);
}
function dumpFirstFrameToConsole() {
var video = document.getElementById("v1");
video.src = "short.mp4";
video.preload = "metadata";
video.addEventListener("loadeddata", function() {
drawVideoToConsole(video);
});
}
function dumpLastFrameToConsole() {
var video = document.getElementById("v1");
video.src = "short.mp4";
video.preload = "metadata";
video.seenEnded = false;
// Seek to the end
video.addEventListener("loadeddata", function() {
video.currentTime = video.duration;
video.onseeked = () => {
video.onseeked = null;
callSeekToNextFrame();
};
});
function callSeekToNextFrame() {
video.seekToNextFrame().then(
() => {
if (!video.seenEnded)
callSeekToNextFrame();
},
() => {
// Reach the end, do nothing.
}
);
}
video.addEventListener("ended", function() {
video.seenEnded = true;
drawVideoToConsole(video);
});
}
</script>
</body>
</html>

View File

@ -0,0 +1,2 @@
skip-if(Android) fuzzy-if(OSX,22,49977) skip-if(winWidget) HTTP(..) == short.mp4.firstframe.html short.mp4.firstframe-ref.html
skip-if(Android) fuzzy-if(OSX,23,51392) fuzzy-if(winWidget,59,76797) HTTP(..) == short.mp4.lastframe.html short.mp4.lastframe-ref.html

View File

@ -0,0 +1,4 @@
<!DOCTYPE HTML>
<img style="position:absolute; left:0; top:0"
src=""
>

View File

@ -0,0 +1,19 @@
<!DOCTYPE HTML>
<html class="reftest-wait">
<head>
<script type="text/javascript">
function doTest() {
var video = document.getElementById("v1");
video.src = "../short.mp4";
video.preload = "metadata";
video.addEventListener("loadeddata", function() {
document.documentElement.removeAttribute('class');
});
}
window.addEventListener("MozReftestInvalidate", doTest);
</script>
</head>
<body>
<video id="v1" style="position:absolute; left:0; top:0"></video>
</body>
</html>

File diff suppressed because one or more lines are too long

View File

@ -0,0 +1,42 @@
<!DOCTYPE HTML>
<html class="reftest-wait">
<head>
<script type="text/javascript">
function doTest() {
var video = document.getElementById("v1");
video.src = "../short.mp4";
video.preload = "metadata";
video.seenEnded = false;
// Seek to the end
video.addEventListener("loadeddata", function() {
video.currentTime = video.duration;
video.onseeked = () => {
video.onseeked = null;
callSeekToNextFrame();
};
});
function callSeekToNextFrame() {
video.seekToNextFrame().then(
() => {
if (!video.seenEnded)
callSeekToNextFrame();
},
() => {
// Reach the end, do nothing.
}
);
}
video.addEventListener("ended", function() {
video.seenEnded = true;
document.documentElement.removeAttribute('class');
});
}
window.addEventListener("MozReftestInvalidate", doTest);
</script>
</head>
<body>
<video id="v1" style="position:absolute; left:0; top:0"></video>
</body>
</html>

View File

@ -429,3 +429,6 @@ include ../../dom/encoding/test/reftest/reftest.list
# APZ/async positioning tests
include ../../gfx/layers/apz/test/reftest/reftest.list
# Media
include ../../dom/media/test/reftest/reftest.list