[Piglit] [PATCH 9/9] arb_direct_state_access: Added *NamedRenderbuffer* tests

Martin Peres martin.peres at linux.intel.com
Thu Feb 26 07:41:28 PST 2015


v2: review from Tapani
- add some documentation
- set the minimum GL version to 2.0

Signed-off-by: Martin Peres <martin.peres at linux.intel.com>
---
 tests/all.py                                       |   1 +
 .../spec/arb_direct_state_access/CMakeLists.gl.txt |   1 +
 .../arb_direct_state_access/namedrenderbuffer.c    | 182 +++++++++++++++++++++
 3 files changed, 184 insertions(+)
 create mode 100644 tests/spec/arb_direct_state_access/namedrenderbuffer.c

diff --git a/tests/all.py b/tests/all.py
index 159ee5e..6ba37e8 100644
--- a/tests/all.py
+++ b/tests/all.py
@@ -4001,6 +4001,7 @@ spec['ARB_direct_state_access']['transformfeedback-bufferbase'] = PiglitGLTest([
 spec['ARB_direct_state_access']['transformfeedback-bufferrange'] = PiglitGLTest(['arb_direct_state_access-transformfeedback-bufferrange'], run_concurrent=True)
 spec['ARB_direct_state_access']['gettransformfeedback'] = PiglitGLTest(['arb_direct_state_access-gettransformfeedback'], run_concurrent=True)
 spec['ARB_direct_state_access']['create-renderbuffers'] = PiglitGLTest(['arb_direct_state_access-create-renderbuffers'], run_concurrent=True)
+spec['ARB_direct_state_access']['namedrenderbuffer'] = PiglitGLTest(['arb_direct_state_access-namedrenderbuffer'], run_concurrent=True)
 spec['ARB_direct_state_access']['dsa-textures'] = PiglitGLTest(['arb_direct_state_access-dsa-textures'], run_concurrent=True)
 spec['ARB_direct_state_access']['texturesubimage'] = PiglitGLTest(['arb_direct_state_access-texturesubimage'], run_concurrent=True)
 spec['ARB_direct_state_access']['bind-texture-unit'] = PiglitGLTest(['arb_direct_state_access-bind-texture-unit'], run_concurrent=True)
diff --git a/tests/spec/arb_direct_state_access/CMakeLists.gl.txt b/tests/spec/arb_direct_state_access/CMakeLists.gl.txt
index 2dbc013..a5ae423 100644
--- a/tests/spec/arb_direct_state_access/CMakeLists.gl.txt
+++ b/tests/spec/arb_direct_state_access/CMakeLists.gl.txt
@@ -14,6 +14,7 @@ piglit_add_executable (arb_direct_state_access-transformfeedback-bufferbase tran
 piglit_add_executable (arb_direct_state_access-transformfeedback-bufferrange transformfeedback-bufferrange.c)
 piglit_add_executable (arb_direct_state_access-gettransformfeedback gettransformfeedback.c)
 piglit_add_executable (arb_direct_state_access-create-renderbuffers create-renderbuffers.c)
+piglit_add_executable (arb_direct_state_access-namedrenderbuffer namedrenderbuffer.c)
 piglit_add_executable (arb_direct_state_access-dsa-textures dsa-textures.c dsa-utils.c)
 piglit_add_executable (arb_direct_state_access-texturesubimage texturesubimage.c)
 piglit_add_executable (arb_direct_state_access-bind-texture-unit bind-texture-unit.c)
diff --git a/tests/spec/arb_direct_state_access/namedrenderbuffer.c b/tests/spec/arb_direct_state_access/namedrenderbuffer.c
new file mode 100644
index 0000000..9d8e0e5
--- /dev/null
+++ b/tests/spec/arb_direct_state_access/namedrenderbuffer.c
@@ -0,0 +1,182 @@
+/*
+ * Copyright 2015 Intel Corporation
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice (including the next
+ * paragraph) shall be included in all copies or substantial portions of the
+ * Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ * DEALINGS IN THE SOFTWARE.
+ */
+
+/** @file namedrenderbuffer.c
+ *
+ * Tests NamedRenderbufferStorage* functions to see if they behaves in the
+ * expected way, throwing the correct errors, etc. Also test
+ * glGetRenderbufferParameteriv.
+ *
+ * From OpenGL 4.5, section 9.2.4 "Renderbuffer Objects", page 298:
+ *
+ * "void NamedRenderbufferStorageMultisample(uint renderbuffer, sizei samples,
+ *                                           enum internalformat,sizei width,
+ *                                           sizei height );
+ *
+ * [...]
+ * For NamedRenderbufferStorageMultisample, renderbuffer is the name of the
+ * renderbuffer object. internalformat must be color-renderable,
+ * depth-renderable, or stencilrenderable (as defined in section 9.4). width
+ * and height are the dimensions in pixels of the renderbuffer. Upon success,
+ * RenderbufferStorageMultisample deletes any existing data store for the
+ * renderbuffer image, and the contents of the data store are undefined.
+ * RENDERBUFFER_WIDTH is set to width, RENDERBUFFER_HEIGHT is set to
+ * height, and RENDERBUFFER_INTERNAL_FORMAT is set to internalformat.
+ * If samples is zero, then RENDERBUFFER_SAMPLES is set to zero. Otherwise
+ * samples represents a request for a desired minimum number of samples. Since
+ * different implementations may support different sample counts for
+ * multisampled rendering, the actual number of samples allocated for the
+ * renderbuffer image is implementation-dependent. However, the resulting value
+ * for RENDERBUFFER_SAMPLES is guaranteed to be greater than or equal to
+ * samples and no more than the next larger sample count supported by the
+ * implementation. A GL implementation may vary its allocation of internal
+ * component resolution based on any *RenderbufferStorageMultisample parameter
+ * (except target and renderbuffer), but the allocation and chosen internal
+ * format must not be a function of any other state and cannot be changed once
+ * they are established.
+ *
+ * Errors
+ * An INVALID_ENUM error is generated by RenderbufferStorageMultisample
+ *  if target is not RENDERBUFFER.
+ * An INVALID_OPERATION error is generated by NamedRenderbufferStorageMultisample
+ *  if renderbuffer is not the name of an existing renderbuffer object.
+ * An INVALID_VALUE error is generated if samples, width, or height is negative.
+ * An INVALID_OPERATION error is generated if samples is greater than the
+ *  maximum number of samples supported for internalformat (see
+ *  GetInternalformativ in section 22.3).
+ * An INVALID_ENUM error is generated if internalformat is not one of the
+ *  color-renderable, depth-renderable, or stencil-renderable formats defined
+ *  in section 9.4.
+ * An INVALID_VALUE error is generated if either width or height is greater
+ *  than the value of MAX_RENDERBUFFER_SIZE.
+ *
+ * void NamedRenderbufferStorage(uint renderbuffer, enum internalformat,
+ *                               sizei width, sizei height);
+ * are equivalent to [...] NamedRenderbufferStorageMultisample(renderbuffer, 0,
+ * internalformat, width, height);"
+ */
+
+#include "piglit-util-gl.h"
+#include "dsa-utils.h"
+
+PIGLIT_GL_TEST_CONFIG_BEGIN
+
+	config.supports_gl_compat_version = 20;
+
+	config.window_visual = PIGLIT_GL_VISUAL_RGBA |
+		PIGLIT_GL_VISUAL_DOUBLE;
+
+PIGLIT_GL_TEST_CONFIG_END
+
+void
+piglit_init(int argc, char **argv)
+{
+	piglit_require_extension("GL_ARB_direct_state_access");
+	piglit_require_extension("GL_ARB_framebuffer_object");
+}
+
+enum piglit_result
+piglit_display(void)
+{
+	bool pass = true;
+	GLuint ids[10], genID;
+	GLint size, width;
+
+	/* Test retrieving information about an unexisting buffer */
+	glCreateRenderbuffers(10, ids);
+	piglit_check_gl_error(GL_NO_ERROR);
+
+	/* Check some various cases of errors */
+	glNamedRenderbufferStorageMultisample(1337, 0, GL_RGBA, 1024, 768);
+	SUBTEST(GL_INVALID_OPERATION, pass, "set unexisting renderbuffer");
+
+	glGetNamedRenderbufferParameteriv(1337, GL_RENDERBUFFER_WIDTH, &width);
+	SUBTEST(GL_INVALID_OPERATION, pass, "get unexisting renderbuffer");
+
+	glGetNamedRenderbufferParameteriv(ids[0], GL_TRUE, &width);
+	SUBTEST(GL_INVALID_ENUM, pass, "get unexisting parameter");
+
+	/* Test retrieving information on an un-initialized buffer */
+	glGenRenderbuffers(1, &genID);
+	piglit_check_gl_error(GL_NO_ERROR);
+
+	glGetNamedRenderbufferParameteriv(1337, GL_RENDERBUFFER_WIDTH, &width);
+	SUBTEST(GL_INVALID_OPERATION, pass, "get uninitialized renderbuffer");
+
+	/* Test the width/heights limits */
+	glGetIntegerv(GL_MAX_RENDERBUFFER_SIZE, &size);
+
+	glNamedRenderbufferStorageMultisample(ids[0], 0, GL_RGBA, -1, 768);
+	SUBTEST(GL_INVALID_VALUE, pass, "width < 0");
+
+	glNamedRenderbufferStorageMultisample(ids[0], 0, GL_RGBA, size + 1,
+					      768);
+	SUBTEST(GL_INVALID_VALUE, pass, "width == MAX_RENDER_SIZE(%d) + 1",
+		size);
+
+	glNamedRenderbufferStorageMultisample(ids[0], 0, GL_RGBA, 1024, -1);
+	SUBTEST(GL_INVALID_VALUE, pass, "height < 0");
+
+	glNamedRenderbufferStorageMultisample(ids[0], 0, GL_RGBA, 1024,
+					      size + 1);
+	SUBTEST(GL_INVALID_VALUE, pass, "height == MAX_RENDER_SIZE(%d) + 1",
+		size);
+
+	/* Test the samples limits */
+	glGetIntegerv(GL_MAX_SAMPLES, &size);
+
+	glNamedRenderbufferStorageMultisample(ids[0], -1, GL_RGBA, 1024, 768);
+	SUBTEST(GL_INVALID_VALUE, pass, "samples < 0");
+
+	glNamedRenderbufferStorageMultisample(ids[0], size + 1, GL_RGBA, 1024,
+					      768);
+	SUBTEST(GL_INVALID_OPERATION, pass, "samples == MAX_SAMPLES(%d) + 1",
+		size);
+
+	/* Misc tests */
+	glNamedRenderbufferStorageMultisample(ids[0], 0, GL_TRUE, 1024, 768);
+	SUBTEST(GL_INVALID_ENUM, pass, "invalid internalformat");
+
+	/* bind one buffer so as we can check we never change its state */
+	glBindRenderbuffer(GL_RENDERBUFFER, ids[1]);
+	piglit_check_gl_error(GL_NO_ERROR);
+
+	/* Test to change the parameters of an unbound renderbuffer */
+	glNamedRenderbufferStorageMultisample(ids[0], 0, GL_RGBA, 1024,
+					      768);
+	SUBTEST(GL_NO_ERROR, pass, "update unbound buffer");
+
+	glGetNamedRenderbufferParameteriv(ids[0], GL_RENDERBUFFER_WIDTH,
+			&width);
+	piglit_check_gl_error(GL_NO_ERROR);
+	SUBTESTCONDITION(width == 1024, pass,
+			 "width of the unbound buffer updated");
+
+	glGetRenderbufferParameteriv(GL_RENDERBUFFER, GL_RENDERBUFFER_WIDTH,
+			&width);
+	piglit_check_gl_error(GL_NO_ERROR);
+	SUBTESTCONDITION(width == 0, pass,
+			 "width of the bound buffer unchanged");
+
+	return pass ? PIGLIT_PASS : PIGLIT_FAIL;
+}
-- 
2.3.0



More information about the Piglit mailing list