[LTP] [PATCH] lib: add TST_NO_SLOW_KCONFIG_CHECK macro for testcase tools
Li Wang
liwang@redhat.com
Fri Jan 17 09:27:22 CET 2025
On Fri, Jan 17, 2025 at 3:49 PM Andrea Cervesato <andrea.cervesato@suse.com>
wrote:
> Hi Li,
>
> the feature is interesting, but I have the feeling this should be added
> to tst_test struct rather than using a flag at compile time.
> For example, by adding to tst_test a slow_kconfig attribute.
>
Thanks. But sounds a little bit unnecessary to add new field in tst_test
struct.
What about using an global variable like tst_no_slow_kcofig_check ?
>
> Andrea
>
> On 1/17/25 08:17, Li Wang wrote:
> > The macro TST_NO_SLOW_KCONFIG_CHECK is added to control whether
> > the tst_has_slow_kconfig() function (which presumably checks for
> > slow kernel configurations) should be executed.
> >
> > This allows test cases and tools to opt out of this additional
> > check, enabling more flexible and faster test execution in
> > certain scenarios.
> >
> > Signed-off-by: Li Wang <liwang@redhat.com>
> > ---
> > lib/tst_test.c | 2 ++
> > testcases/lib/tst_device.c | 1 +
> > testcases/lib/tst_get_free_pids.c | 1 +
> > testcases/lib/tst_ns_create.c | 1 +
> > testcases/lib/tst_ns_exec.c | 1 +
> > testcases/lib/tst_run_shell.c | 1 +
> > 6 files changed, 7 insertions(+)
> >
> > diff --git a/lib/tst_test.c b/lib/tst_test.c
> > index b204ad975..00d34b6f0 100644
> > --- a/lib/tst_test.c
> > +++ b/lib/tst_test.c
> > @@ -1702,8 +1702,10 @@ unsigned int tst_multiply_timeout(unsigned int
> timeout)
> > if (timeout < 1)
> > tst_brk(TBROK, "timeout must to be >= 1! (%d)", timeout);
> >
> > +#ifndef TST_NO_SLOW_KCONFIG_CHECK
> > if (tst_has_slow_kconfig())
> > timeout *= 4;
> > +#endif
> >
> > return timeout * timeout_mul;
> > }
> > diff --git a/testcases/lib/tst_device.c b/testcases/lib/tst_device.c
> > index 45f77a38b..386636610 100644
> > --- a/testcases/lib/tst_device.c
> > +++ b/testcases/lib/tst_device.c
> > @@ -8,6 +8,7 @@
> > #include <stdio.h>
> > #include <stdlib.h>
> > #define TST_NO_DEFAULT_MAIN
> > +#define TST_NO_SLOW_KCONFIG_CHECK
> > #include "tst_test.h"
> > #include "old/old_device.h"
> >
> > diff --git a/testcases/lib/tst_get_free_pids.c
> b/testcases/lib/tst_get_free_pids.c
> > index 370ec3e26..c6436687a 100644
> > --- a/testcases/lib/tst_get_free_pids.c
> > +++ b/testcases/lib/tst_get_free_pids.c
> > @@ -1,6 +1,7 @@
> > // SPDX-License-Identifier: GPL-2.0-or-later
> >
> > #define TST_NO_DEFAULT_MAIN
> > +#define TST_NO_SLOW_KCONFIG_CHECK
> > #include <stdio.h>
> > #include "tst_test.h"
> >
> > diff --git a/testcases/lib/tst_ns_create.c
> b/testcases/lib/tst_ns_create.c
> > index ce3707a60..8c22ad449 100644
> > --- a/testcases/lib/tst_ns_create.c
> > +++ b/testcases/lib/tst_ns_create.c
> > @@ -17,6 +17,7 @@
> > */
> >
> > #define TST_NO_DEFAULT_MAIN
> > +#define TST_NO_SLOW_KCONFIG_CHECK
> >
> > #include <stdio.h>
> > #include <string.h>
> > diff --git a/testcases/lib/tst_ns_exec.c b/testcases/lib/tst_ns_exec.c
> > index 6a8e39339..ca5b717da 100644
> > --- a/testcases/lib/tst_ns_exec.c
> > +++ b/testcases/lib/tst_ns_exec.c
> > @@ -14,6 +14,7 @@
> > */
> >
> > #define TST_NO_DEFAULT_MAIN
> > +#define TST_NO_SLOW_KCONFIG_CHECK
> >
> > #include <stdio.h>
> > #include <sys/wait.h>
> > diff --git a/testcases/lib/tst_run_shell.c
> b/testcases/lib/tst_run_shell.c
> > index 7a446e004..b12a1e9f6 100644
> > --- a/testcases/lib/tst_run_shell.c
> > +++ b/testcases/lib/tst_run_shell.c
> > @@ -5,6 +5,7 @@
> > #include <sys/mount.h>
> >
> > #define TST_NO_DEFAULT_MAIN
> > +#define TST_NO_SLOW_KCONFIG_CHECK
> > #include "tst_test.h"
> > #include "tst_safe_stdio.h"
> > #include "ujson.h"
>
>
--
Regards,
Li Wang
More information about the ltp
mailing list