mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/netdev/net.git/
synced 2026-04-17 22:23:45 -04:00
Merge tag 'linux-kselftest-kunit-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
Pull KUnit updates from Shuah Khan: - several fixes to kunit tool - new klist structure test - support for m68k under QEMU - support for overriding the QEMU serial port - support for SH under QEMU * tag 'linux-kselftest-kunit-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest: kunit: add tests for using current KUnit test field kunit: tool: Add support for SH under QEMU kunit: tool: Add support for overriding the QEMU serial port .gitignore: Unignore .kunitconfig list: test: Test the klist structure kunit: increase KUNIT_LOG_SIZE to 2048 bytes kunit: Use gfp in kunit_alloc_resource() kernel-doc kunit: tool: fix pre-existing `mypy --strict` errors and update run_checks.py kunit: tool: remove unused imports and variables kunit: tool: add subscripts for type annotations where appropriate kunit: fix bug of extra newline characters in debugfs logs kunit: fix bug in the order of lines in debugfs logs kunit: fix bug in debugfs logs of parameterized tests kunit: tool: Add support for m68k under QEMU
This commit is contained in:
@@ -55,14 +55,24 @@ static int debugfs_print_results(struct seq_file *seq, void *v)
|
||||
enum kunit_status success = kunit_suite_has_succeeded(suite);
|
||||
struct kunit_case *test_case;
|
||||
|
||||
if (!suite || !suite->log)
|
||||
if (!suite)
|
||||
return 0;
|
||||
|
||||
seq_printf(seq, "%s", suite->log);
|
||||
/* Print KTAP header so the debugfs log can be parsed as valid KTAP. */
|
||||
seq_puts(seq, "KTAP version 1\n");
|
||||
seq_puts(seq, "1..1\n");
|
||||
|
||||
/* Print suite header because it is not stored in the test logs. */
|
||||
seq_puts(seq, KUNIT_SUBTEST_INDENT "KTAP version 1\n");
|
||||
seq_printf(seq, KUNIT_SUBTEST_INDENT "# Subtest: %s\n", suite->name);
|
||||
seq_printf(seq, KUNIT_SUBTEST_INDENT "1..%zd\n", kunit_suite_num_test_cases(suite));
|
||||
|
||||
kunit_suite_for_each_test_case(suite, test_case)
|
||||
debugfs_print_result(seq, suite, test_case);
|
||||
|
||||
if (suite->log)
|
||||
seq_printf(seq, "%s", suite->log);
|
||||
|
||||
seq_printf(seq, "%s %d %s\n",
|
||||
kunit_status_to_ok_not_ok(success), 1, suite->name);
|
||||
return 0;
|
||||
|
||||
@@ -6,6 +6,7 @@
|
||||
* Author: Brendan Higgins <brendanhiggins@google.com>
|
||||
*/
|
||||
#include <kunit/test.h>
|
||||
#include <kunit/test-bug.h>
|
||||
|
||||
#include "try-catch-impl.h"
|
||||
|
||||
@@ -443,18 +444,6 @@ static struct kunit_suite kunit_resource_test_suite = {
|
||||
.test_cases = kunit_resource_test_cases,
|
||||
};
|
||||
|
||||
static void kunit_log_test(struct kunit *test);
|
||||
|
||||
static struct kunit_case kunit_log_test_cases[] = {
|
||||
KUNIT_CASE(kunit_log_test),
|
||||
{}
|
||||
};
|
||||
|
||||
static struct kunit_suite kunit_log_test_suite = {
|
||||
.name = "kunit-log-test",
|
||||
.test_cases = kunit_log_test_cases,
|
||||
};
|
||||
|
||||
static void kunit_log_test(struct kunit *test)
|
||||
{
|
||||
struct kunit_suite suite;
|
||||
@@ -481,6 +470,29 @@ static void kunit_log_test(struct kunit *test)
|
||||
#endif
|
||||
}
|
||||
|
||||
static void kunit_log_newline_test(struct kunit *test)
|
||||
{
|
||||
kunit_info(test, "Add newline\n");
|
||||
if (test->log) {
|
||||
KUNIT_ASSERT_NOT_NULL_MSG(test, strstr(test->log, "Add newline\n"),
|
||||
"Missing log line, full log:\n%s", test->log);
|
||||
KUNIT_EXPECT_NULL(test, strstr(test->log, "Add newline\n\n"));
|
||||
} else {
|
||||
kunit_skip(test, "only useful when debugfs is enabled");
|
||||
}
|
||||
}
|
||||
|
||||
static struct kunit_case kunit_log_test_cases[] = {
|
||||
KUNIT_CASE(kunit_log_test),
|
||||
KUNIT_CASE(kunit_log_newline_test),
|
||||
{}
|
||||
};
|
||||
|
||||
static struct kunit_suite kunit_log_test_suite = {
|
||||
.name = "kunit-log-test",
|
||||
.test_cases = kunit_log_test_cases,
|
||||
};
|
||||
|
||||
static void kunit_status_set_failure_test(struct kunit *test)
|
||||
{
|
||||
struct kunit fake;
|
||||
@@ -521,7 +533,46 @@ static struct kunit_suite kunit_status_test_suite = {
|
||||
.test_cases = kunit_status_test_cases,
|
||||
};
|
||||
|
||||
static void kunit_current_test(struct kunit *test)
|
||||
{
|
||||
/* Check results of both current->kunit_test and
|
||||
* kunit_get_current_test() are equivalent to current test.
|
||||
*/
|
||||
KUNIT_EXPECT_PTR_EQ(test, test, current->kunit_test);
|
||||
KUNIT_EXPECT_PTR_EQ(test, test, kunit_get_current_test());
|
||||
}
|
||||
|
||||
static void kunit_current_fail_test(struct kunit *test)
|
||||
{
|
||||
struct kunit fake;
|
||||
|
||||
kunit_init_test(&fake, "fake test", NULL);
|
||||
KUNIT_EXPECT_EQ(test, fake.status, KUNIT_SUCCESS);
|
||||
|
||||
/* Set current->kunit_test to fake test. */
|
||||
current->kunit_test = &fake;
|
||||
|
||||
kunit_fail_current_test("This should make `fake` test fail.");
|
||||
KUNIT_EXPECT_EQ(test, fake.status, (enum kunit_status)KUNIT_FAILURE);
|
||||
kunit_cleanup(&fake);
|
||||
|
||||
/* Reset current->kunit_test to current test. */
|
||||
current->kunit_test = test;
|
||||
}
|
||||
|
||||
static struct kunit_case kunit_current_test_cases[] = {
|
||||
KUNIT_CASE(kunit_current_test),
|
||||
KUNIT_CASE(kunit_current_fail_test),
|
||||
{}
|
||||
};
|
||||
|
||||
static struct kunit_suite kunit_current_test_suite = {
|
||||
.name = "kunit_current",
|
||||
.test_cases = kunit_current_test_cases,
|
||||
};
|
||||
|
||||
kunit_test_suites(&kunit_try_catch_test_suite, &kunit_resource_test_suite,
|
||||
&kunit_log_test_suite, &kunit_status_test_suite);
|
||||
&kunit_log_test_suite, &kunit_status_test_suite,
|
||||
&kunit_current_test_suite);
|
||||
|
||||
MODULE_LICENSE("GPL v2");
|
||||
|
||||
@@ -108,28 +108,51 @@ static void kunit_print_test_stats(struct kunit *test,
|
||||
stats.total);
|
||||
}
|
||||
|
||||
/**
|
||||
* kunit_log_newline() - Add newline to the end of log if one is not
|
||||
* already present.
|
||||
* @log: The log to add the newline to.
|
||||
*/
|
||||
static void kunit_log_newline(char *log)
|
||||
{
|
||||
int log_len, len_left;
|
||||
|
||||
log_len = strlen(log);
|
||||
len_left = KUNIT_LOG_SIZE - log_len - 1;
|
||||
|
||||
if (log_len > 0 && log[log_len - 1] != '\n')
|
||||
strncat(log, "\n", len_left);
|
||||
}
|
||||
|
||||
/*
|
||||
* Append formatted message to log, size of which is limited to
|
||||
* KUNIT_LOG_SIZE bytes (including null terminating byte).
|
||||
*/
|
||||
void kunit_log_append(char *log, const char *fmt, ...)
|
||||
{
|
||||
char line[KUNIT_LOG_SIZE];
|
||||
va_list args;
|
||||
int len_left;
|
||||
int len, log_len, len_left;
|
||||
|
||||
if (!log)
|
||||
return;
|
||||
|
||||
len_left = KUNIT_LOG_SIZE - strlen(log) - 1;
|
||||
log_len = strlen(log);
|
||||
len_left = KUNIT_LOG_SIZE - log_len - 1;
|
||||
if (len_left <= 0)
|
||||
return;
|
||||
|
||||
/* Evaluate length of line to add to log */
|
||||
va_start(args, fmt);
|
||||
vsnprintf(line, sizeof(line), fmt, args);
|
||||
len = vsnprintf(NULL, 0, fmt, args) + 1;
|
||||
va_end(args);
|
||||
|
||||
strncat(log, line, len_left);
|
||||
/* Print formatted line to the log */
|
||||
va_start(args, fmt);
|
||||
vsnprintf(log + log_len, min(len, len_left), fmt, args);
|
||||
va_end(args);
|
||||
|
||||
/* Add newline to end of log if not already present. */
|
||||
kunit_log_newline(log);
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(kunit_log_append);
|
||||
|
||||
@@ -147,10 +170,18 @@ EXPORT_SYMBOL_GPL(kunit_suite_num_test_cases);
|
||||
|
||||
static void kunit_print_suite_start(struct kunit_suite *suite)
|
||||
{
|
||||
kunit_log(KERN_INFO, suite, KUNIT_SUBTEST_INDENT "KTAP version 1\n");
|
||||
kunit_log(KERN_INFO, suite, KUNIT_SUBTEST_INDENT "# Subtest: %s",
|
||||
/*
|
||||
* We do not log the test suite header as doing so would
|
||||
* mean debugfs display would consist of the test suite
|
||||
* header prior to individual test results.
|
||||
* Hence directly printk the suite status, and we will
|
||||
* separately seq_printf() the suite header for the debugfs
|
||||
* representation.
|
||||
*/
|
||||
pr_info(KUNIT_SUBTEST_INDENT "KTAP version 1\n");
|
||||
pr_info(KUNIT_SUBTEST_INDENT "# Subtest: %s\n",
|
||||
suite->name);
|
||||
kunit_log(KERN_INFO, suite, KUNIT_SUBTEST_INDENT "1..%zd",
|
||||
pr_info(KUNIT_SUBTEST_INDENT "1..%zd\n",
|
||||
kunit_suite_num_test_cases(suite));
|
||||
}
|
||||
|
||||
@@ -167,10 +198,9 @@ static void kunit_print_ok_not_ok(void *test_or_suite,
|
||||
|
||||
/*
|
||||
* We do not log the test suite results as doing so would
|
||||
* mean debugfs display would consist of the test suite
|
||||
* description and status prior to individual test results.
|
||||
* Hence directly printk the suite status, and we will
|
||||
* separately seq_printf() the suite status for the debugfs
|
||||
* mean debugfs display would consist of an incorrect test
|
||||
* number. Hence directly printk the suite result, and we will
|
||||
* separately seq_printf() the suite results for the debugfs
|
||||
* representation.
|
||||
*/
|
||||
if (suite)
|
||||
@@ -437,7 +467,6 @@ static void kunit_run_case_catch_errors(struct kunit_suite *suite,
|
||||
struct kunit_try_catch_context context;
|
||||
struct kunit_try_catch *try_catch;
|
||||
|
||||
kunit_init_test(test, test_case->name, test_case->log);
|
||||
try_catch = &test->try_catch;
|
||||
|
||||
kunit_try_catch_init(try_catch,
|
||||
@@ -533,6 +562,8 @@ int kunit_run_tests(struct kunit_suite *suite)
|
||||
struct kunit_result_stats param_stats = { 0 };
|
||||
test_case->status = KUNIT_SKIPPED;
|
||||
|
||||
kunit_init_test(&test, test_case->name, test_case->log);
|
||||
|
||||
if (!test_case->generate_params) {
|
||||
/* Non-parameterised test. */
|
||||
kunit_run_case_catch_errors(suite, test_case, &test);
|
||||
|
||||
300
lib/list-test.c
300
lib/list-test.c
@@ -8,6 +8,7 @@
|
||||
#include <kunit/test.h>
|
||||
|
||||
#include <linux/list.h>
|
||||
#include <linux/klist.h>
|
||||
|
||||
struct list_test_struct {
|
||||
int data;
|
||||
@@ -1199,6 +1200,303 @@ static struct kunit_suite hlist_test_module = {
|
||||
.test_cases = hlist_test_cases,
|
||||
};
|
||||
|
||||
kunit_test_suites(&list_test_module, &hlist_test_module);
|
||||
|
||||
struct klist_test_struct {
|
||||
int data;
|
||||
struct klist klist;
|
||||
struct klist_node klist_node;
|
||||
};
|
||||
|
||||
static int node_count;
|
||||
static struct klist_node *last_node;
|
||||
|
||||
static void check_node(struct klist_node *node_ptr)
|
||||
{
|
||||
node_count++;
|
||||
last_node = node_ptr;
|
||||
}
|
||||
|
||||
static void check_delete_node(struct klist_node *node_ptr)
|
||||
{
|
||||
node_count--;
|
||||
last_node = node_ptr;
|
||||
}
|
||||
|
||||
static void klist_test_add_tail(struct kunit *test)
|
||||
{
|
||||
struct klist_node a, b;
|
||||
struct klist mylist;
|
||||
struct klist_iter i;
|
||||
|
||||
node_count = 0;
|
||||
klist_init(&mylist, &check_node, NULL);
|
||||
|
||||
klist_add_tail(&a, &mylist);
|
||||
KUNIT_EXPECT_EQ(test, node_count, 1);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &a);
|
||||
|
||||
klist_add_tail(&b, &mylist);
|
||||
KUNIT_EXPECT_EQ(test, node_count, 2);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &b);
|
||||
|
||||
/* should be [list] -> a -> b */
|
||||
klist_iter_init(&mylist, &i);
|
||||
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &a);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &b);
|
||||
KUNIT_EXPECT_NULL(test, klist_next(&i));
|
||||
|
||||
klist_iter_exit(&i);
|
||||
|
||||
}
|
||||
|
||||
static void klist_test_add_head(struct kunit *test)
|
||||
{
|
||||
struct klist_node a, b;
|
||||
struct klist mylist;
|
||||
struct klist_iter i;
|
||||
|
||||
node_count = 0;
|
||||
klist_init(&mylist, &check_node, NULL);
|
||||
|
||||
klist_add_head(&a, &mylist);
|
||||
KUNIT_EXPECT_EQ(test, node_count, 1);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &a);
|
||||
|
||||
klist_add_head(&b, &mylist);
|
||||
KUNIT_EXPECT_EQ(test, node_count, 2);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &b);
|
||||
|
||||
/* should be [list] -> b -> a */
|
||||
klist_iter_init(&mylist, &i);
|
||||
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &b);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &a);
|
||||
KUNIT_EXPECT_NULL(test, klist_next(&i));
|
||||
|
||||
klist_iter_exit(&i);
|
||||
|
||||
}
|
||||
|
||||
static void klist_test_add_behind(struct kunit *test)
|
||||
{
|
||||
struct klist_node a, b, c, d;
|
||||
struct klist mylist;
|
||||
struct klist_iter i;
|
||||
|
||||
node_count = 0;
|
||||
klist_init(&mylist, &check_node, NULL);
|
||||
|
||||
klist_add_head(&a, &mylist);
|
||||
klist_add_head(&b, &mylist);
|
||||
|
||||
klist_add_behind(&c, &a);
|
||||
KUNIT_EXPECT_EQ(test, node_count, 3);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &c);
|
||||
|
||||
klist_add_behind(&d, &b);
|
||||
KUNIT_EXPECT_EQ(test, node_count, 4);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &d);
|
||||
|
||||
klist_iter_init(&mylist, &i);
|
||||
|
||||
/* should be [list] -> b -> d -> a -> c*/
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &b);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &d);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &a);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &c);
|
||||
KUNIT_EXPECT_NULL(test, klist_next(&i));
|
||||
|
||||
klist_iter_exit(&i);
|
||||
|
||||
}
|
||||
|
||||
static void klist_test_add_before(struct kunit *test)
|
||||
{
|
||||
struct klist_node a, b, c, d;
|
||||
struct klist mylist;
|
||||
struct klist_iter i;
|
||||
|
||||
node_count = 0;
|
||||
klist_init(&mylist, &check_node, NULL);
|
||||
|
||||
klist_add_head(&a, &mylist);
|
||||
klist_add_head(&b, &mylist);
|
||||
klist_add_before(&c, &a);
|
||||
KUNIT_EXPECT_EQ(test, node_count, 3);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &c);
|
||||
|
||||
klist_add_before(&d, &b);
|
||||
KUNIT_EXPECT_EQ(test, node_count, 4);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &d);
|
||||
|
||||
klist_iter_init(&mylist, &i);
|
||||
|
||||
/* should be [list] -> b -> d -> a -> c*/
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &d);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &b);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &c);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &a);
|
||||
KUNIT_EXPECT_NULL(test, klist_next(&i));
|
||||
|
||||
klist_iter_exit(&i);
|
||||
|
||||
}
|
||||
|
||||
/*
|
||||
* Verify that klist_del() delays the deletion of a node until there
|
||||
* are no other references to it
|
||||
*/
|
||||
static void klist_test_del_refcount_greater_than_zero(struct kunit *test)
|
||||
{
|
||||
struct klist_node a, b, c, d;
|
||||
struct klist mylist;
|
||||
struct klist_iter i;
|
||||
|
||||
node_count = 0;
|
||||
klist_init(&mylist, &check_node, &check_delete_node);
|
||||
|
||||
/* Add nodes a,b,c,d to the list*/
|
||||
klist_add_tail(&a, &mylist);
|
||||
klist_add_tail(&b, &mylist);
|
||||
klist_add_tail(&c, &mylist);
|
||||
klist_add_tail(&d, &mylist);
|
||||
|
||||
klist_iter_init(&mylist, &i);
|
||||
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &a);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &b);
|
||||
/* Advance the iterator to point to node c*/
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &c);
|
||||
|
||||
/* Try to delete node c while there is a reference to it*/
|
||||
klist_del(&c);
|
||||
|
||||
/*
|
||||
* Verify that node c is still attached to the list even after being
|
||||
* deleted. Since the iterator still points to c, the reference count is not
|
||||
* decreased to 0
|
||||
*/
|
||||
KUNIT_EXPECT_TRUE(test, klist_node_attached(&c));
|
||||
|
||||
/* Check that node c has not been removed yet*/
|
||||
KUNIT_EXPECT_EQ(test, node_count, 4);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &d);
|
||||
|
||||
klist_iter_exit(&i);
|
||||
|
||||
/*
|
||||
* Since the iterator is no longer pointing to node c, node c is removed
|
||||
* from the list
|
||||
*/
|
||||
KUNIT_EXPECT_EQ(test, node_count, 3);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &c);
|
||||
|
||||
}
|
||||
|
||||
/*
|
||||
* Verify that klist_del() deletes a node immediately when there are no
|
||||
* other references to it.
|
||||
*/
|
||||
static void klist_test_del_refcount_zero(struct kunit *test)
|
||||
{
|
||||
struct klist_node a, b, c, d;
|
||||
struct klist mylist;
|
||||
struct klist_iter i;
|
||||
|
||||
node_count = 0;
|
||||
klist_init(&mylist, &check_node, &check_delete_node);
|
||||
|
||||
/* Add nodes a,b,c,d to the list*/
|
||||
klist_add_tail(&a, &mylist);
|
||||
klist_add_tail(&b, &mylist);
|
||||
klist_add_tail(&c, &mylist);
|
||||
klist_add_tail(&d, &mylist);
|
||||
/* Delete node c*/
|
||||
klist_del(&c);
|
||||
|
||||
/* Check that node c is deleted from the list*/
|
||||
KUNIT_EXPECT_EQ(test, node_count, 3);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &c);
|
||||
|
||||
/* Should be [list] -> a -> b -> d*/
|
||||
klist_iter_init(&mylist, &i);
|
||||
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &a);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &b);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &d);
|
||||
KUNIT_EXPECT_NULL(test, klist_next(&i));
|
||||
|
||||
klist_iter_exit(&i);
|
||||
|
||||
}
|
||||
|
||||
static void klist_test_remove(struct kunit *test)
|
||||
{
|
||||
/* This test doesn't check correctness under concurrent access */
|
||||
struct klist_node a, b, c, d;
|
||||
struct klist mylist;
|
||||
struct klist_iter i;
|
||||
|
||||
node_count = 0;
|
||||
klist_init(&mylist, &check_node, &check_delete_node);
|
||||
|
||||
/* Add nodes a,b,c,d to the list*/
|
||||
klist_add_tail(&a, &mylist);
|
||||
klist_add_tail(&b, &mylist);
|
||||
klist_add_tail(&c, &mylist);
|
||||
klist_add_tail(&d, &mylist);
|
||||
/* Delete node c*/
|
||||
klist_remove(&c);
|
||||
|
||||
/* Check the nodes in the list*/
|
||||
KUNIT_EXPECT_EQ(test, node_count, 3);
|
||||
KUNIT_EXPECT_PTR_EQ(test, last_node, &c);
|
||||
|
||||
/* should be [list] -> a -> b -> d*/
|
||||
klist_iter_init(&mylist, &i);
|
||||
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &a);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &b);
|
||||
KUNIT_EXPECT_PTR_EQ(test, klist_next(&i), &d);
|
||||
KUNIT_EXPECT_NULL(test, klist_next(&i));
|
||||
|
||||
klist_iter_exit(&i);
|
||||
|
||||
}
|
||||
|
||||
static void klist_test_node_attached(struct kunit *test)
|
||||
{
|
||||
struct klist_node a = {};
|
||||
struct klist mylist;
|
||||
|
||||
klist_init(&mylist, NULL, NULL);
|
||||
|
||||
KUNIT_EXPECT_FALSE(test, klist_node_attached(&a));
|
||||
klist_add_head(&a, &mylist);
|
||||
KUNIT_EXPECT_TRUE(test, klist_node_attached(&a));
|
||||
klist_del(&a);
|
||||
KUNIT_EXPECT_FALSE(test, klist_node_attached(&a));
|
||||
|
||||
}
|
||||
|
||||
static struct kunit_case klist_test_cases[] = {
|
||||
KUNIT_CASE(klist_test_add_tail),
|
||||
KUNIT_CASE(klist_test_add_head),
|
||||
KUNIT_CASE(klist_test_add_behind),
|
||||
KUNIT_CASE(klist_test_add_before),
|
||||
KUNIT_CASE(klist_test_del_refcount_greater_than_zero),
|
||||
KUNIT_CASE(klist_test_del_refcount_zero),
|
||||
KUNIT_CASE(klist_test_remove),
|
||||
KUNIT_CASE(klist_test_node_attached),
|
||||
{},
|
||||
};
|
||||
|
||||
static struct kunit_suite klist_test_module = {
|
||||
.name = "klist",
|
||||
.test_cases = klist_test_cases,
|
||||
};
|
||||
|
||||
kunit_test_suites(&list_test_module, &hlist_test_module, &klist_test_module);
|
||||
|
||||
MODULE_LICENSE("GPL v2");
|
||||
|
||||
Reference in New Issue
Block a user