mirror of
https://gitlab.freedesktop.org/cairo/cairo.git
synced 2026-05-18 05:58:08 +02:00
In order to run under memfault, the framework is first extended to handle running concurrent tests - i.e. multi-threading. (Not that this is a requirement for memfault, instead it shares a common goal of storing per-test data). To that end all the global data is moved into a per-test context and the targets are adjusted to avoid overlap on shared, global resources (such as output files and frame buffers). In order to preserve the simplicity of the standard draw routines, the context is not passed explicitly as a parameter to the routines, but is instead attached to the cairo_t via the user_data. For the masochist, to enable the tests to be run across multiple threads simply set the environment variable CAIRO_TEST_NUM_THREADS to the desired number. In the long run, we can hope the need for memfault (runtime testing of error paths) will be mitigated by static analysis. A promising candidate for this task would appear to be http://hal.cs.berkeley.edu/cil/.
111 lines
3.4 KiB
C
111 lines
3.4 KiB
C
/*
|
|
* Copyright © 2008 Adrian Johnson
|
|
*
|
|
* 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: Adrian Johnson <ajohnson@redneon.com>
|
|
*/
|
|
|
|
#include "cairo-test.h"
|
|
|
|
static cairo_test_draw_function_t draw;
|
|
|
|
#define CIRCLE_SIZE 10
|
|
#define PAD 2
|
|
#define WIDTH (CIRCLE_SIZE*6.5 + PAD)
|
|
#define HEIGHT (CIRCLE_SIZE*3.5 + PAD)
|
|
|
|
static const cairo_test_t test = {
|
|
"finer-grained-fallbacks",
|
|
"Test that multiple PS/PDF fallback images in various locations are correct",
|
|
WIDTH, HEIGHT,
|
|
draw
|
|
};
|
|
|
|
static void
|
|
draw_circle (cairo_t *cr, double x, double y)
|
|
{
|
|
cairo_save (cr);
|
|
cairo_translate (cr, x, y);
|
|
cairo_arc (cr, 0, 0, CIRCLE_SIZE / 2, 0., 2. * M_PI);
|
|
cairo_fill (cr);
|
|
cairo_restore (cr);
|
|
}
|
|
|
|
static void
|
|
draw_circles (cairo_t *cr)
|
|
{
|
|
draw_circle (cr, 0, -CIRCLE_SIZE*0.1);
|
|
draw_circle (cr, CIRCLE_SIZE*0.4, CIRCLE_SIZE*0.25);
|
|
|
|
draw_circle (cr, CIRCLE_SIZE*2, 0);
|
|
draw_circle (cr, CIRCLE_SIZE*4, 0);
|
|
draw_circle (cr, CIRCLE_SIZE*6, 0);
|
|
}
|
|
|
|
/* For each of circle and fallback_circle we draw:
|
|
* - two overlapping
|
|
* - one isolated
|
|
* - one off the page
|
|
* - one overlapping the edge of the page.
|
|
*
|
|
* We also draw a circle and fallback_circle overlapping each other.
|
|
*
|
|
* Circles are drawn in green. An opaque color and CAIRO_OPERATOR_OVER
|
|
* is used to ensure they will be emitted as a vectors in PS/PDF.
|
|
*
|
|
* Fallback circles are drawn in red. CAIRO_OPERATOR_ADD is used to
|
|
* ensure they will be emitted as a fallback image in PS/PDF.
|
|
*/
|
|
static cairo_test_status_t
|
|
draw (cairo_t *cr, int width, int height)
|
|
{
|
|
cairo_translate (cr, PAD, PAD);
|
|
|
|
/* Draw overlapping circle and fallback circle */
|
|
cairo_set_source_rgb (cr, 0.0, 1.0, 0.0);
|
|
cairo_set_operator (cr, CAIRO_OPERATOR_OVER);
|
|
draw_circle (cr, CIRCLE_SIZE*0.5, CIRCLE_SIZE*1.5);
|
|
|
|
cairo_set_source_rgb (cr, 1.0, 0.0, 0.0);
|
|
cairo_set_operator (cr, CAIRO_OPERATOR_ADD);
|
|
draw_circle (cr, CIRCLE_SIZE*0.75, CIRCLE_SIZE*1.75);
|
|
|
|
/* Draw circles */
|
|
cairo_set_source_rgb (cr, 0.0, 1.0, 0.0);
|
|
cairo_set_operator (cr, CAIRO_OPERATOR_OVER);
|
|
cairo_translate (cr, CIRCLE_SIZE*2.5, CIRCLE_SIZE*0.6);
|
|
draw_circles (cr);
|
|
|
|
/* Draw fallback circles */
|
|
cairo_set_source_rgb (cr, 1.0, 0.0, 0.0);
|
|
cairo_set_operator (cr, CAIRO_OPERATOR_ADD);
|
|
cairo_translate (cr, 0, CIRCLE_SIZE*2);
|
|
draw_circles (cr);
|
|
|
|
return CAIRO_TEST_SUCCESS;
|
|
}
|
|
|
|
int
|
|
main (void)
|
|
{
|
|
return cairo_test (&test);
|
|
}
|