X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Fccanlint%2Ftests%2Fcompile_tests.c;h=4d8686798c0aa12040defb489cd28ebc4d7acd1b;hp=062912d427ea3bb49e2b22a71cca94082c606df3;hb=2926cafb52b9d95646d9dafa877d53f2368d8b2c;hpb=7a163ea2dcafc056fdafc8c71ef011e2bfdbeb65 diff --git a/tools/ccanlint/tests/compile_tests.c b/tools/ccanlint/tests/compile_tests.c index 062912d4..4d868679 100644 --- a/tools/ccanlint/tests/compile_tests.c +++ b/tools/ccanlint/tests/compile_tests.c @@ -2,6 +2,7 @@ #include #include #include +#include #include #include #include @@ -21,16 +22,12 @@ static const char *can_build(struct manifest *m) return NULL; } +/* FIXME: Merge this into one place. */ static char *obj_list(const struct manifest *m, bool link_with_module) { - char *list; + char *list = talloc_strdup(m, ""); struct ccan_file *i; - - /* We expect to be linked with tap, unless that's us. */ - if (!streq(m->basename, "tap")) - list = talloc_asprintf(m, "%s/ccan/tap.o", ccan_dir); - else - list = talloc_strdup(m, ""); + struct manifest *subm; /* Objects from any other C files. */ list_for_each(&m->other_test_c_files, i, list) @@ -42,9 +39,10 @@ static char *obj_list(const struct manifest *m, bool link_with_module) list = talloc_asprintf_append(list, " %s", i->compiled); /* Other ccan modules. */ - list_for_each(&m->dep_dirs, i, list) { - if (i->compiled) - list = talloc_asprintf_append(list, " %s", i->compiled); + list_for_each(&m->deps, subm, list) { + if (subm->compiled) + list = talloc_asprintf_append(list, " %s", + subm->compiled); } return list; @@ -53,7 +51,7 @@ static char *obj_list(const struct manifest *m, bool link_with_module) static char *lib_list(const struct manifest *m) { unsigned int i, num; - char **libs = get_libs(m, ".", &num, &m->info_file->compiled); + char **libs = get_libs(m, m->dir, &num, &m->info_file->compiled); char *ret = talloc_strdup(m, ""); for (i = 0; i < num; i++) @@ -61,25 +59,22 @@ static char *lib_list(const struct manifest *m) return ret; } -static char *compile(const void *ctx, - struct manifest *m, - struct ccan_file *file, - bool fail, - bool link_with_module, - bool keep) +static bool compile(const void *ctx, + struct manifest *m, + struct ccan_file *file, + bool fail, + bool link_with_module, + bool keep, char **output) { - char *errmsg; - file->compiled = maybe_temp_file(ctx, "", keep, file->fullname); - errmsg = compile_and_link(ctx, file->fullname, ccan_dir, - obj_list(m, link_with_module), - fail ? "-DFAIL" : "", - lib_list(m), file->compiled); - if (errmsg) { + if (!compile_and_link(ctx, file->fullname, ccan_dir, + obj_list(m, link_with_module), + fail ? "-DFAIL" : "", + lib_list(m), file->compiled, output)) { talloc_free(file->compiled); - return errmsg; + return false; } - return NULL; + return true; } static void do_compile_tests(struct manifest *m, @@ -88,44 +83,42 @@ static void do_compile_tests(struct manifest *m, { char *cmdout; struct ccan_file *i; - - list_for_each(&m->compile_ok_tests, i, list) { - cmdout = compile(score, m, i, false, false, keep); - if (cmdout) { - score->error = "Failed to compile tests"; - score_file_error(score, i, 0, cmdout); - } - } - - list_for_each(&m->run_tests, i, list) { - cmdout = compile(score, m, i, false, false, keep); - if (cmdout) { - score->error = "Failed to compile tests"; - score_file_error(score, i, 0, cmdout); - } - } - - list_for_each(&m->api_tests, i, list) { - cmdout = compile(score, m, i, false, true, keep); - if (cmdout) { - score->error = "Failed to compile tests"; - score_file_error(score, i, 0, cmdout); + struct list_head *list; + bool errors = false, warnings = false; + + foreach_ptr(list, &m->compile_ok_tests, &m->run_tests, &m->api_tests) { + list_for_each(list, i, list) { + if (!compile(score, m, i, false, list == &m->api_tests, + keep, &cmdout)) { + score->error = "Failed to compile tests"; + score_file_error(score, i, 0, cmdout); + errors = true; + } else if (!streq(cmdout, "")) { + score->error = "Test compiled with warnings"; + score_file_error(score, i, 0, cmdout); + warnings = true; + } } } /* The compile fail tests are a bit weird, handle them separately */ - if (score->error) + if (errors) return; + /* For historical reasons, "fail" often means "gives warnings" */ list_for_each(&m->compile_fail_tests, i, list) { - cmdout = compile(score, m, i, false, false, false); - if (cmdout) { + if (!compile(score, m, i, false, false, false, &cmdout)) { score->error = "Failed to compile without -DFAIL"; score_file_error(score, i, 0, cmdout); return; } - cmdout = compile(score, m, i, true, false, false); - if (!cmdout) { + if (!streq(cmdout, "")) { + score->error = "Compile with warnigns without -DFAIL"; + score_file_error(score, i, 0, cmdout); + return; + } + if (compile(score, m, i, true, false, false, &cmdout) + && streq(cmdout, "")) { score->error = "Compiled successfully with -DFAIL?"; score_file_error(score, i, 0, NULL); return; @@ -133,14 +126,16 @@ static void do_compile_tests(struct manifest *m, } score->pass = true; - score->score = score->total; + score->total = 2; + score->score = 1 + !warnings; } -struct ccanlint compile_tests = { - .key = "compile-tests", +struct ccanlint tests_compile = { + .key = "tests_compile", .name = "Module tests compile", .check = do_compile_tests, .can_run = can_build, + .needs = "tests_helpers_compile objects_build" }; -REGISTER_TEST(compile_tests, &compile_test_helpers, &build_objs, NULL); +REGISTER_TEST(tests_compile);