summaryrefslogtreecommitdiff
path: root/test/get-xrender-format.c
diff options
context:
space:
mode:
authorCarl Worth <cworth@cworth.org>2008-01-27 12:14:51 -0800
committerCarl Worth <cworth@cworth.org>2008-01-28 15:39:40 -0800
commitd7fd3bd536465881446686305622d31fdc6fd48f (patch)
treed789784bfcd04fa4c6cf596f3dbe4f9f0341ad4a /test/get-xrender-format.c
parentcc94dce25085fef936b7cb36cf9fc41569668eba (diff)
downloadcairo-d7fd3bd536465881446686305622d31fdc6fd48f.tar.gz
Add get-xrender-format test to test cairo_xlib_surface_get_xrender_format
Diffstat (limited to 'test/get-xrender-format.c')
-rw-r--r--test/get-xrender-format.c104
1 files changed, 104 insertions, 0 deletions
diff --git a/test/get-xrender-format.c b/test/get-xrender-format.c
new file mode 100644
index 000000000..3309f4089
--- /dev/null
+++ b/test/get-xrender-format.c
@@ -0,0 +1,104 @@
+/*
+ * Copyright © 2008 Red Hat, Inc.
+ *
+ * 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 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.
+ *
+ * Author: Carl D. Worth <cworth@cworth.org>
+ */
+
+#include "cairo-test.h"
+
+#include "cairo-xlib.h"
+#include "cairo-xlib-xrender.h"
+
+int
+main (void)
+{
+ Display *dpy;
+ XRenderPictFormat *orig_format, *format;
+ cairo_surface_t *surface;
+ Pixmap pixmap;
+ int screen;
+
+ cairo_test_init ("get-xrender-format");
+
+ dpy = XOpenDisplay (NULL);
+ if (! dpy) {
+ cairo_test_log ("Error: Cannot open display: %s.\n",
+ XDisplayName (NULL));
+ cairo_test_fini ();
+ return CAIRO_TEST_UNTESTED;
+ }
+
+ screen = DefaultScreen (dpy);
+
+ cairo_test_log ("Testing with image surface.\n");
+
+ surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, 1, 1);
+
+ format = cairo_xlib_surface_get_xrender_format (surface);
+ if (format != NULL) {
+ cairo_test_log ("Error: expected NULL for image surface\n");
+ return CAIRO_TEST_FAILURE;
+ }
+
+ cairo_surface_destroy (surface);
+
+ cairo_test_log ("Testing with non-xrender xlib surface.\n");
+
+ pixmap = XCreatePixmap (dpy, DefaultRootWindow (dpy),
+ 1, 1, DefaultDepth (dpy, screen));
+ surface = cairo_xlib_surface_create (dpy, pixmap,
+ DefaultVisual (dpy, screen),
+ 1, 1);
+ orig_format = XRenderFindVisualFormat (dpy, DefaultVisual (dpy, screen));
+ format = cairo_xlib_surface_get_xrender_format (surface);
+ if (format != orig_format) {
+ cairo_test_log ("Error: did not receive the same format as XRenderFindVisualFormat\n");
+ return CAIRO_TEST_FAILURE;
+ }
+ cairo_surface_destroy (surface);
+ XFreePixmap (dpy, pixmap);
+
+ cairo_test_log ("Testing with xlib xrender surface.\n");
+
+ orig_format = XRenderFindStandardFormat (dpy, PictStandardARGB32);
+ pixmap = XCreatePixmap (dpy, DefaultRootWindow (dpy),
+ 1, 1, 32);
+ surface = cairo_xlib_surface_create_with_xrender_format (dpy,
+ pixmap,
+ DefaultScreenOfDisplay (dpy),
+ orig_format,
+ 1, 1);
+ format = cairo_xlib_surface_get_xrender_format (surface);
+ if (format != orig_format) {
+ cairo_test_log ("Error: did not receive the same format originally set\n");
+ return CAIRO_TEST_FAILURE;
+ }
+
+ cairo_surface_destroy (surface);
+
+ XCloseDisplay (dpy);
+
+ cairo_test_fini ();
+
+ return CAIRO_TEST_SUCCESS;
+}