From: Richard Palethorpe <rpalethorpe@suse.de>
To: Andrea Cervesato <andrea.cervesato@suse.com>
Cc: ltp@lists.linux.it
Subject: Re: [LTP] [PATCH v1] Refactor pidns10 test using new LTP API
Date: Tue, 11 Oct 2022 10:59:21 +0100 [thread overview]
Message-ID: <87v8oq7kak.fsf@suse.de> (raw)
In-Reply-To: <20220805094619.663-1-andrea.cervesato@suse.com>
Andrea Cervesato via ltp <ltp@lists.linux.it> writes:
> Signed-off-by: Andrea Cervesato <andrea.cervesato@suse.com>
> ---
> testcases/kernel/containers/pidns/pidns10.c | 133 ++++++--------------
> 1 file changed, 38 insertions(+), 95 deletions(-)
>
> diff --git a/testcases/kernel/containers/pidns/pidns10.c b/testcases/kernel/containers/pidns/pidns10.c
> index b38b9fd18..cbc9d3585 100644
> --- a/testcases/kernel/containers/pidns/pidns10.c
> +++ b/testcases/kernel/containers/pidns/pidns10.c
> @@ -1,112 +1,55 @@
> +// SPDX-License-Identifier: GPL-2.0
> /*
> -* Copyright (c) International Business Machines Corp., 2007
> -* This program is free software; you can redistribute it and/or modify
> -* it under the terms of the GNU General Public License as published by
> -* the Free Software Foundation; either version 2 of the License, or
> -* (at your option) any later version.
> -* This program 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 General Public License for more details.
> -* You should have received a copy of the GNU General Public License
> -* along with this program; if not, write to the Free Software
> -* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
> -*
> -***************************************************************************
> -* File: pidns10.c
> -* *
> -* * Description:
> -* * The pidns10.c testcase verifies inside the container, if kill(-1, signal)
> -* * fails with ESRCH when there are no processes in container.
> -* *
> -* * Test Assertion & Strategy:
> -* * Create a PID namespace container.
> -* * Invoke kill(-1, SIGUSR1) inside container and check return code and error.
> -* * kill() should have failed;except swapper & init, no process is inside.
> -* *
> -* * Usage: <for command-line>
> -* * pidns10
> -* *
> -* * History:
> -* * DATE NAME DESCRIPTION
> -* * 13/11/08 Gowrishankar M Creation of this test.
> -* * <gowrishankar.m@in.ibm.com>
> -*
> -******************************************************************************/
> -#define _GNU_SOURCE 1
> -#include <sys/wait.h>
> -#include <sys/types.h>
> -#include <string.h>
> -#include <stdlib.h>
> -#include <unistd.h>
> -#include <stdio.h>
> -#include <errno.h>
> -#include "pidns_helper.h"
> -#include "test.h"
> -
> -char *TCID = "pidns10";
> -int TST_TOTAL = 1;
> + * Copyright (C) International Business Machines Corp., 2008
> + * 13/11/08 Gowrishankar M <gowrishankar.m@in.ibm.com>
> + * Copyright (C) 2022 SUSE LLC Andrea Cervesato <andrea.cervesato@suse.com>
> + */
>
> -int child_fn(void *);
> +/*\
> + * [Description]
> + *
> + * Clone a process with CLONE_NEWPID flag and check if kill(-1, signal) fails
> + * with ESRCH when there are no process in the container.
> + */
>
> -#define CHILD_PID 1
> -#define PARENT_PID 0
> +#include "tst_test.h"
> +#include "lapi/namespaces_constants.h"
>
> -/*
> - * child_fn() - Inside container
> - */
> -int child_fn(void *arg)
> +static int child_func(LTP_ATTRIBUTE_UNUSED void *arg)
> {
> - int exit_val, ret;
> - pid_t pid, ppid;
> + pid_t cpid, ppid;
> + int ret;
>
> - /* Set process id and parent pid */
> - pid = getpid();
> + cpid = getpid();
> ppid = getppid();
> - if (pid != CHILD_PID || ppid != PARENT_PID) {
> - printf("cinit: pidns was not created.\n");
> +
> + if (cpid != 1 || ppid != 0) {
> + tst_res(TFAIL, "Got unexpected result of cpid=%d ppid=%d", cpid, ppid);
> return 1;
> }
>
> - if ((ret = kill(-1, SIGUSR1)) == -1 && errno == ESRCH) {
> - printf("cinit: kill(-1, sig) failed with -1 / ESRCH as "
> - "expected\n");
> - exit_val = 0;
> - } else {
> - printf("cinit: kill(-1, sig) didn't fail with -1 / ESRCH "
> - "(%d); failed with %d / %d instead", ESRCH, ret, errno);
> - exit_val = 1;
> + ret = kill(-1, SIGUSR1);
> +
> + if (ret != -1 || errno != ESRCH) {
> + tst_res(TFAIL, "kill() didn't fail with ESRCH");
> + return 0;
> }
> - exit(exit_val);
> -}
>
> -static void setup(void)
> -{
> - tst_require_root();
> - check_newpid();
> + tst_res(TPASS, "Can't kill processes from child namespace");
> +
> + return 0;
> }
>
> -int main(void)
> +static void run(void)
> {
> - int status;
> - pid_t pid;
> -
> - setup();
> -
> - pid = getpid();
> -
> - /* Container creation on PID namespace */
> - TEST(do_clone_unshare_test(T_CLONE, CLONE_NEWPID, child_fn, NULL));
> - if (TEST_RETURN == -1) {
> - tst_brkm(TBROK | TTERRNO, NULL, "clone failed");
> - }
> -
> - sleep(1);
> - if (wait(&status) < 0)
> - tst_resm(TWARN, "parent: waitpid() failed.");
> + int ret;
>
> - if (WIFEXITED(status) && WEXITSTATUS(status) != 0)
> - tst_resm(TBROK, "container was terminated abnormally");
> -
> - tst_exit();
> + ret = ltp_clone_quick(CLONE_NEWPID | SIGCHLD, child_func, 0);
tst_clone
> + if (ret < 0)
> + tst_brk(TBROK | TERRNO, "clone failed");
> }
> +
> +static struct tst_test test = {
> + .test_all = run,
> + .needs_root = 1,
> +};
> --
> 2.35.3
--
Thank you,
Richard.
--
Mailing list info: https://lists.linux.it/listinfo/ltp
prev parent reply other threads:[~2022-10-11 9:59 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-08-05 9:46 [LTP] [PATCH v1] Refactor pidns10 test using new LTP API Andrea Cervesato via ltp
2022-10-11 9:59 ` Richard Palethorpe [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87v8oq7kak.fsf@suse.de \
--to=rpalethorpe@suse.de \
--cc=andrea.cervesato@suse.com \
--cc=ltp@lists.linux.it \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.