summaryrefslogtreecommitdiffstats
path: root/src/test/test-loopback.c
blob: db6ee0f32dd0a906d3b6f63620cac0d8ae06bafa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/* SPDX-License-Identifier: LGPL-2.1-or-later */

#include <sched.h>
#include <stdio.h>
#include <string.h>

#include "errno-util.h"
#include "log.h"
#include "loopback-setup.h"
#include "tests.h"

TEST_RET(loopback_setup) {
        int r;

        if (unshare(CLONE_NEWUSER | CLONE_NEWNET) < 0) {
                if (ERRNO_IS_PRIVILEGE(errno) || ERRNO_IS_NOT_SUPPORTED(errno))
                        return log_tests_skipped("lacking privileges or namespaces not supported");
                return log_error_errno(errno, "Failed to create user+network namespace: %m");
        }

        r = loopback_setup();
        if (ERRNO_IS_NEG_PRIVILEGE(r))
                return log_tests_skipped("lacking privileges");
        if (r < 0)
                return log_error_errno(r, "loopback: %m");

        log_info("> ipv6 main");
        /* <0 → fork error, ==0 → success, >0 → error in child */
        assert_se(system("ip -6 route show table main") >= 0);

        log_info("> ipv6 local");
        assert_se(system("ip -6 route show table local") >=0);

        log_info("> ipv4 main");
        assert_se(system("ip -4 route show table main") >= 0);

        log_info("> ipv4 local");
        assert_se(system("ip -4 route show table local") >= 0);

        return EXIT_SUCCESS;
}

static int intro(void) {
        log_show_color(true);
        return EXIT_SUCCESS;
}

DEFINE_TEST_MAIN_WITH_INTRO(LOG_INFO, intro);