[Cogl] [PATCH 1/2] Add a test for cogl_framebuffer_push_path_clip
Neil Roberts
neil at linux.intel.com
Mon Dec 2 10:56:17 PST 2013
The test makes an L-shaped path that fills the whole framebuffer
except for the top right quadrant. It then clips to that and tries to
fill the framebuffer with a rectangle. Then it verifies that all of
the quadrants have the expected colour.
This is currently failing due to a bug in the primitive clipping.
---
tests/conform/Makefile.am | 4 ++-
tests/conform/test-conform-main.c | 1 +
tests/conform/test-path-clip.c | 67 +++++++++++++++++++++++++++++++++++++++
3 files changed, 71 insertions(+), 1 deletion(-)
create mode 100644 tests/conform/test-path-clip.c
diff --git a/tests/conform/Makefile.am b/tests/conform/Makefile.am
index a54f0e7..e3493a9 100644
--- a/tests/conform/Makefile.am
+++ b/tests/conform/Makefile.am
@@ -75,7 +75,9 @@ test_sources += test-fence.c
endif
if BUILD_COGL_PATH
-test_sources += test-path.c
+test_sources += \
+ test-path.c \
+ test-path-clip.c
endif
test_conformance_SOURCES = $(common_sources) $(test_sources)
diff --git a/tests/conform/test-conform-main.c b/tests/conform/test-conform-main.c
index dae98b5..572235b 100644
--- a/tests/conform/test-conform-main.c
+++ b/tests/conform/test-conform-main.c
@@ -58,6 +58,7 @@ main (int argc, char **argv)
UNPORTED_TEST (test_readpixels);
#ifdef COGL_HAS_COGL_PATH_SUPPORT
ADD_TEST (test_path, 0, 0);
+ ADD_TEST (test_path_clip, 0, TEST_KNOWN_FAILURE);
#endif
ADD_TEST (test_depth_test, 0, 0);
ADD_TEST (test_color_mask, 0, 0);
diff --git a/tests/conform/test-path-clip.c b/tests/conform/test-path-clip.c
new file mode 100644
index 0000000..18f4339
--- /dev/null
+++ b/tests/conform/test-path-clip.c
@@ -0,0 +1,67 @@
+#include <cogl/cogl.h>
+#include <cogl-path/cogl-path.h>
+
+#include <string.h>
+
+#include "test-utils.h"
+
+void
+test_path_clip (void)
+{
+ CoglPath *path;
+ CoglPipeline *pipeline;
+ int fb_width, fb_height;
+
+ fb_width = cogl_framebuffer_get_width (test_fb);
+ fb_height = cogl_framebuffer_get_height (test_fb);
+
+ cogl_framebuffer_orthographic (test_fb,
+ 0, 0, fb_width, fb_height, -1, 100);
+
+ path = cogl_path_new (test_ctx);
+
+ cogl_framebuffer_clear4f (test_fb,
+ COGL_BUFFER_BIT_COLOR,
+ 1.0f, 0.0f, 0.0f, 1.0f);
+
+ /* Make an L-shape with the top right corner left untouched */
+ cogl_path_move_to (path, 0, fb_height);
+ cogl_path_line_to (path, fb_width, fb_height);
+ cogl_path_line_to (path, fb_width, fb_height / 2);
+ cogl_path_line_to (path, fb_width / 2, fb_height / 2);
+ cogl_path_line_to (path, fb_width / 2, 0);
+ cogl_path_line_to (path, 0, 0);
+ cogl_path_close (path);
+
+ cogl_framebuffer_push_path_clip (test_fb, path);
+
+ /* Try to fill the framebuffer with a blue rectangle. This should be
+ * clipped to leave the top right quadrant as is */
+ pipeline = cogl_pipeline_new (test_ctx);
+ cogl_pipeline_set_color4ub (pipeline, 0, 0, 255, 255);
+ cogl_framebuffer_draw_rectangle (test_fb,
+ pipeline,
+ 0, 0, fb_width, fb_height);
+
+ cogl_framebuffer_pop_clip (test_fb);
+
+ cogl_object_unref (pipeline);
+ cogl_object_unref (path);
+
+ /* Check each of the four quadrants */
+ test_utils_check_pixel (test_fb,
+ fb_width / 4, fb_height / 4,
+ 0x0000ffff);
+ test_utils_check_pixel (test_fb,
+ fb_width * 3 / 4, fb_height / 4,
+ 0xff0000ff);
+ test_utils_check_pixel (test_fb,
+ fb_width / 4, fb_height * 3 / 4,
+ 0x0000ffff);
+ test_utils_check_pixel (test_fb,
+ fb_width * 3 / 4, fb_height * 3 / 4,
+ 0x0000ffff);
+
+ if (cogl_test_verbose ())
+ g_print ("OK\n");
+}
--
1.8.3.1
More information about the Cogl
mailing list