[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <f85ee226-122c-479f-a831-de5f986fb3c0@linux.dev>
Date: Fri, 9 Aug 2024 16:49:17 -0700
From: Martin KaFai Lau <martin.lau@...ux.dev>
To: Alexis Lothoré (eBPF Foundation)
<alexis.lothore@...tlin.com>
Cc: Alexei Starovoitov <ast@...nel.org>,
Daniel Borkmann <daniel@...earbox.net>, Andrii Nakryiko <andrii@...nel.org>,
Eduard Zingerman <eddyz87@...il.com>, Song Liu <song@...nel.org>,
Yonghong Song <yonghong.song@...ux.dev>,
John Fastabend <john.fastabend@...il.com>, KP Singh <kpsingh@...nel.org>,
Stanislav Fomichev <sdf@...ichev.me>, Hao Luo <haoluo@...gle.com>,
Jiri Olsa <jolsa@...nel.org>, Mykola Lysenko <mykolal@...com>,
Shuah Khan <shuah@...nel.org>, ebpf@...uxfoundation.org,
Thomas Petazzoni <thomas.petazzoni@...tlin.com>,
linux-kernel@...r.kernel.org, bpf@...r.kernel.org,
linux-kselftest@...r.kernel.org, Alan Maguire <alan.maguire@...cle.com>
Subject: Re: [PATCH bpf-next v2 2/4] selftests/bpf: convert
test_cgroup_storage to test_progs
On 8/6/24 12:55 AM, Alexis Lothoré (eBPF Foundation) wrote:
> +++ b/tools/testing/selftests/bpf/prog_tests/cgroup_storage.c
> @@ -0,0 +1,65 @@
> +// SPDX-License-Identifier: GPL-2.0
> +
> +#include <test_progs.h>
> +#include "cgroup_helpers.h"
> +#include "cgroup_storage.skel.h"
> +
> +#define TEST_CGROUP "/test-bpf-cgroup-storage-buf/"
> +#define PING_CMD "ping localhost -c 1 -W 1 -q"
> +
> +void test_cgroup_storage(void)
> +{
> + struct bpf_cgroup_storage_key key;
> + struct cgroup_storage *skel;
> + unsigned long long value;
> + int cgroup_fd;
> + int err;
> +
> + cgroup_fd = cgroup_setup_and_join(TEST_CGROUP);
Same. cgroup_fd is leaked.
> + if (!ASSERT_OK_FD(cgroup_fd, "create cgroup"))
> + return;
> +
> + skel = cgroup_storage__open_and_load();
> + if (!ASSERT_OK_PTR(skel, "load program"))
> + goto cleanup_cgroup;
> +
> + skel->links.bpf_prog =
> + bpf_program__attach_cgroup(skel->progs.bpf_prog, cgroup_fd);
> + if (!ASSERT_OK_PTR(skel->links.bpf_prog, "attach program"))
> + goto cleanup_progs;
> +
> + /* Check that one out of every two packets is dropped */
> + err = SYS_NOFAIL(PING_CMD);
Better create a netns for network traffic test. It is pretty simple and there
are existing examples to borrow, e.g. the setup_test_env() in
prog_tests/sock_addr.c. The netns setup should be done after the
cgroup_setup_and_join().
Powered by blists - more mailing lists