diff options
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/test-cgroup-mask.c | 8 | ||||
| -rw-r--r-- | src/test/test-engine.c | 7 | ||||
| -rw-r--r-- | src/test/test-execute.c | 8 | ||||
| -rw-r--r-- | src/test/test-install-root.c | 54 | ||||
| -rw-r--r-- | src/test/test-path-lookup.c | 40 | ||||
| -rw-r--r-- | src/test/test-path.c | 10 | ||||
| -rw-r--r-- | src/test/test-rbtree.c | 362 | ||||
| -rw-r--r-- | src/test/test-sched-prio.c | 7 | ||||
| -rw-r--r-- | src/test/test-unit-file.c | 7 | ||||
| -rw-r--r-- | src/test/test-unit-name.c | 2 | 
10 files changed, 109 insertions, 396 deletions
| diff --git a/src/test/test-cgroup-mask.c b/src/test/test-cgroup-mask.c index ad15075a5b..4eb8fcd773 100644 --- a/src/test/test-cgroup-mask.c +++ b/src/test/test-cgroup-mask.c @@ -21,7 +21,9 @@  #include "macro.h"  #include "manager.h" +#include "rm-rf.h"  #include "test-helper.h" +#include "tests.h"  #include "unit.h"  static int test_cgroup_mask(void) { @@ -33,7 +35,7 @@ static int test_cgroup_mask(void) {          /* Prepare the manager. */          assert_se(set_unit_path(TEST_DIR) >= 0); -        r = manager_new(MANAGER_USER, true, &m); +        r = manager_new(UNIT_FILE_USER, true, &m);          if (r == -EPERM || r == -EACCES) {                  puts("manager_new: Permission denied. Skipping test.");                  return EXIT_TEST_SKIP; @@ -107,7 +109,11 @@ static int test_cgroup_mask(void) {  }  int main(int argc, char* argv[]) { +        _cleanup_(rm_rf_and_freep) char *runtime_dir = NULL;          int rc = 0; + +        assert_se(runtime_dir = setup_fake_runtime_dir());          TEST_REQ_RUNNING_SYSTEMD(rc = test_cgroup_mask()); +          return rc;  } diff --git a/src/test/test-engine.c b/src/test/test-engine.c index ca66f5b684..361d1e7b0b 100644 --- a/src/test/test-engine.c +++ b/src/test/test-engine.c @@ -23,9 +23,12 @@  #include "bus-util.h"  #include "manager.h" +#include "rm-rf.h"  #include "test-helper.h" +#include "tests.h"  int main(int argc, char *argv[]) { +        _cleanup_(rm_rf_and_freep) char *runtime_dir = NULL;          _cleanup_(sd_bus_error_free) sd_bus_error err = SD_BUS_ERROR_NULL;          Manager *m = NULL;          Unit *a = NULL, *b = NULL, *c = NULL, *d = NULL, *e = NULL, *g = NULL, *h = NULL; @@ -34,9 +37,11 @@ int main(int argc, char *argv[]) {          Job *j;          int r; +        assert_se(runtime_dir = setup_fake_runtime_dir()); +          /* prepare the test */          assert_se(set_unit_path(TEST_DIR) >= 0); -        r = manager_new(MANAGER_USER, true, &m); +        r = manager_new(UNIT_FILE_USER, true, &m);          if (MANAGER_SKIP_TEST(r)) {                  printf("Skipping test: manager_new: %s\n", strerror(-r));                  return EXIT_TEST_SKIP; diff --git a/src/test/test-execute.c b/src/test/test-execute.c index 901cc44af6..77ef4e8b2a 100644 --- a/src/test/test-execute.c +++ b/src/test/test-execute.c @@ -291,14 +291,14 @@ static void test_exec_spec_interpolation(Manager *m) {          test(m, "exec-spec-interpolation.service", 0, CLD_EXITED);  } -static int run_tests(ManagerRunningAs running_as, test_function_t *tests) { +static int run_tests(UnitFileScope scope, test_function_t *tests) {          test_function_t *test = NULL;          Manager *m = NULL;          int r;          assert_se(tests); -        r = manager_new(running_as, true, &m); +        r = manager_new(scope, true, &m);          if (MANAGER_SKIP_TEST(r)) {                  printf("Skipping test: manager_new: %s\n", strerror(-r));                  return EXIT_TEST_SKIP; @@ -366,9 +366,9 @@ int main(int argc, char *argv[]) {          assert_se(unsetenv("VAR2") == 0);          assert_se(unsetenv("VAR3") == 0); -        r = run_tests(MANAGER_USER, user_tests); +        r = run_tests(UNIT_FILE_USER, user_tests);          if (r != 0)                  return r; -        return run_tests(MANAGER_SYSTEM, system_tests); +        return run_tests(UNIT_FILE_SYSTEM, system_tests);  } diff --git a/src/test/test-install-root.c b/src/test/test-install-root.c index cd250ca7b8..2138655e29 100644 --- a/src/test/test-install-root.c +++ b/src/test/test-install-root.c @@ -30,6 +30,8 @@ static void test_basic_mask_and_enable(const char *root) {          UnitFileChange *changes = NULL;          unsigned n_changes = 0; +        log_set_max_level(LOG_DEBUG); +          assert_se(unit_file_get_state(UNIT_FILE_SYSTEM, root, "a.service", NULL) == -ENOENT);          assert_se(unit_file_get_state(UNIT_FILE_SYSTEM, root, "b.service", NULL) == -ENOENT);          assert_se(unit_file_get_state(UNIT_FILE_SYSTEM, root, "c.service", NULL) == -ENOENT); @@ -628,6 +630,57 @@ static void test_preset_and_list(const char *root) {          assert_se(got_yes && got_no);  } +static void test_revert(const char *root) { +        const char *p; +        UnitFileState state; +        UnitFileChange *changes = NULL; +        unsigned n_changes = 0; + +        assert(root); + +        assert_se(unit_file_get_state(UNIT_FILE_SYSTEM, root, "xx.service", NULL) == -ENOENT); +        assert_se(unit_file_get_state(UNIT_FILE_SYSTEM, root, "yy.service", NULL) == -ENOENT); + +        p = strjoina(root, "/usr/lib/systemd/system/xx.service"); +        assert_se(write_string_file(p, "# Empty\n", WRITE_STRING_FILE_CREATE) >= 0); + +        assert_se(unit_file_get_state(UNIT_FILE_SYSTEM, root, "xx.service", NULL) >= 0); +        assert_se(unit_file_get_state(UNIT_FILE_SYSTEM, root, "xx.service", &state) >= 0 && state == UNIT_FILE_STATIC); + +        /* Initially there's nothing to revert */ +        assert_se(unit_file_revert(UNIT_FILE_SYSTEM, root, STRV_MAKE("xx.service"), &changes, &n_changes) >= 0); +        assert_se(n_changes == 0); +        unit_file_changes_free(changes, n_changes); +        changes = NULL; n_changes = 0; + +        p = strjoina(root, SYSTEM_CONFIG_UNIT_PATH"/xx.service"); +        assert_se(write_string_file(p, "# Empty override\n", WRITE_STRING_FILE_CREATE) >= 0); + +        /* Revert the override file */ +        assert_se(unit_file_revert(UNIT_FILE_SYSTEM, root, STRV_MAKE("xx.service"), &changes, &n_changes) >= 0); +        assert_se(n_changes == 1); +        assert_se(changes[0].type == UNIT_FILE_UNLINK); +        assert_se(streq(changes[0].path, p)); +        unit_file_changes_free(changes, n_changes); +        changes = NULL; n_changes = 0; + +        p = strjoina(root, SYSTEM_CONFIG_UNIT_PATH"/xx.service.d/dropin.conf"); +        assert_se(mkdir_parents(p, 0755) >= 0); +        assert_se(write_string_file(p, "# Empty dropin\n", WRITE_STRING_FILE_CREATE) >= 0); + +        /* Revert the dropin file */ +        assert_se(unit_file_revert(UNIT_FILE_SYSTEM, root, STRV_MAKE("xx.service"), &changes, &n_changes) >= 0); +        assert_se(n_changes == 2); +        assert_se(changes[0].type == UNIT_FILE_UNLINK); +        assert_se(streq(changes[0].path, p)); + +        p = strjoina(root, SYSTEM_CONFIG_UNIT_PATH"/xx.service.d"); +        assert_se(changes[1].type == UNIT_FILE_UNLINK); +        assert_se(streq(changes[1].path, p)); +        unit_file_changes_free(changes, n_changes); +        changes = NULL; n_changes = 0; +} +  int main(int argc, char *argv[]) {          char root[] = "/tmp/rootXXXXXX";          const char *p; @@ -656,6 +709,7 @@ int main(int argc, char *argv[]) {          test_template_enable(root);          test_indirect(root);          test_preset_and_list(root); +        test_revert(root);          assert_se(rm_rf(root, REMOVE_ROOT|REMOVE_PHYSICAL) >= 0); diff --git a/src/test/test-path-lookup.c b/src/test/test-path-lookup.c index 268da002a9..096326d176 100644 --- a/src/test/test-path-lookup.c +++ b/src/test/test-path-lookup.c @@ -26,41 +26,38 @@  #include "string-util.h"  #include "strv.h" -static void test_paths(ManagerRunningAs running_as, bool personal) { +static void test_paths(UnitFileScope scope) {          char template[] = "/tmp/test-path-lookup.XXXXXXX";          _cleanup_lookup_paths_free_ LookupPaths lp_without_env = {};          _cleanup_lookup_paths_free_ LookupPaths lp_with_env = {}; -        char *exists, *not, *systemd_unit_path; +        char *systemd_unit_path;          assert_se(mkdtemp(template)); -        exists = strjoina(template, "/exists"); -        assert_se(mkdir(exists, 0755) == 0); -        not = strjoina(template, "/not");          assert_se(unsetenv("SYSTEMD_UNIT_PATH") == 0); -        assert_se(lookup_paths_init(&lp_without_env, running_as, personal, NULL, exists, not, not) == 0); - -        assert_se(!strv_isempty(lp_without_env.unit_path)); -        assert_se(strv_contains(lp_without_env.unit_path, exists)); -        assert_se(strv_contains(lp_without_env.unit_path, not)); +        assert_se(lookup_paths_init(&lp_without_env, scope, 0, NULL) >= 0); +        assert_se(!strv_isempty(lp_without_env.search_path)); +        assert_se(lookup_paths_reduce(&lp_without_env) >= 0);          systemd_unit_path = strjoina(template, "/systemd-unit-path");          assert_se(setenv("SYSTEMD_UNIT_PATH", systemd_unit_path, 1) == 0); -        assert_se(lookup_paths_init(&lp_with_env, running_as, personal, NULL, exists, not, not) == 0); -        assert_se(strv_length(lp_with_env.unit_path) == 1); -        assert_se(streq(lp_with_env.unit_path[0], systemd_unit_path)); +        assert_se(lookup_paths_init(&lp_with_env, scope, 0, NULL) == 0); +        assert_se(strv_length(lp_with_env.search_path) == 1); +        assert_se(streq(lp_with_env.search_path[0], systemd_unit_path)); +        assert_se(lookup_paths_reduce(&lp_with_env) >= 0); +        assert_se(strv_length(lp_with_env.search_path) == 0);          assert_se(rm_rf(template, REMOVE_ROOT|REMOVE_PHYSICAL) >= 0);  } -static void print_generator_paths(ManagerRunningAs running_as) { +static void print_generator_binary_paths(UnitFileScope scope) {          _cleanup_strv_free_ char **paths;          char **dir; -        log_info("Generators dirs (%s):", running_as == MANAGER_SYSTEM ? "system" : "user"); +        log_info("Generators dirs (%s):", scope == UNIT_FILE_SYSTEM ? "system" : "user"); -        paths = generator_paths(running_as); +        paths = generator_binary_paths(scope);          STRV_FOREACH(dir, paths)                  log_info("        %s", *dir);  } @@ -70,13 +67,12 @@ int main(int argc, char **argv) {          log_parse_environment();          log_open(); -        test_paths(MANAGER_SYSTEM, false); -        test_paths(MANAGER_SYSTEM, true); -        test_paths(MANAGER_USER, false); -        test_paths(MANAGER_USER, true); +        test_paths(UNIT_FILE_SYSTEM); +        test_paths(UNIT_FILE_USER); +        test_paths(UNIT_FILE_GLOBAL); -        print_generator_paths(MANAGER_SYSTEM); -        print_generator_paths(MANAGER_USER); +        print_generator_binary_paths(UNIT_FILE_SYSTEM); +        print_generator_binary_paths(UNIT_FILE_USER);          return EXIT_SUCCESS;  } diff --git a/src/test/test-path.c b/src/test/test-path.c index 1e704a03dc..435cafd83a 100644 --- a/src/test/test-path.c +++ b/src/test/test-path.c @@ -30,6 +30,7 @@  #include "string-util.h"  #include "strv.h"  #include "test-helper.h" +#include "tests.h"  #include "unit.h"  #include "util.h" @@ -44,7 +45,7 @@ static int setup_test(Manager **m) {          assert_se(m); -        r = manager_new(MANAGER_USER, true, &tmp); +        r = manager_new(UNIT_FILE_USER, true, &tmp);          if (MANAGER_SKIP_TEST(r)) {                  printf("Skipping test: manager_new: %s\n", strerror(-r));                  return -EXIT_TEST_SKIP; @@ -243,7 +244,7 @@ static void test_path_makedirectory_directorymode(Manager *m) {  }  int main(int argc, char *argv[]) { -        test_function_t tests[] = { +        static const test_function_t tests[] = {                  test_path_exists,                  test_path_existsglob,                  test_path_changed, @@ -253,12 +254,15 @@ int main(int argc, char *argv[]) {                  test_path_makedirectory_directorymode,                  NULL,          }; -        test_function_t *test = NULL; + +        _cleanup_(rm_rf_and_freep) char *runtime_dir = NULL; +        const test_function_t *test = NULL;          Manager *m = NULL;          log_parse_environment();          log_open(); +        assert_se(runtime_dir = setup_fake_runtime_dir());          assert_se(set_unit_path(TEST_DIR "/test-path/") >= 0);          for (test = tests; test && *test; test++) { diff --git a/src/test/test-rbtree.c b/src/test/test-rbtree.c deleted file mode 100644 index 8ae416c557..0000000000 --- a/src/test/test-rbtree.c +++ /dev/null @@ -1,362 +0,0 @@ -/*** -  This file is part of systemd. See COPYING for details. - -  systemd is free software; you can redistribute it and/or modify it -  under the terms of the GNU Lesser General Public License as published by -  the Free Software Foundation; either version 2.1 of the License, or -  (at your option) any later version. - -  systemd is distributed in the hope that it will be useful, but -  WITHOUT ANY WARRANTY; without even the implied warranty of -  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -  Lesser General Public License for more details. - -  You should have received a copy of the GNU Lesser General Public License -  along with systemd; If not, see <http://www.gnu.org/licenses/>. -***/ - -/* - * Tests for RB-Tree - */ - -#undef NDEBUG -#include <assert.h> -#include <stddef.h> -#include <stdlib.h> -#include "c-rbtree.h" - -/* verify that all API calls are exported */ -static void test_api(void) { -        CRBTree t = {}; -        CRBNode n = C_RBNODE_INIT(n); - -        assert(!c_rbnode_is_linked(&n)); - -        /* init, is_linked, add, remove, remove_init */ - -        c_rbtree_add(&t, NULL, &t.root, &n); -        assert(c_rbnode_is_linked(&n)); - -        c_rbtree_remove_init(&t, &n); -        assert(!c_rbnode_is_linked(&n)); - -        c_rbtree_add(&t, NULL, &t.root, &n); -        assert(c_rbnode_is_linked(&n)); - -        c_rbtree_remove(&t, &n); -        assert(c_rbnode_is_linked(&n)); /* @n wasn't touched */ - -        c_rbnode_init(&n); -        assert(!c_rbnode_is_linked(&n)); - -        /* first, last, leftmost, rightmost, next, prev */ - -        assert(!c_rbtree_first(&t)); -        assert(!c_rbtree_last(&t)); -        assert(&n == c_rbnode_leftmost(&n)); -        assert(&n == c_rbnode_rightmost(&n)); -        assert(!c_rbnode_next(&n)); -        assert(!c_rbnode_prev(&n)); -} - -/* copied from c-rbtree.c, relies on internal representation */ -static inline _Bool c_rbnode_is_red(CRBNode *n) { -        return !((unsigned long)n->__parent_and_color & 1UL); -} - -/* copied from c-rbtree.c, relies on internal representation */ -static inline _Bool c_rbnode_is_black(CRBNode *n) { -        return !!((unsigned long)n->__parent_and_color & 1UL); -} - -static size_t validate(CRBTree *t) { -        unsigned int i_black, n_black; -        CRBNode *n, *p, *o; -        size_t count = 0; - -        assert(t); -        assert(!t->root || c_rbnode_is_black(t->root)); - -        /* traverse to left-most child, count black nodes */ -        i_black = 0; -        n = t->root; -        while (n && n->left) { -                if (c_rbnode_is_black(n)) -                        ++i_black; -                n = n->left; -        } -        n_black = i_black; - -        /* -         * Traverse tree and verify correctness: -         *  1) A node is either red or black -         *  2) The root is black -         *  3) All leaves are black -         *  4) Every red node must have two black child nodes -         *  5) Every path to a leaf contains the same number of black nodes -         * -         * Note that NULL nodes are considered black, which is why we don't -         * check for 3). -         */ -        o = NULL; -        while (n) { -                ++count; - -                /* verify natural order */ -                assert(n > o); -                o = n; - -                /* verify consistency */ -                assert(!n->right || c_rbnode_parent(n->right) == n); -                assert(!n->left || c_rbnode_parent(n->left) == n); - -                /* verify 2) */ -                if (!c_rbnode_parent(n)) -                        assert(c_rbnode_is_black(n)); - -                if (c_rbnode_is_red(n)) { -                        /* verify 4) */ -                        assert(!n->left || c_rbnode_is_black(n->left)); -                        assert(!n->right || c_rbnode_is_black(n->right)); -                } else { -                        /* verify 1) */ -                        assert(c_rbnode_is_black(n)); -                } - -                /* verify 5) */ -                if (!n->left && !n->right) -                        assert(i_black == n_black); - -                /* get next node */ -                if (n->right) { -                        n = n->right; -                        if (c_rbnode_is_black(n)) -                                ++i_black; - -                        while (n->left) { -                                n = n->left; -                                if (c_rbnode_is_black(n)) -                                        ++i_black; -                        } -                } else { -                        while ((p = c_rbnode_parent(n)) && n == p->right) { -                                n = p; -                                if (c_rbnode_is_black(p->right)) -                                        --i_black; -                        } - -                        n = p; -                        if (p && c_rbnode_is_black(p->left)) -                                --i_black; -                } -        } - -        return count; -} - -static void insert(CRBTree *t, CRBNode *n) { -        CRBNode **i, *p; - -        assert(t); -        assert(n); -        assert(!c_rbnode_is_linked(n)); - -        i = &t->root; -        p = NULL; -        while (*i) { -                p = *i; -                if (n < *i) { -                        i = &(*i)->left; -                } else { -                        assert(n > *i); -                        i = &(*i)->right; -                } -        } - -        c_rbtree_add(t, p, i, n); -} - -static void shuffle(void **nodes, size_t n_memb) { -        unsigned int i, j; -        void *t; - -        for (i = 0; i < n_memb; ++i) { -                j = rand() % n_memb; -                t = nodes[j]; -                nodes[j] = nodes[i]; -                nodes[i] = t; -        } -} - -/* run some pseudo-random tests on the tree */ -static void test_shuffle(void) { -        CRBNode *nodes[256]; -        CRBTree t = {}; -        unsigned int i, j; -        size_t n; - -        /* allocate and initialize all nodes */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) { -                nodes[i] = malloc(sizeof(*nodes[i])); -                assert(nodes[i]); -                c_rbnode_init(nodes[i]); -        } - -        /* shuffle nodes and validate *empty* tree */ -        shuffle((void **)nodes, sizeof(nodes) / sizeof(*nodes)); -        n = validate(&t); -        assert(n == 0); - -        /* add all nodes and validate after each insertion */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) { -                insert(&t, nodes[i]); -                n = validate(&t); -                assert(n == i + 1); -        } - -        /* shuffle nodes again */ -        shuffle((void **)nodes, sizeof(nodes) / sizeof(*nodes)); - -        /* remove all nodes (in different order) and validate on each round */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) { -                c_rbtree_remove(&t, nodes[i]); -                n = validate(&t); -                assert(n == sizeof(nodes) / sizeof(*nodes) - i - 1); -                c_rbnode_init(nodes[i]); -        } - -        /* shuffle nodes and validate *empty* tree again */ -        shuffle((void **)nodes, sizeof(nodes) / sizeof(*nodes)); -        n = validate(&t); -        assert(n == 0); - -        /* add all nodes again */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) { -                insert(&t, nodes[i]); -                n = validate(&t); -                assert(n == i + 1); -        } - -        /* 4 times, remove half of the nodes and add them again */ -        for (j = 0; j < 4; ++j) { -                /* shuffle nodes again */ -                shuffle((void **)nodes, sizeof(nodes) / sizeof(*nodes)); - -                /* remove half of the nodes */ -                for (i = 0; i < sizeof(nodes) / sizeof(*nodes) / 2; ++i) { -                        c_rbtree_remove(&t, nodes[i]); -                        n = validate(&t); -                        assert(n == sizeof(nodes) / sizeof(*nodes) - i - 1); -                        c_rbnode_init(nodes[i]); -                } - -                /* shuffle the removed half */ -                shuffle((void **)nodes, sizeof(nodes) / sizeof(*nodes) / 2); - -                /* add the removed half again */ -                for (i = 0; i < sizeof(nodes) / sizeof(*nodes) / 2; ++i) { -                        insert(&t, nodes[i]); -                        n = validate(&t); -                        assert(n == sizeof(nodes) / sizeof(*nodes) / 2 + i + 1); -                } -        } - -        /* shuffle nodes again */ -        shuffle((void **)nodes, sizeof(nodes) / sizeof(*nodes)); - -        /* remove all */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) { -                c_rbtree_remove(&t, nodes[i]); -                n = validate(&t); -                assert(n == sizeof(nodes) / sizeof(*nodes) - i - 1); -                c_rbnode_init(nodes[i]); -        } - -        /* free nodes again */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) -                free(nodes[i]); -} - -typedef struct { -        unsigned long key; -        CRBNode rb; -} Node; - -#define node_from_rb(_rb) ((Node *)((char *)(_rb) - offsetof(Node, rb))) - -static int compare(CRBTree *t, void *k, CRBNode *n) { -        unsigned long key = (unsigned long)k; -        Node *node = node_from_rb(n); - -        return (key < node->key) ? -1 : (key > node->key) ? 1 : 0; -} - -/* run tests against the c_rbtree_find*() helpers */ -static void test_map(void) { -        CRBNode **slot, *p; -        CRBTree t = {}; -        Node *nodes[2048]; -        unsigned long i; - -        /* allocate and initialize all nodes */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) { -                nodes[i] = malloc(sizeof(*nodes[i])); -                assert(nodes[i]); -                nodes[i]->key = i; -                c_rbnode_init(&nodes[i]->rb); -        } - -        /* shuffle nodes */ -        shuffle((void **)nodes, sizeof(nodes) / sizeof(*nodes)); - -        /* add all nodes, and verify that each node is linked */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) { -                assert(!c_rbnode_is_linked(&nodes[i]->rb)); -                assert(!c_rbtree_find_entry(&t, compare, (void *)nodes[i]->key, Node, rb)); - -                slot = c_rbtree_find_slot(&t, compare, (void *)nodes[i]->key, &p); -                assert(slot); -                c_rbtree_add(&t, p, slot, &nodes[i]->rb); - -                assert(c_rbnode_is_linked(&nodes[i]->rb)); -                assert(nodes[i] == c_rbtree_find_entry(&t, compare, (void *)nodes[i]->key, Node, rb)); -        } - -        /* shuffle nodes again */ -        shuffle((void **)nodes, sizeof(nodes) / sizeof(*nodes)); - -        /* remove all nodes (in different order) */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) { -                assert(c_rbnode_is_linked(&nodes[i]->rb)); -                assert(nodes[i] == c_rbtree_find_entry(&t, compare, (void *)nodes[i]->key, Node, rb)); - -                c_rbtree_remove_init(&t, &nodes[i]->rb); - -                assert(!c_rbnode_is_linked(&nodes[i]->rb)); -                assert(!c_rbtree_find_entry(&t, compare, (void *)nodes[i]->key, Node, rb)); -        } - -        /* free nodes again */ -        for (i = 0; i < sizeof(nodes) / sizeof(*nodes); ++i) -                free(nodes[i]); -} - -int main(int argc, char **argv) { -        unsigned int i; - -        /* we want stable tests, so use fixed seed */ -        srand(0xdeadbeef); - -        test_api(); - -        /* -         * The tests are pseudo random; run them multiple times, each run will -         * have different orders and thus different results. -         */ -        for (i = 0; i < 4; ++i) { -                test_shuffle(); -                test_map(); -        } - -        return 0; -} diff --git a/src/test/test-sched-prio.c b/src/test/test-sched-prio.c index 7f515b53d8..3e9caafc71 100644 --- a/src/test/test-sched-prio.c +++ b/src/test/test-sched-prio.c @@ -21,9 +21,12 @@  #include "macro.h"  #include "manager.h" +#include "rm-rf.h"  #include "test-helper.h" +#include "tests.h"  int main(int argc, char *argv[]) { +        _cleanup_(rm_rf_and_freep) char *runtime_dir = NULL;          Manager *m = NULL;          Unit *idle_ok, *idle_bad, *rr_ok, *rr_bad, *rr_sched;          Service *ser; @@ -31,9 +34,11 @@ int main(int argc, char *argv[]) {          FDSet *fdset = NULL;          int r; +        assert_se(runtime_dir = setup_fake_runtime_dir()); +          /* prepare the test */          assert_se(set_unit_path(TEST_DIR) >= 0); -        r = manager_new(MANAGER_USER, true, &m); +        r = manager_new(UNIT_FILE_USER, true, &m);          if (MANAGER_SKIP_TEST(r)) {                  printf("Skipping test: manager_new: %s\n", strerror(-r));                  return EXIT_TEST_SKIP; diff --git a/src/test/test-unit-file.c b/src/test/test-unit-file.c index cc6c61ba63..114ddf8478 100644 --- a/src/test/test-unit-file.c +++ b/src/test/test-unit-file.c @@ -35,10 +35,12 @@  #include "install.h"  #include "load-fragment.h"  #include "macro.h" +#include "rm-rf.h"  #include "specifier.h"  #include "string-util.h"  #include "strv.h"  #include "test-helper.h" +#include "tests.h"  #include "user-util.h"  #include "util.h" @@ -113,7 +115,7 @@ static void test_config_parse_exec(void) {          Manager *m = NULL;          Unit *u = NULL; -        r = manager_new(MANAGER_USER, true, &m); +        r = manager_new(UNIT_FILE_USER, true, &m);          if (MANAGER_SKIP_TEST(r)) {                  printf("Skipping test: manager_new: %s\n", strerror(-r));                  return; @@ -840,11 +842,14 @@ static void test_config_parse_pass_environ(void) {  }  int main(int argc, char *argv[]) { +        _cleanup_(rm_rf_and_freep) char *runtime_dir = NULL;          int r;          log_parse_environment();          log_open(); +        assert_se(runtime_dir = setup_fake_runtime_dir()); +          r = test_unit_file_get_set();          test_config_parse_exec();          test_config_parse_capability_set(); diff --git a/src/test/test-unit-name.c b/src/test/test-unit-name.c index 3de94ef425..2fd83f321c 100644 --- a/src/test/test-unit-name.c +++ b/src/test/test-unit-name.c @@ -209,7 +209,7 @@ static int test_unit_printf(void) {          assert_se(get_home_dir(&home) >= 0);          assert_se(get_shell(&shell) >= 0); -        r = manager_new(MANAGER_USER, true, &m); +        r = manager_new(UNIT_FILE_USER, true, &m);          if (r == -EPERM || r == -EACCES || r == -EADDRINUSE) {                  puts("manager_new: Permission denied. Skipping test.");                  return EXIT_TEST_SKIP; | 
