// SPDX-License-Identifier: GPL-2.0 /* * TODO: Add test description. */ #include #include /* * This is the most fundamental element of KUnit, the test case. A test case * makes a set EXPECTATIONs and ASSERTIONs about the behavior of some code; if * any expectations or assertions are not met, the test fails; otherwise, the * test passes. * * In KUnit, a test case is just a function with the signature * `void (*)(struct test *)`. `struct test` is a context object that stores * information about the current test. */ #ifdef CONFIG_UML /* NOTE: UML TC */ static void ${test_prefix}_bar(struct test *test) { /* Test cases for UML */ return; } #else /* NOTE: Target running TC must be in the #ifndef CONFIG_UML */ static void ${test_prefix}_foo(struct test *test) { /* * This is an EXPECTATION; it is how KUnit tests things. When you want * to test a piece of code, you set some expectations about what the * code should do. KUnit then runs the test and verifies that the code's * behavior matched what was expected. */ EXPECT_EQ(test, 1, 2); // Obvious failure. } #endif /* * This is run once before each test case, see the comment on * example_test_module for more information. */ static int ${test_prefix}_init(struct test *test) { return 0; } /* * This is run once after each test case, see the comment on example_test_module * for more information. */ static void ${test_prefix}_exit(struct test *test) { } /* * Here we make a list of all the test cases we want to add to the test module * below. */ static struct test_case ${test_prefix}_cases[] = { /* * This is a helper to create a test case object from a test case * function; its exact function is not important to understand how to * use KUnit, just know that this is how you associate test cases with a * test module. */ #ifdef CONFIG_UML /* NOTE: UML TC */ TEST_CASE(${test_prefix}_bar), #else /* NOTE: Target running TC */ TEST_CASE(${test_prefix}_foo), #endif {}, }; /* * This defines a suite or grouping of tests. * * Test cases are defined as belonging to the suite by adding them to * `test_cases`. * * Often it is desirable to run some function which will set up things which * will be used by every test; this is accomplished with an `init` function * which runs before each test case is invoked. Similarly, an `exit` function * may be specified which runs after every test case and can be used to for * cleanup. For clarity, running tests in a test module would behave as follows: * * module.init(test); * module.test_case[0](test); * module.exit(test); * module.init(test); * module.test_case[1](test); * module.exit(test); * ...; */ static struct test_module ${test_prefix}_module = { .name = "${test_prefix}", .init = ${test_prefix}_init, .exit = ${test_prefix}_exit, .test_cases = ${test_prefix}_cases, }; /* * This registers the above test module telling KUnit that this is a suite of * tests that need to be run. */ module_test(${test_prefix}_module);