X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;f=tools%2Fccanlint%2Ftests%2Fdepends_exist.c;h=76750fb1236f7bab79e7ff2a73412aa74185d919;hb=f243444490e8dcdaa399942b70e72d03005370f7;hp=ff67857f8cdc5a98a89c00e8d948e6e12a6dff87;hpb=60824f8a0f758dc7808eb31cc83434ea78f44ed1;p=ccan diff --git a/tools/ccanlint/tests/depends_exist.c b/tools/ccanlint/tests/depends_exist.c index ff67857f..76750fb1 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->basename, 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,22 +42,42 @@ 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; } /* FIXME: check this is still true once we reduce features. */ static void check_depends_exist(struct manifest *m, - bool keep, unsigned int *timeleft, struct score *score) { 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")) { @@ -56,16 +89,18 @@ static void check_depends_exist(struct manifest *m, } if (safe_mode) - deps = get_safe_ccan_deps(m, m->dir, true); + deps = get_safe_ccan_deps(m, m->dir, "testdepends", true); else - deps = get_deps(m, m->dir, true, - &m->info_file->compiled[COMPILE_NORMAL]); + 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")) { @@ -73,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; } @@ -90,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);