X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;f=tools%2Fccanlint%2Ftests%2Fdepends_exist.c;h=3d50a063a243c857bd79179c21dae0eba118955d;hb=932d65dd6537250e617516749f03a00fea3b34f6;hp=d869cbb7f38cb53a539359e21f8d5f212cfaef07;hpb=1842f55199e6a5da273ca21b6fbe8afa6ecdfe11;p=ccan diff --git a/tools/ccanlint/tests/depends_exist.c b/tools/ccanlint/tests/depends_exist.c index d869cbb7..3d50a063 100644 --- a/tools/ccanlint/tests/depends_exist.c +++ b/tools/ccanlint/tests/depends_exist.c @@ -14,7 +14,20 @@ #include #include -static bool add_dep(struct manifest *m, const char *dep, struct score *score) +static bool have_dep(struct manifest *m, const char *dep) +{ + struct manifest *i; + + list_for_each(&m->deps, i, list) + if (streq(i->modname, dep + strlen("ccan/"))) + return true; + + return false; +} + +static bool add_dep(struct manifest *m, + struct list_head *deplist, + const char *dep, struct score *score) { struct stat st; struct manifest *subm; @@ -29,7 +42,7 @@ static bool add_dep(struct manifest *m, const char *dep, struct score *score) return false; } subm = get_manifest(m, dir); - list_add_tail(&m->deps, &subm->list); + list_add_tail(deplist, &subm->list); return true; } @@ -39,14 +52,35 @@ static void check_depends_exist(struct manifest *m, { unsigned int i; char **deps; - char *updir = talloc_strdup(m, m->dir); - bool needs_tap; - if (strrchr(updir, '/')) - *strrchr(updir, '/') = '\0'; + if (safe_mode) + deps = get_safe_ccan_deps(m, m->dir, "depends", true); + else + deps = get_deps(m, m->dir, "depends", true, + get_or_compile_info); + + for (i = 0; deps[i]; i++) { + if (!strstarts(deps[i], "ccan/")) + continue; + + if (!add_dep(m, &m->deps, deps[i], score)) + return; + } + + score->pass = true; + score->score = score->total; +} + +static void check_test_depends_exist(struct manifest *m, + unsigned int *timeleft, + struct score *score) +{ + unsigned int i; + char **deps; + bool needs_tap; /* We may need libtap for testing, unless we're "tap" */ - if (streq(m->basename, "tap")) { + if (streq(m->modname, "tap")) { needs_tap = false; } else if (list_empty(&m->run_tests) && list_empty(&m->api_tests)) { needs_tap = false; @@ -55,16 +89,18 @@ static void check_depends_exist(struct manifest *m, } if (safe_mode) - deps = get_safe_ccan_deps(m, m->dir, "depends", true); + deps = get_safe_ccan_deps(m, m->dir, "testdepends", true); else - deps = get_deps(m, m->dir, "depends", true, + deps = get_deps(m, m->dir, "testdepends", true, get_or_compile_info); for (i = 0; deps[i]; i++) { if (!strstarts(deps[i], "ccan/")) continue; - if (!add_dep(m, deps[i], score)) + /* Don't add dependency twice: we can only be on one list! */ + if (!have_dep(m, deps[i]) + && !add_dep(m, &m->test_deps, deps[i], score)) return; if (streq(deps[i], "ccan/tap")) { @@ -72,7 +108,8 @@ static void check_depends_exist(struct manifest *m, } } - if (needs_tap && !add_dep(m, "ccan/tap", score)) { + if (needs_tap && !have_dep(m, "ccan/tap") + && !add_dep(m, &m->test_deps, "ccan/tap", score)) { return; } @@ -89,3 +126,13 @@ struct ccanlint depends_exist = { }; REGISTER_TEST(depends_exist); + +struct ccanlint test_depends_exist = { + .key = "test_depends_exist", + .name = "Module's CCAN test dependencies can be found", + .compulsory = false, + .check = check_test_depends_exist, + .needs = "depends_exist" +}; + +REGISTER_TEST(test_depends_exist);