Bug 872701 - Add test that highp floats work iff GL gives a format for them. - r=bjacob

This commit is contained in:
Jeff Gilbert 2013-10-09 16:41:56 -07:00
Родитель f12c78d39a
Коммит 8d1258cc0c
4 изменённых файлов: 91 добавлений и 9 удалений

Просмотреть файл

@ -134,6 +134,7 @@ DriverInfo = (function() {
getOS: function() { return kOS; },
getDriver: function() { return kDriver; },
getOSVersion: function() { return kOSVersion; },
hasWebGL: function { return kHasWebGL; },
};
})();

Просмотреть файл

@ -3,6 +3,7 @@ support-files =
driver-info.js
webgl-util.js
[test_highp_fs.html]
[test_webgl_available.html]
[test_webgl_conformance.html]
[test_webgl_request_mismatch.html]

Просмотреть файл

@ -0,0 +1,63 @@
<!DOCTYPE HTML>
<title>WebGL test: `highp` support</title>
<script src="/MochiKit/MochiKit.js"></script>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" href="/tests/SimpleTest/test.css">
<script src="webgl-util.js"></script>
<script src="driver-info.js"></script>
<script id="shader-vs" type="x-shader/x-vertex">
void main(void) {
gl_Position = vec4(vec3(0.0), 1.0);
}
</script>
<script id="shader-fs" type="x-shader/x-fragment">
precision highp float;
void main(void) {
gl_FragColor = vec4(1.0, 1.0, 1.0, 1.0);
}
</script>
<body>
<canvas id="c"></canvas>
<script>
var gl = WebGLUtil.getWebGL('c');
// Give ourselves a scope to return early from:
(function() {
if (DriverInfo.getOS() == DriverInfo.OS.ANDROID &&
DriverInfo.getOSVersion() < 15)
{
// Consider 'random'. Actually, ARMv6 fails, and ARMv7 succeeds, but we have
// not been successful at determining this from JS. (see bug 917478)
return;
}
ok(gl, 'Should have a WebGL context.');
// Catch actual WebGLUtil errors, not GL errors.
function errorFunc(str) {
ok(false, 'Error: ' + str);
}
WebGLUtil.setErrorFunc(errorFunc);
var format = gl.getShaderPrecisionFormat(gl.FRAGMENT_SHADER, gl.HIGH_FLOAT);
ok(!gl.getError(), 'Unexpected GL error.');
var prog = WebGLUtil.createProgramByIds(gl, 'shader-vs', 'shader-fs');
ok(!gl.getError(), 'Unexpected GL error.');
if (format) {
ok(prog, 'Frag shader with unconditional `precision highp float` should ' +
'link if `getShaderPrecisionFormat` gives a format for it.');
} else {
ok(!prog, 'Frag shader with unconditional `precision highp float` should ' +
'NOT link if `getShaderPrecisionFormat` gives NO format for it.');
}
})();
</script>

Просмотреть файл

@ -1,6 +1,6 @@
WebGLUtil = (function() {
// ---------------------------------------------------------------------------
// Error handling
// Error handling (for obvious failures, such as invalid element ids)
function defaultErrorFunc(str) {
console.log('Error: ' + str);
@ -15,6 +15,22 @@ WebGLUtil = (function() {
gErrorFunc(str);
}
// ---------------------------------------------------------------------------
// Warning handling (for failures that may be intentional)
function defaultWarningFunc(str) {
console.log('Warning: ' + str);
}
var gWarningFunc = defaultWarningFunc;
function setWarningFunc(func) {
gWarningFunc = func;
}
function warning(str) {
gWarningFunc(str);
}
// ---------------------------------------------------------------------------
// WebGL helpers
@ -63,19 +79,19 @@ WebGLUtil = (function() {
return null;
}
var src = getContentById(id);
var src = getContentFromElem(elem);
var shader;
if (elem.type == "x-shader/x-fragment") {
shader = gl.createShader(gl.FRAGMENT_SHADER);
} else if (shaderScript.type == "x-shader/x-vertex") {
} else if (elem.type == "x-shader/x-vertex") {
shader = gl.createShader(gl.VERTEX_SHADER);
} else {
error('Bad MIME type for shader \'' + id + '\': ' + elem.type + '.');
return null;
}
gl.shaderSource(shader, str);
gl.shaderSource(shader, src);
gl.compileShader(shader);
return shader;
@ -93,11 +109,11 @@ WebGLUtil = (function() {
gl.linkProgram(prog);
if (!gl.getProgramParameter(prog, gl.LINK_STATUS)) {
var str = "Shader program linking failed:\n";
str += "Shader program info log:\n" + gl.getProgramInfoLog(prog) + "\n\n";
str += "Vert shader log:\n" + gl.getShaderInfoLog(vs) + "\n\n";
str += "Frag shader log:\n" + gl.getShaderInfoLog(fs);
error(str);
var str = "Shader program linking failed:";
str += "\nShader program info log:\n" + gl.getProgramInfoLog(prog);
str += "\n\nVert shader log:\n" + gl.getShaderInfoLog(vs);
str += "\n\nFrag shader log:\n" + gl.getShaderInfoLog(fs);
warning(str);
return null;
}
@ -106,6 +122,7 @@ WebGLUtil = (function() {
return {
setErrorFunc: setErrorFunc,
setWarningFunc: setWarningFunc,
getWebGL: getWebGL,
createShaderById: createShaderById,