diff options
Diffstat (limited to 'tools/testing/selftests/bpf/prog_tests/mptcp.c')
| -rw-r--r-- | tools/testing/selftests/bpf/prog_tests/mptcp.c | 19 | 
1 files changed, 17 insertions, 2 deletions
diff --git a/tools/testing/selftests/bpf/prog_tests/mptcp.c b/tools/testing/selftests/bpf/prog_tests/mptcp.c index 59f08d6d1d53..cd0c42fff7c0 100644 --- a/tools/testing/selftests/bpf/prog_tests/mptcp.c +++ b/tools/testing/selftests/bpf/prog_tests/mptcp.c @@ -7,6 +7,8 @@  #include "network_helpers.h"  #include "mptcp_sock.skel.h" +#define NS_TEST "mptcp_ns" +  #ifndef TCP_CA_NAME_MAX  #define TCP_CA_NAME_MAX	16  #endif @@ -138,12 +140,20 @@ out:  static void test_base(void)  { +	struct nstoken *nstoken = NULL;  	int server_fd, cgroup_fd;  	cgroup_fd = test__join_cgroup("/mptcp");  	if (!ASSERT_GE(cgroup_fd, 0, "test__join_cgroup"))  		return; +	SYS(fail, "ip netns add %s", NS_TEST); +	SYS(fail, "ip -net %s link set dev lo up", NS_TEST); + +	nstoken = open_netns(NS_TEST); +	if (!ASSERT_OK_PTR(nstoken, "open_netns")) +		goto fail; +  	/* without MPTCP */  	server_fd = start_server(AF_INET, SOCK_STREAM, NULL, 0, 0);  	if (!ASSERT_GE(server_fd, 0, "start_server")) @@ -157,13 +167,18 @@ with_mptcp:  	/* with MPTCP */  	server_fd = start_mptcp_server(AF_INET, NULL, 0, 0);  	if (!ASSERT_GE(server_fd, 0, "start_mptcp_server")) -		goto close_cgroup_fd; +		goto fail;  	ASSERT_OK(run_test(cgroup_fd, server_fd, true), "run_test mptcp");  	close(server_fd); -close_cgroup_fd: +fail: +	if (nstoken) +		close_netns(nstoken); + +	SYS_NOFAIL("ip netns del " NS_TEST " &> /dev/null"); +  	close(cgroup_fd);  }  |