14 #include "CUnit/Basic.h"
17 #include "../postgis_config.h"
139 #define MAX_CUNIT_MSG_LENGTH 256
146 int main(
int argc,
char *argv[])
150 CU_pSuite suite_to_run;
152 CU_pTest test_to_run = NULL;
153 CU_ErrorCode errCode = 0;
154 CU_pTestRegistry registry;
164 if (CUE_SUCCESS != CU_initialize_registry())
166 errCode = CU_get_error();
167 printf(
" Error attempting to initialize registry: %d. See CUError.h for error code list.\n", errCode);
179 CU_basic_set_mode(CU_BRM_VERBOSE);
182 errCode = CU_basic_run_tests();
189 registry = CU_get_registry();
190 for (index = 1; index < argc; index++)
192 suite_name = argv[index];
194 suite_to_run = CU_get_suite_by_name(suite_name, registry);
195 if (NULL == suite_to_run)
198 suite_to_run = registry->pSuite;
199 while (suite_to_run != NULL)
201 test_to_run = CU_get_test_by_name(suite_name, suite_to_run);
202 if (test_to_run != NULL)
205 test_name = suite_name;
206 suite_name = suite_to_run->pName;
209 suite_to_run = suite_to_run->pNext;
212 if (suite_to_run == NULL)
214 printf(
"\n'%s' does not appear to be either a suite name or a test name.\n\n", suite_name);
218 if (test_name != NULL && test_to_run != NULL)
221 printf(
"\nRunning test '%s' in suite '%s'.\n", test_name, suite_name);
225 errCode = CU_run_test(suite_to_run, test_to_run);
226 if (errCode != CUE_SUCCESS)
228 printf(
" Error attempting to run tests: %d. See CUError.h for error code list.\n", errCode);
232 num_run = CU_get_number_of_asserts();
233 num_failed = CU_get_number_of_failures();
234 printf(
"\n %s - asserts - %3d passed, %3d failed, %3d total.\n\n",
235 (0 == num_failed ?
"PASSED" :
"FAILED"), (num_run - num_failed), num_failed, num_run);
241 printf(
"\nRunning all tests in suite '%s'.\n", suite_name);
245 errCode = CU_run_suite(suite_to_run);
246 if (errCode != CUE_SUCCESS)
248 printf(
" Error attempting to run tests: %d. See CUError.h for error code list.\n", errCode);
252 num_run = CU_get_number_of_tests_run();
253 num_failed = CU_get_number_of_tests_failed();
254 printf(
"\n %s - tests - %3d passed, %3d failed, %3d total.\n",
255 (0 == num_failed ?
"PASSED" :
"FAILED"), (num_run - num_failed), num_failed, num_run);
256 num_run = CU_get_number_of_asserts();
257 num_failed = CU_get_number_of_failures();
258 printf(
" - asserts - %3d passed, %3d failed, %3d total.\n\n",
259 (num_run - num_failed), num_failed, num_run);
265 CU_basic_show_failures(CU_get_failure_list());
268 num_failed = CU_get_number_of_failures();
269 CU_cleanup_registry();
292 fprintf(stderr,
"NOTICE: %s\n", buf);
301 fprintf(stderr,
"DEBUG%d: %s\n", level, buf);
322 LWGEOM* observed = transfn(input);
void sfcgal_suite_setup(void)
void out_x3d_suite_setup(void)
void in_encoded_polyline_suite_setup(void)
void clip_by_rect_suite_setup()
int main(int argc, char *argv[])
#define MAX_CUNIT_MSG_LENGTH
void out_encoded_polyline_suite_setup(void)
void geos_cluster_suite_setup(void)
void boundary_suite_setup()
void force_sfs_suite_setup(void)
void buildarea_suite_setup()
static void cu_debuglogger(int level, const char *fmt, va_list ap)
void unionfind_suite_setup(void)
void do_fn_test(LWGEOM *(*transfn)(LWGEOM *), char *input_wkt, char *expected_wkt)
void wkt_out_suite_setup(void)
void twkb_in_suite_setup(void)
void homogenize_suite_setup(void)
void misc_suite_setup(void)
void gserialized2_suite_setup(void)
void measures_suite_setup(void)
void wrapx_suite_setup(void)
void cu_error_msg_reset()
PG_SuiteSetup setupfuncs[]
void iterator_suite_setup(void)
void triangulate_suite_setup(void)
void stringbuffer_suite_setup(void)
void chaikin_suite_setup(void)
void split_suite_setup(void)
void tree_suite_setup(void)
void out_gml_suite_setup(void)
static void cu_errorreporter(const char *fmt, va_list ap)
CUnit error handler Log message in a global var instead of printing in stderr.
void twkb_out_suite_setup(void)
void out_svg_suite_setup(void)
void geos_suite_setup(void)
void effectivearea_suite_setup(void)
void in_geojson_suite_setup(void)
void wkb_in_suite_setup(void)
char cu_error_msg[MAX_CUNIT_ERROR_LENGTH+1]
void wkb_out_suite_setup(void)
void geodetic_suite_setup(void)
void ptarray_suite_setup(void)
void node_suite_setup(void)
void out_kml_suite_setup(void)
void surface_suite_setup(void)
void varint_suite_setup(void)
void out_geojson_suite_setup(void)
void wkt_in_suite_setup(void)
void algorithms_suite_setup()
void minimum_bounding_circle_suite_setup(void)
void gserialized1_suite_setup(void)
void filterm_suite_setup(void)
static void cu_noticereporter(const char *fmt, va_list ap)
void force_dims_suite_setup(void)
void lwstroke_suite_setup(void)
void(* PG_SuiteSetup)(void)
#define MAX_CUNIT_ERROR_LENGTH
#define ASSERT_LWGEOM_EQUAL(o, e)
void(*) typedef void(*) voi lwgeom_set_handlers)(lwallocator allocator, lwreallocator reallocator, lwfreeor freeor, lwreporter errorreporter, lwreporter noticereporter)
Install custom memory management and error handling functions you want your application to use.
void lwgeom_free(LWGEOM *geom)
#define LW_PARSER_CHECK_NONE
void lwgeom_set_debuglogger(lwdebuglogger debuglogger)
LWGEOM * lwgeom_from_wkt(const char *wkt, const char check)