From 6c1d3e2739e97674069862ec7369677d25e80312 Mon Sep 17 00:00:00 2001 From: Rusty Russell Date: Tue, 1 Mar 2011 17:47:49 +1030 Subject: [PATCH] ccanlint: run tests with reduced-feature config.h --- tools/ccanlint/tests/reduce_features.c | 2 ++ tools/ccanlint/tests/tests_compile.c | 50 +++++++++++++++++++++----- tools/ccanlint/tests/tests_pass.c | 10 ++++++ 3 files changed, 53 insertions(+), 9 deletions(-) diff --git a/tools/ccanlint/tests/reduce_features.c b/tools/ccanlint/tests/reduce_features.c index 2a389ce5..aaeba751 100644 --- a/tools/ccanlint/tests/reduce_features.c +++ b/tools/ccanlint/tests/reduce_features.c @@ -174,6 +174,8 @@ struct ccanlint reduce_features = { .name = "Produce config.h with reduced features", .can_run = can_run, .check = do_reduce_features, + /* We only want to compile up versions with reduced featuress once + * objects for normal tests are built. */ .needs = "tests_compile" }; REGISTER_TEST(reduce_features); diff --git a/tools/ccanlint/tests/tests_compile.c b/tools/ccanlint/tests/tests_compile.c index 13a8f0db..9e6d5dc7 100644 --- a/tools/ccanlint/tests/tests_compile.c +++ b/tools/ccanlint/tests/tests_compile.c @@ -14,6 +14,7 @@ #include #include #include +#include "reduce_features.h" static const char *can_build(struct manifest *m) { @@ -62,12 +63,13 @@ static char *lib_list(const struct manifest *m) static bool compile(const void *ctx, struct manifest *m, struct ccan_file *file, + const char *flags, bool fail, bool link_with_module, bool keep, char **output) { - char *f = talloc_asprintf(ctx, "%s%s", - fail ? "-DFAIL " : "", cflags); + char *f = talloc_asprintf(ctx, "%s%s%s", + flags, fail ? "-DFAIL " : "", cflags); file->compiled = maybe_temp_file(ctx, "", keep, file->fullname); if (!compile_and_link(ctx, file->fullname, ccan_dir, @@ -79,9 +81,8 @@ static bool compile(const void *ctx, return true; } -static void do_compile_tests(struct manifest *m, - bool keep, - unsigned int *timeleft, struct score *score) +static void compile_tests(struct manifest *m, bool keep, + struct score *score, const char *incl) { char *cmdout; struct ccan_file *i; @@ -90,8 +91,8 @@ static void do_compile_tests(struct manifest *m, 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)) { + if (!compile(score, m, i, incl, false, + list == &m->api_tests, keep, &cmdout)) { score_file_error(score, i, 0, "Compile failed:\n%s", cmdout); @@ -111,7 +112,7 @@ static void do_compile_tests(struct manifest *m, /* For historical reasons, "fail" often means "gives warnings" */ list_for_each(&m->compile_fail_tests, i, list) { - if (!compile(score, m, i, false, false, false, &cmdout)) { + if (!compile(score, m, i, incl, false, false, false, &cmdout)) { score_file_error(score, i, 0, "Compile without -DFAIL failed:\n%s", cmdout); @@ -124,7 +125,7 @@ static void do_compile_tests(struct manifest *m, cmdout); return; } - if (compile(score, m, i, true, false, false, &cmdout) + if (compile(score, m, i, incl, true, false, false, &cmdout) && streq(cmdout, "")) { score_file_error(score, i, 0, "Compiled successfully with -DFAIL?"); @@ -137,6 +138,13 @@ static void do_compile_tests(struct manifest *m, score->score = 1 + !warnings; } +static void do_compile_tests(struct manifest *m, + bool keep, + unsigned int *timeleft, struct score *score) +{ + return compile_tests(m, keep, score, ""); +} + struct ccanlint tests_compile = { .key = "tests_compile", .name = "Module tests compile", @@ -146,3 +154,27 @@ struct ccanlint tests_compile = { }; REGISTER_TEST(tests_compile); + +static const char *features_reduced(struct manifest *m) +{ + if (features_were_reduced) + return NULL; + return "No features to turn off"; +} + +static void do_compile_tests_without_features(struct manifest *m, + bool keep, + unsigned int *timeleft, + struct score *score) +{ + return compile_tests(m, keep, score, "-I. "); +} + +struct ccanlint tests_compile_without_features = { + .key = "tests_compile_without_features", + .name = "Module tests compile (without features)", + .check = do_compile_tests_without_features, + .can_run = features_reduced, + .needs = "reduce_features" +}; +REGISTER_TEST(tests_compile_without_features); diff --git a/tools/ccanlint/tests/tests_pass.c b/tools/ccanlint/tests/tests_pass.c index 1d3c0182..f30fed66 100644 --- a/tools/ccanlint/tests/tests_pass.c +++ b/tools/ccanlint/tests/tests_pass.c @@ -75,3 +75,13 @@ struct ccanlint tests_pass = { }; REGISTER_TEST(tests_pass); + +struct ccanlint tests_pass_without_features = { + .key = "tests_pass_without_features", + .name = "Module's run and api tests pass (without features)", + .check = do_run_tests, + .handle = run_under_debugger, + .needs = "tests_pass reduce_features" +}; + +REGISTER_TEST(tests_pass_without_features); -- 2.39.2