summaryrefslogtreecommitdiffstats
path: root/dom/canvas/test/webgl-mochitest/test_video_fastpath.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-19 00:47:55 +0000
commit26a029d407be480d791972afb5975cf62c9360a6 (patch)
treef435a8308119effd964b339f76abb83a57c29483 /dom/canvas/test/webgl-mochitest/test_video_fastpath.js
parentInitial commit. (diff)
downloadfirefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz
firefox-26a029d407be480d791972afb5975cf62c9360a6.zip
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/canvas/test/webgl-mochitest/test_video_fastpath.js')
-rw-r--r--dom/canvas/test/webgl-mochitest/test_video_fastpath.js34
1 files changed, 34 insertions, 0 deletions
diff --git a/dom/canvas/test/webgl-mochitest/test_video_fastpath.js b/dom/canvas/test/webgl-mochitest/test_video_fastpath.js
new file mode 100644
index 0000000000..1c204237a7
--- /dev/null
+++ b/dom/canvas/test/webgl-mochitest/test_video_fastpath.js
@@ -0,0 +1,34 @@
+var gl;
+var video;
+
+function onPlayingTestVideo() {
+ video.removeEventListener("playing", onPlayingTestVideo, true);
+ gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, video);
+ is(
+ gl.getError(),
+ gl.NO_ERROR,
+ "texImage2D should not generate any error here."
+ );
+ video.pause();
+ SimpleTest.finish();
+}
+
+function startTest(file) {
+ gl = document.createElement("canvas").getContext("webgl");
+ ext = gl.getExtension("MOZ_debug");
+ ok(ext, "MOZ_debug extenstion should exist");
+ gl.bindTexture(gl.TEXTURE_2D, gl.createTexture());
+ gl.pixelStorei(ext.UNPACK_REQUIRE_FASTPATH, true);
+ is(
+ gl.getError(),
+ gl.NO_ERROR,
+ "pixelStorei should not generate any error here."
+ );
+
+ video = document.createElement("video");
+ video.addEventListener("playing", onPlayingTestVideo, true);
+ video.preload = "auto";
+ video.src = file;
+ video.loop = true;
+ video.play();
+}