From: Petr Machata <petrm@nvidia.com>
To: Mohsin Bashir <mohsin.bashr@gmail.com>
Cc: <netdev@vger.kernel.org>, <shuah@kernel.org>,
<davem@davemloft.net>, <edumazet@google.com>, <kuba@kernel.org>,
<pabeni@redhat.com>, <willemb@google.com>, <petrm@nvidia.com>,
<dw@davidwei.uk>, <przemyslaw.kitszel@intel.com>,
<linux-kselftest@vger.kernel.org>
Subject: Re: [PATCH net-next] selftests: net: py: support verbose printing, display executed commands
Date: Mon, 15 Jul 2024 12:45:58 +0200 [thread overview]
Message-ID: <87bk2yrkcs.fsf@nvidia.com> (raw)
In-Reply-To: <20240715030723.1768360-1-mohsin.bashr@gmail.com>
Mohsin Bashir <mohsin.bashr@gmail.com> writes:
> Add verbosity support to show the commands executed while
> running tests. Enable verbosity if either an environment
> variable 'VERBOSE' is set to a non-zero number or it is defined
> in a config file under driver tests as discussed here:
> https://github.com/linux-netdev/nipa/wiki/Running-driver-tests.
>
> Signed-off-by: Mohsin Bashir <mohsin.bashr@gmail.com>
> ---
> tools/testing/selftests/drivers/net/lib/py/env.py | 14 +++++++++++++-
> tools/testing/selftests/net/lib/py/__init__.py | 7 +++++++
> tools/testing/selftests/net/lib/py/utils.py | 14 ++++++++++++++
> 3 files changed, 34 insertions(+), 1 deletion(-)
>
> diff --git a/tools/testing/selftests/drivers/net/lib/py/env.py b/tools/testing/selftests/drivers/net/lib/py/env.py
> index a5e800b8f103..ec53cf59e104 100644
> --- a/tools/testing/selftests/drivers/net/lib/py/env.py
> +++ b/tools/testing/selftests/drivers/net/lib/py/env.py
> @@ -4,7 +4,7 @@ import os
> import time
> from pathlib import Path
> from lib.py import KsftSkipEx, KsftXfailEx
> -from lib.py import cmd, ethtool, ip
> +from lib.py import cmd, ethtool, ip, verbosity_ctl
> from lib.py import NetNS, NetdevSimDev
> from .remote import Remote
>
> @@ -42,6 +42,12 @@ class NetDrvEnv:
>
> self.env = _load_env_file(src_path)
>
> + try:
> + verbosity_ctl(level=int(self.env.get('VERBOSE', 0)))
> + except ValueError as e:
> + print(f'Ignoring \'VERBOSE\'. Unknown value \'{self.env.get("VERBOSE")}\'')
> + verbosity_ctl(level=0)
> +
I think you are looking to catch the integer conversion errors here, so
just enclose that bit:
env_level = self.env.get('VERBOSE', 0)
try:
level = int(env_level)
except ValueError as e:
print(f'Ignoring \'VERBOSE\'. Unknown value \'{env_level}\'')
level = 0
verbosity_ctl(level=level)
Now instead of cut'n'pasting this twice, shouldn't this be the real
verbosity_ctl()? Call it set_verbosity(self.env) maybe, call from the
three sites that currently open-code the same.
> if 'NETIF' in self.env:
> self.dev = ip("link show dev " + self.env['NETIF'], json=True)[0]
> else:
> @@ -92,6 +98,12 @@ class NetDrvEpEnv:
> self._ns = None
> self._ns_peer = None
>
> + try:
> + verbosity_ctl(level=int(self.env.get('VERBOSE', 0)))
> + except ValueError as e:
> + print(f'Ignoring \'VERBOSE\'. Unknown value \'{self.env.get("VERBOSE")}\'')
> + verbosity_ctl(level=0)
> +
> if "NETIF" in self.env:
> if nsim_test is True:
> raise KsftXfailEx("Test only works on netdevsim")
> diff --git a/tools/testing/selftests/net/lib/py/__init__.py b/tools/testing/selftests/net/lib/py/__init__.py
> index b6d498d125fe..1541079fadce 100644
> --- a/tools/testing/selftests/net/lib/py/__init__.py
> +++ b/tools/testing/selftests/net/lib/py/__init__.py
> @@ -1,8 +1,15 @@
> # SPDX-License-Identifier: GPL-2.0
>
> +import os
> from .consts import KSRC
> from .ksft import *
> from .netns import NetNS
> from .nsim import *
> from .utils import *
> from .ynl import NlError, YnlFamily, EthtoolFamily, NetdevFamily, RtnlFamily
> +
> +try:
> + verbosity_ctl(level=int(os.environ.get('VERBOSE', 0)))
> +except ValueError as e:
> + print(f'Ignoring \'VERBOSE\'. Unknown value \'{os.environ.get("VERBOSE")}\'')
> + verbosity_ctl(level=0)
> diff --git a/tools/testing/selftests/net/lib/py/utils.py b/tools/testing/selftests/net/lib/py/utils.py
> index 72590c3f90f1..4a59958649be 100644
> --- a/tools/testing/selftests/net/lib/py/utils.py
> +++ b/tools/testing/selftests/net/lib/py/utils.py
> @@ -9,6 +9,18 @@ import subprocess
> import time
>
>
> +def verbosity_ctl(level=None):
> + global VERBOSITY_LEVEL
> + if level is not None:
> + VERBOSITY_LEVEL = level
> + return VERBOSITY_LEVEL
IMHO, have a set_verbosity to just set it, and have verbose() below ask
for the global directly. So if VERBOSITY_LEVEL >= 1.
> +def verbose(*objs, **kwargs):
> + if verbosity_ctl() >= 1:
> + print(*objs, **kwargs)
> +
> +
> class CmdExitFailure(Exception):
> pass
>
> @@ -22,6 +34,8 @@ class cmd:
> self.stderr = None
> self.ret = None
>
> + verbose("#cmd|", comm)
> +
> self.comm = comm
> if host:
> self.proc = host.cmd(comm)
next prev parent reply other threads:[~2024-07-15 11:00 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-07-15 3:07 [PATCH net-next] selftests: net: py: support verbose printing, display executed commands Mohsin Bashir
2024-07-15 10:45 ` Petr Machata [this message]
2024-08-03 2:58 ` Mohsin Bashir
2024-08-05 14:14 ` Petr Machata
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=87bk2yrkcs.fsf@nvidia.com \
--to=petrm@nvidia.com \
--cc=davem@davemloft.net \
--cc=dw@davidwei.uk \
--cc=edumazet@google.com \
--cc=kuba@kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=mohsin.bashr@gmail.com \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=przemyslaw.kitszel@intel.com \
--cc=shuah@kernel.org \
--cc=willemb@google.com \
/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.