diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /dom/canvas/test/webgl-mochitest/test_texsubimage_float.html | |
parent | Initial commit. (diff) | |
download | thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/canvas/test/webgl-mochitest/test_texsubimage_float.html')
-rw-r--r-- | dom/canvas/test/webgl-mochitest/test_texsubimage_float.html | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/dom/canvas/test/webgl-mochitest/test_texsubimage_float.html b/dom/canvas/test/webgl-mochitest/test_texsubimage_float.html new file mode 100644 index 0000000000..991066e41b --- /dev/null +++ b/dom/canvas/test/webgl-mochitest/test_texsubimage_float.html @@ -0,0 +1,56 @@ +<!DOCTYPE HTML> +<title>WebGL test: bug 1003607</title> +<script src="/tests/SimpleTest/SimpleTest.js"></script> +<link rel="stylesheet" href="/tests/SimpleTest/test.css"> +<script src="driver-info.js"></script> +<script src="webgl-util.js"></script> +<body> +<canvas id="c"></canvas> +<script> + +// Give ourselves a scope to return early from: +(function() { + var gl = c.getContext('webgl'); + if (!gl) { + todo(false, 'WebGL is unavailable.'); + return; + } + + function checkGLError(func, info, reference) { + var error = gl.getError(); + var prefix = info ? ('[' + info + '] ') : ''; + var text = 'gl.getError should be 0x' + reference.toString(16) + + ', was 0x' + error.toString(16) + '.'; + func(error == reference, prefix + text); + } + + // Begin test: + if (!gl.getExtension('OES_texture_float')) { + todo(false, 'Not having this extension is fine.'); + return; + } + var tex = gl.createTexture(); + gl.bindTexture(gl.TEXTURE_2D, tex); + gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST); + gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST); + gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE); + gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE); + checkGLError(ok, 'texture parameter setup should succeed', gl.NO_ERROR); + + // Generate data + var width = 2; + var height = 2; + var numChannels = 4; + var data = new Float32Array(width * height * numChannels); + for (var ii = 0; ii < data.length; ++ii) { + data[ii] = 10000; + } + gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, width, height, 0, gl.RGBA, gl.FLOAT, data); + checkGLError(ok, 'floating-point texture allocation should succeed', gl.NO_ERROR); + + // Try respecifying data + gl.texSubImage2D(gl.TEXTURE_2D, 0, 0, 0, width, height, gl.RGBA, gl.FLOAT, data); + checkGLError(ok, 'floating-point texture sub image should succeed', gl.NO_ERROR); +})(); + +</script> |