Skip to content

Commit 4e281f6

Browse files
committed
basic/conf-files: extend conf_files_list() to list unsuffixed files
5dd11ab did a similar change for conf_files_list_strv(). Here we do the same for conf_files_list() and conf_files_list_nulstr(). No change for existing users. Tests are added.
1 parent cf55fc1 commit 4e281f6

File tree

2 files changed

+22
-4
lines changed

2 files changed

+22
-4
lines changed

src/basic/conf-files.c

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -137,7 +137,6 @@ int conf_files_list(char ***strv, const char *suffix, const char *root, const ch
137137
va_list ap;
138138

139139
assert(strv);
140-
assert(suffix);
141140

142141
va_start(ap, dir);
143142
dirs = strv_new_ap(dir, ap);
@@ -153,7 +152,6 @@ int conf_files_list_nulstr(char ***strv, const char *suffix, const char *root, c
153152
_cleanup_strv_free_ char **dirs = NULL;
154153

155154
assert(strv);
156-
assert(suffix);
157155

158156
dirs = strv_split_nulstr(d);
159157
if (!dirs)

src/test/test-conf-files.c

Lines changed: 22 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -47,13 +47,16 @@ static void setup_test_dir(char *tmp_dir, const char *files, ...) {
4747

4848
static void test_conf_files_list(bool use_root) {
4949
char tmp_dir[] = "/tmp/test-conf-files-XXXXXX";
50-
_cleanup_strv_free_ char **found_files = NULL;
51-
const char *root_dir, *search_1, *search_2, *expect_a, *expect_b;
50+
_cleanup_strv_free_ char **found_files = NULL, **found_files2 = NULL;
51+
const char *root_dir, *search_1, *search_2, *expect_a, *expect_b, *expect_c;
52+
53+
log_debug("/* %s */", __func__);
5254

5355
setup_test_dir(tmp_dir,
5456
"/dir1/a.conf",
5557
"/dir2/a.conf",
5658
"/dir2/b.conf",
59+
"/dir2/c.foo",
5760
NULL);
5861

5962
if (use_root) {
@@ -68,6 +71,9 @@ static void test_conf_files_list(bool use_root) {
6871

6972
expect_a = strjoina(tmp_dir, "/dir1/a.conf");
7073
expect_b = strjoina(tmp_dir, "/dir2/b.conf");
74+
expect_c = strjoina(tmp_dir, "/dir2/c.foo");
75+
76+
log_debug("/* Check when filtered by suffix */");
7177

7278
assert_se(conf_files_list(&found_files, ".conf", root_dir, search_1, search_2, NULL) == 0);
7379
strv_print(found_files);
@@ -77,10 +83,24 @@ static void test_conf_files_list(bool use_root) {
7783
assert_se(streq_ptr(found_files[1], expect_b));
7884
assert_se(found_files[2] == NULL);
7985

86+
log_debug("/* Check when unfiltered */");
87+
assert_se(conf_files_list(&found_files2, NULL, root_dir, search_1, search_2, NULL) == 0);
88+
strv_print(found_files2);
89+
90+
assert_se(found_files2);
91+
assert_se(streq_ptr(found_files2[0], expect_a));
92+
assert_se(streq_ptr(found_files2[1], expect_b));
93+
assert_se(streq_ptr(found_files2[2], expect_c));
94+
assert_se(found_files2[3] == NULL);
95+
8096
assert_se(rm_rf(tmp_dir, REMOVE_ROOT|REMOVE_PHYSICAL) == 0);
8197
}
8298

8399
int main(int argc, char **argv) {
100+
log_set_max_level(LOG_DEBUG);
101+
log_parse_environment();
102+
log_open();
103+
84104
test_conf_files_list(false);
85105
test_conf_files_list(true);
86106
return 0;

0 commit comments

Comments
 (0)