12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358 |
- /* SPDX-License-Identifier: GPL-2.0 */
- /*
- * Base unit test (KUnit) API.
- *
- * Copyright (C) 2019, Google LLC.
- * Author: Brendan Higgins <[email protected]>
- */
- #ifndef _KUNIT_TEST_H
- #define _KUNIT_TEST_H
- #include <kunit/assert.h>
- #ifdef CONFIG_SEC_KUNIT
- #include <kunit/kunit-stream.h>
- #endif /* CONFIG_SEC_KUNIT */
- #include <kunit/try-catch.h>
- #include <linux/compiler.h>
- #include <linux/container_of.h>
- #include <linux/err.h>
- #include <linux/init.h>
- #include <linux/kconfig.h>
- #include <linux/kref.h>
- #include <linux/list.h>
- #include <linux/module.h>
- #include <linux/slab.h>
- #include <linux/spinlock.h>
- #include <linux/string.h>
- #include <linux/types.h>
- #include <asm/rwonce.h>
- struct kunit;
- /* Size of log associated with test. */
- #define KUNIT_LOG_SIZE 512
- /* Maximum size of parameter description string. */
- #define KUNIT_PARAM_DESC_SIZE 128
- /* Maximum size of a status comment. */
- #define KUNIT_STATUS_COMMENT_SIZE 256
- /*
- * TAP specifies subtest stream indentation of 4 spaces, 8 spaces for a
- * sub-subtest. See the "Subtests" section in
- * https://node-tap.org/tap-protocol/
- */
- #define KUNIT_SUBTEST_INDENT " "
- #define KUNIT_SUBSUBTEST_INDENT " "
- /**
- * enum kunit_status - Type of result for a test or test suite
- * @KUNIT_SUCCESS: Denotes the test suite has not failed nor been skipped
- * @KUNIT_FAILURE: Denotes the test has failed.
- * @KUNIT_SKIPPED: Denotes the test has been skipped.
- */
- enum kunit_status {
- KUNIT_SUCCESS,
- KUNIT_FAILURE,
- KUNIT_SKIPPED,
- };
- /**
- * struct kunit_case - represents an individual test case.
- *
- * @run_case: the function representing the actual test case.
- * @name: the name of the test case.
- * @generate_params: the generator function for parameterized tests.
- *
- * A test case is a function with the signature,
- * ``void (*)(struct kunit *)``
- * that makes expectations and assertions (see KUNIT_EXPECT_TRUE() and
- * KUNIT_ASSERT_TRUE()) about code under test. Each test case is associated
- * with a &struct kunit_suite and will be run after the suite's init
- * function and followed by the suite's exit function.
- *
- * A test case should be static and should only be created with the
- * KUNIT_CASE() macro; additionally, every array of test cases should be
- * terminated with an empty test case.
- *
- * Example:
- *
- * .. code-block:: c
- *
- * void add_test_basic(struct kunit *test)
- * {
- * KUNIT_EXPECT_EQ(test, 1, add(1, 0));
- * KUNIT_EXPECT_EQ(test, 2, add(1, 1));
- * KUNIT_EXPECT_EQ(test, 0, add(-1, 1));
- * KUNIT_EXPECT_EQ(test, INT_MAX, add(0, INT_MAX));
- * KUNIT_EXPECT_EQ(test, -1, add(INT_MAX, INT_MIN));
- * }
- *
- * static struct kunit_case example_test_cases[] = {
- * KUNIT_CASE(add_test_basic),
- * {}
- * };
- *
- */
- struct kunit_case {
- void (*run_case)(struct kunit *test);
- const char *name;
- const void* (*generate_params)(const void *prev, char *desc);
- /* private: internal use only. */
- enum kunit_status status;
- char *log;
- };
- static inline char *kunit_status_to_ok_not_ok(enum kunit_status status)
- {
- switch (status) {
- case KUNIT_SKIPPED:
- case KUNIT_SUCCESS:
- return "ok";
- case KUNIT_FAILURE:
- return "not ok";
- }
- return "invalid";
- }
- /**
- * KUNIT_CASE - A helper for creating a &struct kunit_case
- *
- * @test_name: a reference to a test case function.
- *
- * Takes a symbol for a function representing a test case and creates a
- * &struct kunit_case object from it. See the documentation for
- * &struct kunit_case for an example on how to use it.
- */
- #define KUNIT_CASE(test_name) { .run_case = test_name, .name = #test_name }
- /**
- * KUNIT_CASE_PARAM - A helper for creation a parameterized &struct kunit_case
- *
- * @test_name: a reference to a test case function.
- * @gen_params: a reference to a parameter generator function.
- *
- * The generator function::
- *
- * const void* gen_params(const void *prev, char *desc)
- *
- * is used to lazily generate a series of arbitrarily typed values that fit into
- * a void*. The argument @prev is the previously returned value, which should be
- * used to derive the next value; @prev is set to NULL on the initial generator
- * call. When no more values are available, the generator must return NULL.
- * Optionally write a string into @desc (size of KUNIT_PARAM_DESC_SIZE)
- * describing the parameter.
- */
- #define KUNIT_CASE_PARAM(test_name, gen_params) \
- { .run_case = test_name, .name = #test_name, \
- .generate_params = gen_params }
- /**
- * struct kunit_suite - describes a related collection of &struct kunit_case
- *
- * @name: the name of the test. Purely informational.
- * @suite_init: called once per test suite before the test cases.
- * @suite_exit: called once per test suite after all test cases.
- * @init: called before every test case.
- * @exit: called after every test case.
- * @test_cases: a null terminated array of test cases.
- *
- * A kunit_suite is a collection of related &struct kunit_case s, such that
- * @init is called before every test case and @exit is called after every
- * test case, similar to the notion of a *test fixture* or a *test class*
- * in other unit testing frameworks like JUnit or Googletest.
- *
- * Every &struct kunit_case must be associated with a kunit_suite for KUnit
- * to run it.
- */
- struct kunit_suite {
- const char name[256];
- int (*suite_init)(struct kunit_suite *suite);
- void (*suite_exit)(struct kunit_suite *suite);
- int (*init)(struct kunit *test);
- void (*exit)(struct kunit *test);
- struct kunit_case *test_cases;
- /* private: internal use only */
- char status_comment[KUNIT_STATUS_COMMENT_SIZE];
- struct dentry *debugfs;
- char *log;
- int suite_init_err;
- };
- /**
- * struct kunit - represents a running instance of a test.
- *
- * @priv: for user to store arbitrary data. Commonly used to pass data
- * created in the init function (see &struct kunit_suite).
- *
- * Used to store information about the current context under which the test
- * is running. Most of this data is private and should only be accessed
- * indirectly via public functions; the one exception is @priv which can be
- * used by the test writer to store arbitrary data.
- */
- struct kunit {
- void *priv;
- /* private: internal use only. */
- const char *name; /* Read only after initialization! */
- char *log; /* Points at case log after initialization */
- struct kunit_try_catch try_catch;
- /* param_value is the current parameter value for a test case. */
- const void *param_value;
- /* param_index stores the index of the parameter in parameterized tests. */
- int param_index;
- /*
- * success starts as true, and may only be set to false during a
- * test case; thus, it is safe to update this across multiple
- * threads using WRITE_ONCE; however, as a consequence, it may only
- * be read after the test case finishes once all threads associated
- * with the test case have terminated.
- */
- spinlock_t lock; /* Guards all mutable test state. */
- enum kunit_status status; /* Read only after test_case finishes! */
- /*
- * Because resources is a list that may be updated multiple times (with
- * new resources) from any thread associated with a test case, we must
- * protect it with some type of lock.
- */
- struct list_head resources; /* Protected by lock. */
- #ifdef CONFIG_SEC_KUNIT
- struct list_head post_conditions;
- #endif /* CONFIG_SEC_KUNIT */
- char status_comment[KUNIT_STATUS_COMMENT_SIZE];
- };
- static inline void kunit_set_failure(struct kunit *test)
- {
- WRITE_ONCE(test->status, KUNIT_FAILURE);
- }
- bool kunit_enabled(void);
- void kunit_init_test(struct kunit *test, const char *name, char *log);
- int kunit_run_tests(struct kunit_suite *suite);
- size_t kunit_suite_num_test_cases(struct kunit_suite *suite);
- unsigned int kunit_test_case_num(struct kunit_suite *suite,
- struct kunit_case *test_case);
- int __kunit_test_suites_init(struct kunit_suite * const * const suites, int num_suites);
- void __kunit_test_suites_exit(struct kunit_suite **suites, int num_suites);
- #if IS_BUILTIN(CONFIG_KUNIT)
- int kunit_run_all_tests(void);
- #else
- static inline int kunit_run_all_tests(void)
- {
- return 0;
- }
- #endif /* IS_BUILTIN(CONFIG_KUNIT) */
- #define __kunit_test_suites(unique_array, ...) \
- static struct kunit_suite *unique_array[] \
- __aligned(sizeof(struct kunit_suite *)) \
- __used __section(".kunit_test_suites") = { __VA_ARGS__ }
- /**
- * kunit_test_suites() - used to register one or more &struct kunit_suite
- * with KUnit.
- *
- * @__suites: a statically allocated list of &struct kunit_suite.
- *
- * Registers @suites with the test framework.
- * This is done by placing the array of struct kunit_suite * in the
- * .kunit_test_suites ELF section.
- *
- * When builtin, KUnit tests are all run via the executor at boot, and when
- * built as a module, they run on module load.
- *
- */
- #define kunit_test_suites(__suites...) \
- __kunit_test_suites(__UNIQUE_ID(array), \
- ##__suites)
- #define kunit_test_suite(suite) kunit_test_suites(&suite)
- /**
- * kunit_test_init_section_suites() - used to register one or more &struct
- * kunit_suite containing init functions or
- * init data.
- *
- * @__suites: a statically allocated list of &struct kunit_suite.
- *
- * This functions identically as kunit_test_suites() except that it suppresses
- * modpost warnings for referencing functions marked __init or data marked
- * __initdata; this is OK because currently KUnit only runs tests upon boot
- * during the init phase or upon loading a module during the init phase.
- *
- * NOTE TO KUNIT DEVS: If we ever allow KUnit tests to be run after boot, these
- * tests must be excluded.
- *
- * The only thing this macro does that's different from kunit_test_suites is
- * that it suffixes the array and suite declarations it makes with _probe;
- * modpost suppresses warnings about referencing init data for symbols named in
- * this manner.
- */
- #define kunit_test_init_section_suites(__suites...) \
- __kunit_test_suites(CONCATENATE(__UNIQUE_ID(array), _probe), \
- ##__suites)
- #define kunit_test_init_section_suite(suite) \
- kunit_test_init_section_suites(&suite)
- #define kunit_suite_for_each_test_case(suite, test_case) \
- for (test_case = suite->test_cases; test_case->run_case; test_case++)
- enum kunit_status kunit_suite_has_succeeded(struct kunit_suite *suite);
- /**
- * kunit_kmalloc_array() - Like kmalloc_array() except the allocation is *test managed*.
- * @test: The test context object.
- * @n: number of elements.
- * @size: The size in bytes of the desired memory.
- * @gfp: flags passed to underlying kmalloc().
- *
- * Just like `kmalloc_array(...)`, except the allocation is managed by the test case
- * and is automatically cleaned up after the test case concludes. See &struct
- * kunit_resource for more information.
- */
- void *kunit_kmalloc_array(struct kunit *test, size_t n, size_t size, gfp_t gfp);
- /**
- * kunit_kmalloc() - Like kmalloc() except the allocation is *test managed*.
- * @test: The test context object.
- * @size: The size in bytes of the desired memory.
- * @gfp: flags passed to underlying kmalloc().
- *
- * See kmalloc() and kunit_kmalloc_array() for more information.
- */
- static inline void *kunit_kmalloc(struct kunit *test, size_t size, gfp_t gfp)
- {
- return kunit_kmalloc_array(test, 1, size, gfp);
- }
- /**
- * kunit_kfree() - Like kfree except for allocations managed by KUnit.
- * @test: The test case to which the resource belongs.
- * @ptr: The memory allocation to free.
- */
- void kunit_kfree(struct kunit *test, const void *ptr);
- /**
- * kunit_kzalloc() - Just like kunit_kmalloc(), but zeroes the allocation.
- * @test: The test context object.
- * @size: The size in bytes of the desired memory.
- * @gfp: flags passed to underlying kmalloc().
- *
- * See kzalloc() and kunit_kmalloc_array() for more information.
- */
- static inline void *kunit_kzalloc(struct kunit *test, size_t size, gfp_t gfp)
- {
- return kunit_kmalloc(test, size, gfp | __GFP_ZERO);
- }
- /**
- * kunit_kcalloc() - Just like kunit_kmalloc_array(), but zeroes the allocation.
- * @test: The test context object.
- * @n: number of elements.
- * @size: The size in bytes of the desired memory.
- * @gfp: flags passed to underlying kmalloc().
- *
- * See kcalloc() and kunit_kmalloc_array() for more information.
- */
- static inline void *kunit_kcalloc(struct kunit *test, size_t n, size_t size, gfp_t gfp)
- {
- return kunit_kmalloc_array(test, n, size, gfp | __GFP_ZERO);
- }
- void kunit_cleanup(struct kunit *test);
- void __printf(2, 3) kunit_log_append(char *log, const char *fmt, ...);
- /**
- * kunit_mark_skipped() - Marks @test_or_suite as skipped
- *
- * @test_or_suite: The test context object.
- * @fmt: A printk() style format string.
- *
- * Marks the test as skipped. @fmt is given output as the test status
- * comment, typically the reason the test was skipped.
- *
- * Test execution continues after kunit_mark_skipped() is called.
- */
- #define kunit_mark_skipped(test_or_suite, fmt, ...) \
- do { \
- WRITE_ONCE((test_or_suite)->status, KUNIT_SKIPPED); \
- scnprintf((test_or_suite)->status_comment, \
- KUNIT_STATUS_COMMENT_SIZE, \
- fmt, ##__VA_ARGS__); \
- } while (0)
- /**
- * kunit_skip() - Marks @test_or_suite as skipped
- *
- * @test_or_suite: The test context object.
- * @fmt: A printk() style format string.
- *
- * Skips the test. @fmt is given output as the test status
- * comment, typically the reason the test was skipped.
- *
- * Test execution is halted after kunit_skip() is called.
- */
- #define kunit_skip(test_or_suite, fmt, ...) \
- do { \
- kunit_mark_skipped((test_or_suite), fmt, ##__VA_ARGS__);\
- kunit_try_catch_throw(&((test_or_suite)->try_catch)); \
- } while (0)
- /*
- * printk and log to per-test or per-suite log buffer. Logging only done
- * if CONFIG_KUNIT_DEBUGFS is 'y'; if it is 'n', no log is allocated/used.
- */
- #define kunit_log(lvl, test_or_suite, fmt, ...) \
- do { \
- printk(lvl fmt, ##__VA_ARGS__); \
- kunit_log_append((test_or_suite)->log, fmt "\n", \
- ##__VA_ARGS__); \
- } while (0)
- #define kunit_printk(lvl, test, fmt, ...) \
- kunit_log(lvl, test, KUNIT_SUBTEST_INDENT "# %s: " fmt, \
- (test)->name, ##__VA_ARGS__)
- /**
- * kunit_info() - Prints an INFO level message associated with @test.
- *
- * @test: The test context object.
- * @fmt: A printk() style format string.
- *
- * Prints an info level message associated with the test suite being run.
- * Takes a variable number of format parameters just like printk().
- */
- #define kunit_info(test, fmt, ...) \
- kunit_printk(KERN_INFO, test, fmt, ##__VA_ARGS__)
- /**
- * kunit_warn() - Prints a WARN level message associated with @test.
- *
- * @test: The test context object.
- * @fmt: A printk() style format string.
- *
- * Prints a warning level message.
- */
- #define kunit_warn(test, fmt, ...) \
- kunit_printk(KERN_WARNING, test, fmt, ##__VA_ARGS__)
- /**
- * kunit_err() - Prints an ERROR level message associated with @test.
- *
- * @test: The test context object.
- * @fmt: A printk() style format string.
- *
- * Prints an error level message.
- */
- #define kunit_err(test, fmt, ...) \
- kunit_printk(KERN_ERR, test, fmt, ##__VA_ARGS__)
- /**
- * KUNIT_SUCCEED() - A no-op expectation. Only exists for code clarity.
- * @test: The test context object.
- *
- * The opposite of KUNIT_FAIL(), it is an expectation that cannot fail. In other
- * words, it does nothing and only exists for code clarity. See
- * KUNIT_EXPECT_TRUE() for more information.
- */
- #define KUNIT_SUCCEED(test) do {} while (0)
- void kunit_do_failed_assertion(struct kunit *test,
- const struct kunit_loc *loc,
- enum kunit_assert_type type,
- const struct kunit_assert *assert,
- assert_format_t assert_format,
- const char *fmt, ...);
- #define _KUNIT_FAILED(test, assert_type, assert_class, assert_format, INITIALIZER, fmt, ...) do { \
- static const struct kunit_loc __loc = KUNIT_CURRENT_LOC; \
- const struct assert_class __assertion = INITIALIZER; \
- kunit_do_failed_assertion(test, \
- &__loc, \
- assert_type, \
- &__assertion.assert, \
- assert_format, \
- fmt, \
- ##__VA_ARGS__); \
- } while (0)
- #define KUNIT_FAIL_ASSERTION(test, assert_type, fmt, ...) \
- _KUNIT_FAILED(test, \
- assert_type, \
- kunit_fail_assert, \
- kunit_fail_assert_format, \
- {}, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_FAIL() - Always causes a test to fail when evaluated.
- * @test: The test context object.
- * @fmt: an informational message to be printed when the assertion is made.
- * @...: string format arguments.
- *
- * The opposite of KUNIT_SUCCEED(), it is an expectation that always fails. In
- * other words, it always results in a failed expectation, and consequently
- * always causes the test case to fail when evaluated. See KUNIT_EXPECT_TRUE()
- * for more information.
- */
- #define KUNIT_FAIL(test, fmt, ...) \
- KUNIT_FAIL_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- fmt, \
- ##__VA_ARGS__)
- #define KUNIT_UNARY_ASSERTION(test, \
- assert_type, \
- condition, \
- expected_true, \
- fmt, \
- ...) \
- do { \
- if (likely(!!(condition) == !!expected_true)) \
- break; \
- \
- _KUNIT_FAILED(test, \
- assert_type, \
- kunit_unary_assert, \
- kunit_unary_assert_format, \
- KUNIT_INIT_UNARY_ASSERT_STRUCT(#condition, \
- expected_true), \
- fmt, \
- ##__VA_ARGS__); \
- } while (0)
- #define KUNIT_TRUE_MSG_ASSERTION(test, assert_type, condition, fmt, ...) \
- KUNIT_UNARY_ASSERTION(test, \
- assert_type, \
- condition, \
- true, \
- fmt, \
- ##__VA_ARGS__)
- #define KUNIT_FALSE_MSG_ASSERTION(test, assert_type, condition, fmt, ...) \
- KUNIT_UNARY_ASSERTION(test, \
- assert_type, \
- condition, \
- false, \
- fmt, \
- ##__VA_ARGS__)
- /*
- * A factory macro for defining the assertions and expectations for the basic
- * comparisons defined for the built in types.
- *
- * Unfortunately, there is no common type that all types can be promoted to for
- * which all the binary operators behave the same way as for the actual types
- * (for example, there is no type that long long and unsigned long long can
- * both be cast to where the comparison result is preserved for all values). So
- * the best we can do is do the comparison in the original types and then coerce
- * everything to long long for printing; this way, the comparison behaves
- * correctly and the printed out value usually makes sense without
- * interpretation, but can always be interpreted to figure out the actual
- * value.
- */
- #define KUNIT_BASE_BINARY_ASSERTION(test, \
- assert_class, \
- format_func, \
- assert_type, \
- left, \
- op, \
- right, \
- fmt, \
- ...) \
- do { \
- const typeof(left) __left = (left); \
- const typeof(right) __right = (right); \
- static const struct kunit_binary_assert_text __text = { \
- .operation = #op, \
- .left_text = #left, \
- .right_text = #right, \
- }; \
- \
- if (likely(__left op __right)) \
- break; \
- \
- _KUNIT_FAILED(test, \
- assert_type, \
- assert_class, \
- format_func, \
- KUNIT_INIT_BINARY_ASSERT_STRUCT(&__text, \
- __left, \
- __right), \
- fmt, \
- ##__VA_ARGS__); \
- } while (0)
- #define KUNIT_BINARY_INT_ASSERTION(test, \
- assert_type, \
- left, \
- op, \
- right, \
- fmt, \
- ...) \
- KUNIT_BASE_BINARY_ASSERTION(test, \
- kunit_binary_assert, \
- kunit_binary_assert_format, \
- assert_type, \
- left, op, right, \
- fmt, \
- ##__VA_ARGS__)
- #define KUNIT_BINARY_PTR_ASSERTION(test, \
- assert_type, \
- left, \
- op, \
- right, \
- fmt, \
- ...) \
- KUNIT_BASE_BINARY_ASSERTION(test, \
- kunit_binary_ptr_assert, \
- kunit_binary_ptr_assert_format, \
- assert_type, \
- left, op, right, \
- fmt, \
- ##__VA_ARGS__)
- #define KUNIT_BINARY_STR_ASSERTION(test, \
- assert_type, \
- left, \
- op, \
- right, \
- fmt, \
- ...) \
- do { \
- const char *__left = (left); \
- const char *__right = (right); \
- static const struct kunit_binary_assert_text __text = { \
- .operation = #op, \
- .left_text = #left, \
- .right_text = #right, \
- }; \
- \
- if (likely(strcmp(__left, __right) op 0)) \
- break; \
- \
- \
- _KUNIT_FAILED(test, \
- assert_type, \
- kunit_binary_str_assert, \
- kunit_binary_str_assert_format, \
- KUNIT_INIT_BINARY_ASSERT_STRUCT(&__text, \
- __left, \
- __right), \
- fmt, \
- ##__VA_ARGS__); \
- } while (0)
- #define KUNIT_PTR_NOT_ERR_OR_NULL_MSG_ASSERTION(test, \
- assert_type, \
- ptr, \
- fmt, \
- ...) \
- do { \
- const typeof(ptr) __ptr = (ptr); \
- \
- if (!IS_ERR_OR_NULL(__ptr)) \
- break; \
- \
- _KUNIT_FAILED(test, \
- assert_type, \
- kunit_ptr_not_err_assert, \
- kunit_ptr_not_err_assert_format, \
- KUNIT_INIT_PTR_NOT_ERR_STRUCT(#ptr, __ptr), \
- fmt, \
- ##__VA_ARGS__); \
- } while (0)
- /**
- * KUNIT_EXPECT_TRUE() - Causes a test failure when the expression is not true.
- * @test: The test context object.
- * @condition: an arbitrary boolean expression. The test fails when this does
- * not evaluate to true.
- *
- * This and expectations of the form `KUNIT_EXPECT_*` will cause the test case
- * to fail when the specified condition is not met; however, it will not prevent
- * the test case from continuing to run; this is otherwise known as an
- * *expectation failure*.
- */
- #define KUNIT_EXPECT_TRUE(test, condition) \
- KUNIT_EXPECT_TRUE_MSG(test, condition, NULL)
- #define KUNIT_EXPECT_TRUE_MSG(test, condition, fmt, ...) \
- KUNIT_TRUE_MSG_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- condition, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_FALSE() - Makes a test failure when the expression is not false.
- * @test: The test context object.
- * @condition: an arbitrary boolean expression. The test fails when this does
- * not evaluate to false.
- *
- * Sets an expectation that @condition evaluates to false. See
- * KUNIT_EXPECT_TRUE() for more information.
- */
- #define KUNIT_EXPECT_FALSE(test, condition) \
- KUNIT_EXPECT_FALSE_MSG(test, condition, NULL)
- #define KUNIT_EXPECT_FALSE_MSG(test, condition, fmt, ...) \
- KUNIT_FALSE_MSG_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- condition, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_EQ() - Sets an expectation that @left and @right are equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an expectation that the values that @left and @right evaluate to are
- * equal. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, (@left) == (@right)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_EQ(test, left, right) \
- KUNIT_EXPECT_EQ_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_EQ_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, ==, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_PTR_EQ() - Expects that pointers @left and @right are equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a pointer.
- * @right: an arbitrary expression that evaluates to a pointer.
- *
- * Sets an expectation that the values that @left and @right evaluate to are
- * equal. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, (@left) == (@right)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_PTR_EQ(test, left, right) \
- KUNIT_EXPECT_PTR_EQ_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_PTR_EQ_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_PTR_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, ==, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_NE() - An expectation that @left and @right are not equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an expectation that the values that @left and @right evaluate to are not
- * equal. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, (@left) != (@right)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_NE(test, left, right) \
- KUNIT_EXPECT_NE_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_NE_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, !=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_PTR_NE() - Expects that pointers @left and @right are not equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a pointer.
- * @right: an arbitrary expression that evaluates to a pointer.
- *
- * Sets an expectation that the values that @left and @right evaluate to are not
- * equal. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, (@left) != (@right)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_PTR_NE(test, left, right) \
- KUNIT_EXPECT_PTR_NE_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_PTR_NE_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_PTR_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, !=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_LT() - An expectation that @left is less than @right.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an expectation that the value that @left evaluates to is less than the
- * value that @right evaluates to. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, (@left) < (@right)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_LT(test, left, right) \
- KUNIT_EXPECT_LT_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_LT_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, <, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_LE() - Expects that @left is less than or equal to @right.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an expectation that the value that @left evaluates to is less than or
- * equal to the value that @right evaluates to. Semantically this is equivalent
- * to KUNIT_EXPECT_TRUE(@test, (@left) <= (@right)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_LE(test, left, right) \
- KUNIT_EXPECT_LE_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_LE_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, <=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_GT() - An expectation that @left is greater than @right.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an expectation that the value that @left evaluates to is greater than
- * the value that @right evaluates to. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, (@left) > (@right)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_GT(test, left, right) \
- KUNIT_EXPECT_GT_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_GT_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, >, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_GE() - Expects that @left is greater than or equal to @right.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an expectation that the value that @left evaluates to is greater than
- * the value that @right evaluates to. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, (@left) >= (@right)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_GE(test, left, right) \
- KUNIT_EXPECT_GE_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_GE_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, >=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_STREQ() - Expects that strings @left and @right are equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a null terminated string.
- * @right: an arbitrary expression that evaluates to a null terminated string.
- *
- * Sets an expectation that the values that @left and @right evaluate to are
- * equal. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, !strcmp((@left), (@right))). See KUNIT_EXPECT_TRUE()
- * for more information.
- */
- #define KUNIT_EXPECT_STREQ(test, left, right) \
- KUNIT_EXPECT_STREQ_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_STREQ_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_STR_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, ==, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_STRNEQ() - Expects that strings @left and @right are not equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a null terminated string.
- * @right: an arbitrary expression that evaluates to a null terminated string.
- *
- * Sets an expectation that the values that @left and @right evaluate to are
- * not equal. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, strcmp((@left), (@right))). See KUNIT_EXPECT_TRUE()
- * for more information.
- */
- #define KUNIT_EXPECT_STRNEQ(test, left, right) \
- KUNIT_EXPECT_STRNEQ_MSG(test, left, right, NULL)
- #define KUNIT_EXPECT_STRNEQ_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_STR_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- left, !=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_NULL() - Expects that @ptr is null.
- * @test: The test context object.
- * @ptr: an arbitrary pointer.
- *
- * Sets an expectation that the value that @ptr evaluates to is null. This is
- * semantically equivalent to KUNIT_EXPECT_PTR_EQ(@test, ptr, NULL).
- * See KUNIT_EXPECT_TRUE() for more information.
- */
- #define KUNIT_EXPECT_NULL(test, ptr) \
- KUNIT_EXPECT_NULL_MSG(test, \
- ptr, \
- NULL)
- #define KUNIT_EXPECT_NULL_MSG(test, ptr, fmt, ...) \
- KUNIT_BINARY_PTR_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- ptr, ==, NULL, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_NOT_NULL() - Expects that @ptr is not null.
- * @test: The test context object.
- * @ptr: an arbitrary pointer.
- *
- * Sets an expectation that the value that @ptr evaluates to is not null. This
- * is semantically equivalent to KUNIT_EXPECT_PTR_NE(@test, ptr, NULL).
- * See KUNIT_EXPECT_TRUE() for more information.
- */
- #define KUNIT_EXPECT_NOT_NULL(test, ptr) \
- KUNIT_EXPECT_NOT_NULL_MSG(test, \
- ptr, \
- NULL)
- #define KUNIT_EXPECT_NOT_NULL_MSG(test, ptr, fmt, ...) \
- KUNIT_BINARY_PTR_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- ptr, !=, NULL, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_EXPECT_NOT_ERR_OR_NULL() - Expects that @ptr is not null and not err.
- * @test: The test context object.
- * @ptr: an arbitrary pointer.
- *
- * Sets an expectation that the value that @ptr evaluates to is not null and not
- * an errno stored in a pointer. This is semantically equivalent to
- * KUNIT_EXPECT_TRUE(@test, !IS_ERR_OR_NULL(@ptr)). See KUNIT_EXPECT_TRUE() for
- * more information.
- */
- #define KUNIT_EXPECT_NOT_ERR_OR_NULL(test, ptr) \
- KUNIT_EXPECT_NOT_ERR_OR_NULL_MSG(test, ptr, NULL)
- #define KUNIT_EXPECT_NOT_ERR_OR_NULL_MSG(test, ptr, fmt, ...) \
- KUNIT_PTR_NOT_ERR_OR_NULL_MSG_ASSERTION(test, \
- KUNIT_EXPECTATION, \
- ptr, \
- fmt, \
- ##__VA_ARGS__)
- #define KUNIT_ASSERT_FAILURE(test, fmt, ...) \
- KUNIT_FAIL_ASSERTION(test, KUNIT_ASSERTION, fmt, ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_TRUE() - Sets an assertion that @condition is true.
- * @test: The test context object.
- * @condition: an arbitrary boolean expression. The test fails and aborts when
- * this does not evaluate to true.
- *
- * This and assertions of the form `KUNIT_ASSERT_*` will cause the test case to
- * fail *and immediately abort* when the specified condition is not met. Unlike
- * an expectation failure, it will prevent the test case from continuing to run;
- * this is otherwise known as an *assertion failure*.
- */
- #define KUNIT_ASSERT_TRUE(test, condition) \
- KUNIT_ASSERT_TRUE_MSG(test, condition, NULL)
- #define KUNIT_ASSERT_TRUE_MSG(test, condition, fmt, ...) \
- KUNIT_TRUE_MSG_ASSERTION(test, \
- KUNIT_ASSERTION, \
- condition, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_FALSE() - Sets an assertion that @condition is false.
- * @test: The test context object.
- * @condition: an arbitrary boolean expression.
- *
- * Sets an assertion that the value that @condition evaluates to is false. This
- * is the same as KUNIT_EXPECT_FALSE(), except it causes an assertion failure
- * (see KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_FALSE(test, condition) \
- KUNIT_ASSERT_FALSE_MSG(test, condition, NULL)
- #define KUNIT_ASSERT_FALSE_MSG(test, condition, fmt, ...) \
- KUNIT_FALSE_MSG_ASSERTION(test, \
- KUNIT_ASSERTION, \
- condition, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_EQ() - Sets an assertion that @left and @right are equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an assertion that the values that @left and @right evaluate to are
- * equal. This is the same as KUNIT_EXPECT_EQ(), except it causes an assertion
- * failure (see KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_EQ(test, left, right) \
- KUNIT_ASSERT_EQ_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_EQ_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, ==, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_PTR_EQ() - Asserts that pointers @left and @right are equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a pointer.
- * @right: an arbitrary expression that evaluates to a pointer.
- *
- * Sets an assertion that the values that @left and @right evaluate to are
- * equal. This is the same as KUNIT_EXPECT_EQ(), except it causes an assertion
- * failure (see KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_PTR_EQ(test, left, right) \
- KUNIT_ASSERT_PTR_EQ_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_PTR_EQ_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_PTR_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, ==, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_NE() - An assertion that @left and @right are not equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an assertion that the values that @left and @right evaluate to are not
- * equal. This is the same as KUNIT_EXPECT_NE(), except it causes an assertion
- * failure (see KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_NE(test, left, right) \
- KUNIT_ASSERT_NE_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_NE_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, !=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_PTR_NE() - Asserts that pointers @left and @right are not equal.
- * KUNIT_ASSERT_PTR_EQ() - Asserts that pointers @left and @right are equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a pointer.
- * @right: an arbitrary expression that evaluates to a pointer.
- *
- * Sets an assertion that the values that @left and @right evaluate to are not
- * equal. This is the same as KUNIT_EXPECT_NE(), except it causes an assertion
- * failure (see KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_PTR_NE(test, left, right) \
- KUNIT_ASSERT_PTR_NE_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_PTR_NE_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_PTR_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, !=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_LT() - An assertion that @left is less than @right.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an assertion that the value that @left evaluates to is less than the
- * value that @right evaluates to. This is the same as KUNIT_EXPECT_LT(), except
- * it causes an assertion failure (see KUNIT_ASSERT_TRUE()) when the assertion
- * is not met.
- */
- #define KUNIT_ASSERT_LT(test, left, right) \
- KUNIT_ASSERT_LT_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_LT_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, <, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_LE() - An assertion that @left is less than or equal to @right.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an assertion that the value that @left evaluates to is less than or
- * equal to the value that @right evaluates to. This is the same as
- * KUNIT_EXPECT_LE(), except it causes an assertion failure (see
- * KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_LE(test, left, right) \
- KUNIT_ASSERT_LE_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_LE_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, <=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_GT() - An assertion that @left is greater than @right.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an assertion that the value that @left evaluates to is greater than the
- * value that @right evaluates to. This is the same as KUNIT_EXPECT_GT(), except
- * it causes an assertion failure (see KUNIT_ASSERT_TRUE()) when the assertion
- * is not met.
- */
- #define KUNIT_ASSERT_GT(test, left, right) \
- KUNIT_ASSERT_GT_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_GT_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, >, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_GE() - Assertion that @left is greater than or equal to @right.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a primitive C type.
- * @right: an arbitrary expression that evaluates to a primitive C type.
- *
- * Sets an assertion that the value that @left evaluates to is greater than the
- * value that @right evaluates to. This is the same as KUNIT_EXPECT_GE(), except
- * it causes an assertion failure (see KUNIT_ASSERT_TRUE()) when the assertion
- * is not met.
- */
- #define KUNIT_ASSERT_GE(test, left, right) \
- KUNIT_ASSERT_GE_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_GE_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_INT_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, >=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_STREQ() - An assertion that strings @left and @right are equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a null terminated string.
- * @right: an arbitrary expression that evaluates to a null terminated string.
- *
- * Sets an assertion that the values that @left and @right evaluate to are
- * equal. This is the same as KUNIT_EXPECT_STREQ(), except it causes an
- * assertion failure (see KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_STREQ(test, left, right) \
- KUNIT_ASSERT_STREQ_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_STREQ_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_STR_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, ==, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_STRNEQ() - Expects that strings @left and @right are not equal.
- * @test: The test context object.
- * @left: an arbitrary expression that evaluates to a null terminated string.
- * @right: an arbitrary expression that evaluates to a null terminated string.
- *
- * Sets an expectation that the values that @left and @right evaluate to are
- * not equal. This is semantically equivalent to
- * KUNIT_ASSERT_TRUE(@test, strcmp((@left), (@right))). See KUNIT_ASSERT_TRUE()
- * for more information.
- */
- #define KUNIT_ASSERT_STRNEQ(test, left, right) \
- KUNIT_ASSERT_STRNEQ_MSG(test, left, right, NULL)
- #define KUNIT_ASSERT_STRNEQ_MSG(test, left, right, fmt, ...) \
- KUNIT_BINARY_STR_ASSERTION(test, \
- KUNIT_ASSERTION, \
- left, !=, right, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_NULL() - Asserts that pointers @ptr is null.
- * @test: The test context object.
- * @ptr: an arbitrary pointer.
- *
- * Sets an assertion that the values that @ptr evaluates to is null. This is
- * the same as KUNIT_EXPECT_NULL(), except it causes an assertion
- * failure (see KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_NULL(test, ptr) \
- KUNIT_ASSERT_NULL_MSG(test, \
- ptr, \
- NULL)
- #define KUNIT_ASSERT_NULL_MSG(test, ptr, fmt, ...) \
- KUNIT_BINARY_PTR_ASSERTION(test, \
- KUNIT_ASSERTION, \
- ptr, ==, NULL, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_NOT_NULL() - Asserts that pointers @ptr is not null.
- * @test: The test context object.
- * @ptr: an arbitrary pointer.
- *
- * Sets an assertion that the values that @ptr evaluates to is not null. This
- * is the same as KUNIT_EXPECT_NOT_NULL(), except it causes an assertion
- * failure (see KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_NOT_NULL(test, ptr) \
- KUNIT_ASSERT_NOT_NULL_MSG(test, \
- ptr, \
- NULL)
- #define KUNIT_ASSERT_NOT_NULL_MSG(test, ptr, fmt, ...) \
- KUNIT_BINARY_PTR_ASSERTION(test, \
- KUNIT_ASSERTION, \
- ptr, !=, NULL, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ASSERT_NOT_ERR_OR_NULL() - Assertion that @ptr is not null and not err.
- * @test: The test context object.
- * @ptr: an arbitrary pointer.
- *
- * Sets an assertion that the value that @ptr evaluates to is not null and not
- * an errno stored in a pointer. This is the same as
- * KUNIT_EXPECT_NOT_ERR_OR_NULL(), except it causes an assertion failure (see
- * KUNIT_ASSERT_TRUE()) when the assertion is not met.
- */
- #define KUNIT_ASSERT_NOT_ERR_OR_NULL(test, ptr) \
- KUNIT_ASSERT_NOT_ERR_OR_NULL_MSG(test, ptr, NULL)
- #define KUNIT_ASSERT_NOT_ERR_OR_NULL_MSG(test, ptr, fmt, ...) \
- KUNIT_PTR_NOT_ERR_OR_NULL_MSG_ASSERTION(test, \
- KUNIT_ASSERTION, \
- ptr, \
- fmt, \
- ##__VA_ARGS__)
- /**
- * KUNIT_ARRAY_PARAM() - Define test parameter generator from an array.
- * @name: prefix for the test parameter generator function.
- * @array: array of test parameters.
- * @get_desc: function to convert param to description; NULL to use default
- *
- * Define function @name_gen_params which uses @array to generate parameters.
- */
- #define KUNIT_ARRAY_PARAM(name, array, get_desc) \
- static const void *name##_gen_params(const void *prev, char *desc) \
- { \
- typeof((array)[0]) *__next = prev ? ((typeof(__next)) prev) + 1 : (array); \
- if (__next - (array) < ARRAY_SIZE((array))) { \
- void (*__get_desc)(typeof(__next), char *) = get_desc; \
- if (__get_desc) \
- __get_desc(__next, desc); \
- return __next; \
- } \
- return NULL; \
- }
- #ifdef CONFIG_SEC_KUNIT
- /*
- * for mock feature from kunit/alpha/master
- */
- struct test_initcall {
- struct list_head node;
- int (*init)(struct test_initcall *this, struct kunit *test);
- void (*exit)(struct test_initcall *this);
- };
- struct kunit_post_condition {
- struct list_head node;
- void (*validate)(struct kunit_post_condition *condition);
- };
- void test_install_initcall(struct test_initcall *initcall);
- #define test_pure_initcall(fn) postcore_initcall(fn)
- #define test_register_initcall(initcall) \
- static int register_test_initcall_##initcall(void) \
- { \
- test_install_initcall(&initcall); \
- \
- return 0; \
- } \
- test_pure_initcall(register_test_initcall_##initcall)
- #endif /* CONFIG_SEC_KUNIT */
- // TODO([email protected]): consider eventually migrating users to explicitly
- // include resource.h themselves if they need it.
- #include <kunit/resource.h>
- #endif /* _KUNIT_TEST_H */
|