| // SPDX-License-Identifier: GPL-2.0 | 
 | /* | 
 |  * Example KUnit test to show how to use KUnit. | 
 |  * | 
 |  * Copyright (C) 2019, Google LLC. | 
 |  * Author: Brendan Higgins <brendanhiggins@google.com> | 
 |  */ | 
 |  | 
 | #include <kunit/test.h> | 
 |  | 
 | /* | 
 |  * 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 kunit *)`. `struct kunit` is a context object that stores | 
 |  * information about the current test. | 
 |  */ | 
 | static void example_simple_test(struct kunit *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. | 
 | 	 */ | 
 | 	KUNIT_EXPECT_EQ(test, 1 + 1, 2); | 
 | } | 
 |  | 
 | /* | 
 |  * This is run once before each test case, see the comment on | 
 |  * example_test_suite for more information. | 
 |  */ | 
 | static int example_test_init(struct kunit *test) | 
 | { | 
 | 	kunit_info(test, "initializing\n"); | 
 |  | 
 | 	return 0; | 
 | } | 
 |  | 
 | /* | 
 |  * Here we make a list of all the test cases we want to add to the test suite | 
 |  * below. | 
 |  */ | 
 | static struct kunit_case example_test_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 suite. | 
 | 	 */ | 
 | 	KUNIT_CASE(example_simple_test), | 
 | 	{} | 
 | }; | 
 |  | 
 | /* | 
 |  * This defines a suite or grouping of tests. | 
 |  * | 
 |  * Test cases are defined as belonging to the suite by adding them to | 
 |  * `kunit_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 suite would behave as follows: | 
 |  * | 
 |  * suite.init(test); | 
 |  * suite.test_case[0](test); | 
 |  * suite.exit(test); | 
 |  * suite.init(test); | 
 |  * suite.test_case[1](test); | 
 |  * suite.exit(test); | 
 |  * ...; | 
 |  */ | 
 | static struct kunit_suite example_test_suite = { | 
 | 	.name = "example", | 
 | 	.init = example_test_init, | 
 | 	.test_cases = example_test_cases, | 
 | }; | 
 |  | 
 | /* | 
 |  * This registers the above test suite telling KUnit that this is a suite of | 
 |  * tests that need to be run. | 
 |  */ | 
 | kunit_test_suites(&example_test_suite); | 
 |  | 
 | MODULE_LICENSE("GPL v2"); |