1 // SPDX-License-Identifier: GPL-2.0+
9 #include <asm/global_data.h>
13 DECLARE_GLOBAL_DATA_PTR;
15 /* Test invalid options */
16 static int log_test_filter_invalid(struct unit_test_state *uts)
18 ut_asserteq(1, run_command("log filter-add -AD", 0));
19 ut_asserteq(1, run_command("log filter-add -l1 -L1", 0));
20 ut_asserteq(1, run_command("log filter-add -l1 -L1", 0));
21 ut_asserteq(1, run_command("log filter-add -lfoo", 0));
22 ut_asserteq(1, run_command("log filter-add -cfoo", 0));
23 ut_asserteq(1, run_command("log filter-add -ccore -ccore -ccore -ccore "
28 LOG_TEST_FLAGS(log_test_filter_invalid, UT_TESTF_CONSOLE_REC);
30 /* Test adding and removing filters */
31 static int log_test_filter(struct unit_test_state *uts)
33 bool any_found = false;
34 bool filt1_found = false;
35 bool filt2_found = false;
37 struct log_filter *filt;
38 struct log_device *ldev;
41 #define create_filter(args, filter_num) do {\
42 ut_assertok(console_record_reset_enable()); \
43 ut_assertok(run_command("log filter-add -p " args, 0)); \
44 ut_assert_skipline(); \
45 ut_assertok(strict_strtoul(uts->actual_str, 10, &(filter_num))); \
46 ut_assert_console_end(); \
49 create_filter("", filt1);
50 create_filter("-DL warning -cmmc -cspi -ffile", filt2);
52 ldev = log_device_find_by_name("console");
53 ut_assertnonnull(ldev);
54 list_for_each_entry(filt, &ldev->filter_head, sibling_node) {
55 if (filt->filter_num == filt1) {
57 ut_asserteq(0, filt->flags);
58 ut_asserteq(LOGL_MAX, filt->level);
59 ut_assertnull(filt->file_list);
60 } else if (filt->filter_num == filt2) {
62 ut_asserteq(LOGFF_HAS_CAT | LOGFF_DENY |
63 LOGFF_LEVEL_MIN, filt->flags);
64 ut_asserteq(true, log_has_cat(filt->cat_list,
65 log_uc_cat(UCLASS_MMC)));
66 ut_asserteq(true, log_has_cat(filt->cat_list,
67 log_uc_cat(UCLASS_SPI)));
68 ut_asserteq(LOGL_WARNING, filt->level);
69 ut_asserteq_str("file", filt->file_list);
72 ut_asserteq(true, filt1_found);
73 ut_asserteq(true, filt2_found);
75 #define remove_filter(filter_num) do { \
76 ut_assertok(console_record_reset_enable()); \
77 snprintf(cmd, sizeof(cmd), "log filter-remove %lu", filter_num); \
78 ut_assertok(run_command(cmd, 0)); \
79 ut_assert_console_end(); \
87 list_for_each_entry(filt, &ldev->filter_head, sibling_node) {
88 if (filt->filter_num == filt1)
90 else if (filt->filter_num == filt2)
93 ut_asserteq(false, filt1_found);
94 ut_asserteq(false, filt2_found);
96 create_filter("", filt1);
97 create_filter("", filt2);
99 ut_assertok(console_record_reset_enable());
100 ut_assertok(run_command("log filter-remove -a", 0));
101 ut_assert_console_end();
103 list_for_each_entry(filt, &ldev->filter_head, sibling_node)
105 ut_asserteq(false, any_found);
109 LOG_TEST_FLAGS(log_test_filter, UT_TESTF_CONSOLE_REC);