1 // SPDX-License-Identifier: GPL-2.0
3 #include <test_progs.h>
5 #include "connect4_dropper.skel.h"
7 #include "cgroup_helpers.h"
8 #include "network_helpers.h"
10 static int run_test(int cgroup_fd, int server_fd, bool classid)
12 struct connect4_dropper *skel;
15 skel = connect4_dropper__open_and_load();
16 if (!ASSERT_OK_PTR(skel, "skel_open"))
19 skel->links.connect_v4_dropper =
20 bpf_program__attach_cgroup(skel->progs.connect_v4_dropper,
22 if (!ASSERT_OK_PTR(skel->links.connect_v4_dropper, "prog_attach")) {
27 if (classid && !ASSERT_OK(join_classid(), "join_classid")) {
33 fd = connect_to_fd_opts(server_fd, NULL);
35 log_err("Unexpected success to connect to server");
38 } else if (errno != EPERM) {
39 log_err("Unexpected errno from connect to server");
43 connect4_dropper__destroy(skel);
47 void test_cgroup_v1v2(void)
49 struct network_helper_opts opts = {};
50 int server_fd, client_fd, cgroup_fd;
51 static const int port = 60120;
53 /* Step 1: Check base connectivity works without any BPF. */
54 server_fd = start_server(AF_INET, SOCK_STREAM, NULL, port, 0);
55 if (!ASSERT_GE(server_fd, 0, "server_fd"))
57 client_fd = connect_to_fd_opts(server_fd, &opts);
58 if (!ASSERT_GE(client_fd, 0, "client_fd")) {
65 /* Step 2: Check BPF policy prog attached to cgroups drops connectivity. */
66 cgroup_fd = test__join_cgroup("/connect_dropper");
67 if (!ASSERT_GE(cgroup_fd, 0, "cgroup_fd"))
69 server_fd = start_server(AF_INET, SOCK_STREAM, NULL, port, 0);
70 if (!ASSERT_GE(server_fd, 0, "server_fd")) {
74 ASSERT_OK(run_test(cgroup_fd, server_fd, false), "cgroup-v2-only");
75 setup_classid_environment();
77 ASSERT_OK(run_test(cgroup_fd, server_fd, true), "cgroup-v1v2");
78 cleanup_classid_environment();