Commit Graph

3 Commits

Author SHA1 Message Date
Nico Pache cd47084fae kunit: Add printf attribute to fail_current_test_impl
commit 82649c7c0da431d147a75c6ae768ee42c1053f53
Author: David Gow <davidgow@google.com>
Date:   Sat Feb 4 12:04:53 2023 +0800

    kunit: Add printf attribute to fail_current_test_impl

    Add the gnu_printf (__printf()) attribute to the
    kunit_fail_current_test() implementation in
    __kunit_fail_current_test_impl(). While it's not actually useful here,
    as this function is never called directly, it nevertheless was
    triggering -Wsuggest-attribute=format warnings, so we should add it to
    reduce the noise.

    Fixes: cc3ed2fe5c93 ("kunit: Add "hooks" to call into KUnit when it's built as a module")
    Reported-by: kernel test robot <lkp@intel.com>
    Signed-off-by: David Gow <davidgow@google.com>
    Reviewed-by: Rae Moar <rmoar@google.com>
    Signed-off-by: Shuah Khan <skhan@linuxfoundation.org>

JIRA: https://issues.redhat.com/browse/RHEL-5618
Signed-off-by: Nico Pache <npache@redhat.com>
2023-11-02 15:26:56 -06:00
Nico Pache 8b723c3887 kunit: Expose 'static stub' API to redirect functions
commit e047c5eaa76324575e1f95664be4c74ce0e2571b
Author: David Gow <davidgow@google.com>
Date:   Tue Jan 31 14:46:40 2023 +0800

    kunit: Expose 'static stub' API to redirect functions

    Add a simple way of redirecting calls to functions by including a
    special prologue in the "real" function which checks to see if the
    replacement function should be called (and, if so, calls it).

    To redirect calls to a function, make the first (non-declaration) line
    of the function:

            KUNIT_STATIC_STUB_REDIRECT(function_name, [function arguments]);

    (This will compile away to nothing if KUnit is not enabled, otherwise it
    will check if a redirection is active, call the replacement function,
    and return. This check is protected by a static branch, so has very
    little overhead when there are no KUnit tests running.)

    Calls to the real function can be redirected to a replacement using:

            kunit_activate_static_stub(test, real_fn, replacement_fn);

    The redirection will only affect calls made from within the kthread of
    the current test, and will be automatically disabled when the test
    completes. It can also be manually disabled with
    kunit_deactivate_static_stub().

    The 'example' KUnit test suite has a more complete example.

    Co-developed-by: Daniel Latypov <dlatypov@google.com>
    Signed-off-by: Daniel Latypov <dlatypov@google.com>
    Signed-off-by: David Gow <davidgow@google.com>
    Reviewed-by: Brendan Higgins <brendanhiggins@google.com>
    Signed-off-by: Shuah Khan <skhan@linuxfoundation.org>

JIRA: https://issues.redhat.com/browse/RHEL-5618
Signed-off-by: Nico Pache <npache@redhat.com>
2023-11-02 15:26:56 -06:00
Nico Pache ca38ec1553 kunit: Add "hooks" to call into KUnit when it's built as a module
commit 7170b7ed6acbde523c5d362c8978c60df4c30f30
Author: David Gow <davidgow@google.com>
Date:   Sat Jan 28 15:10:07 2023 +0800

    kunit: Add "hooks" to call into KUnit when it's built as a module

    KUnit has several macros and functions intended for use from non-test
    code. These hooks, currently the kunit_get_current_test() and
    kunit_fail_current_test() macros, didn't work when CONFIG_KUNIT=m.

    In order to support this case, the required functions and static data
    need to be available unconditionally, even when KUnit itself is not
    built-in. The new 'hooks.c' file is therefore always included, and has
    both the static key required for kunit_get_current_test(), and a table
    of function pointers in struct kunit_hooks_table. This is filled in with
    the real implementations by kunit_install_hooks(), which is kept in
    hooks-impl.h and called when the kunit module is loaded.

    This can  be extended for future features which require similar
    "hook" behaviour, such as static stubs, by simply adding new entries to
    the struct, and the appropriate code to set them.

    Fixed white-space errors during commit:
    Shuah Khan <skhan@linuxfoundation.org>

    Resolved merge conflicts with:
    db105c37a4d6 ("kunit: Export kunit_running()")
    This patch supersedes the above.
    Shuah Khan <skhan@linuxfoundation.org>

    Signed-off-by: David Gow <davidgow@google.com>
    Reviewed-by: Rae Moar <rmoar@google.com>
    Reviewed-by: Brendan Higgins <brendanhiggins@google.com>
    Signed-off-by: Shuah Khan <skhan@linuxfoundation.org>

JIRA: https://issues.redhat.com/browse/RHEL-5618
Signed-off-by: Nico Pache <npache@redhat.com>
2023-11-02 15:26:55 -06:00