Commit 01b43164 authored by Jakub Kicinski's avatar Jakub Kicinski

selftests: net: support matching cases by name prefix

While writing tests with a lot more cases I got tired of having
to jump back and forth to add the name of the test to the ksft_run()
list. Most unittest frameworks do some name matching, e.g. assume
that functions with names starting with test_ are test cases.

Support similar flow in ksft_run(). Let the author list the desired
prefixes. globals() need to be passed explicitly, IDK how to work
around that.
Reviewed-by: default avatarWillem de Bruijn <willemb@google.com>
Link: https://lore.kernel.org/r/20240420025237.3309296-6-kuba@kernel.orgSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent a48a87c0
...@@ -18,8 +18,7 @@ def test_v6(cfg) -> None: ...@@ -18,8 +18,7 @@ def test_v6(cfg) -> None:
def main() -> None: def main() -> None:
with NetDrvEpEnv(__file__) as cfg: with NetDrvEpEnv(__file__) as cfg:
ksft_run([test_v4, test_v6], ksft_run(globs=globals(), case_pfx={"test_"}, args=(cfg, ))
args=(cfg, ))
ksft_exit() ksft_exit()
......
...@@ -99,7 +99,18 @@ def ktap_result(ok, cnt=1, case="", comment=""): ...@@ -99,7 +99,18 @@ def ktap_result(ok, cnt=1, case="", comment=""):
print(res) print(res)
def ksft_run(cases, args=()): def ksft_run(cases=None, globs=None, case_pfx=None, args=()):
cases = cases or []
if globs and case_pfx:
for key, value in globs.items():
if not callable(value):
continue
for prefix in case_pfx:
if key.startswith(prefix):
cases.append(value)
break
totals = {"pass": 0, "fail": 0, "skip": 0, "xfail": 0} totals = {"pass": 0, "fail": 0, "skip": 0, "xfail": 0}
print("KTAP version 1") print("KTAP version 1")
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment