1 // SPDX-License-Identifier: GPL-2.0+
3 * Test for bootdev functions. All start with 'bootmeth'
5 * Copyright 2021 Google LLC
6 * Written by Simon Glass <sjg@chromium.org>
13 #include <test/suites.h>
15 #include "bootstd_common.h"
17 /* Check 'bootmeth list' command */
18 static int bootmeth_cmd_list(struct unit_test_state *uts)
20 console_record_reset_enable();
21 ut_assertok(run_command("bootmeth list", 0));
22 ut_assert_nextline("Order Seq Name Description");
23 ut_assert_nextlinen("---");
24 ut_assert_nextline(" 0 0 syslinux Syslinux boot from a block device");
25 ut_assert_nextline(" 1 1 efi EFI boot from an .efi file");
26 if (IS_ENABLED(CONFIG_BOOTMETH_GLOBAL))
27 ut_assert_nextline(" glob 2 firmware0 VBE simple");
28 ut_assert_nextlinen("---");
29 ut_assert_nextline(IS_ENABLED(CONFIG_BOOTMETH_GLOBAL) ?
30 "(3 bootmeths)" : "(2 bootmeths)");
31 ut_assert_console_end();
35 BOOTSTD_TEST(bootmeth_cmd_list, UT_TESTF_DM | UT_TESTF_SCAN_FDT);
37 /* Check 'bootmeth order' command */
38 static int bootmeth_cmd_order(struct unit_test_state *uts)
40 /* Select just one bootmethod */
41 console_record_reset_enable();
42 ut_assertok(run_command("bootmeth order syslinux", 0));
43 ut_assert_console_end();
44 ut_assertnonnull(env_get("bootmeths"));
45 ut_asserteq_str("syslinux", env_get("bootmeths"));
47 /* Only that one should be listed */
48 ut_assertok(run_command("bootmeth list", 0));
49 ut_assert_nextline("Order Seq Name Description");
50 ut_assert_nextlinen("---");
51 ut_assert_nextline(" 0 0 syslinux Syslinux boot from a block device");
52 ut_assert_nextlinen("---");
53 ut_assert_nextline("(1 bootmeth)");
54 ut_assert_console_end();
56 /* Check the -a flag, efi should show as not in the order ("-") */
57 ut_assertok(run_command("bootmeth list -a", 0));
58 ut_assert_nextline("Order Seq Name Description");
59 ut_assert_nextlinen("---");
60 ut_assert_nextline(" 0 0 syslinux Syslinux boot from a block device");
61 ut_assert_nextline(" - 1 efi EFI boot from an .efi file");
62 if (IS_ENABLED(CONFIG_BOOTMETH_GLOBAL))
63 ut_assert_nextline(" glob 2 firmware0 VBE simple");
64 ut_assert_nextlinen("---");
65 ut_assert_nextline(IS_ENABLED(CONFIG_BOOTMETH_GLOBAL) ?
66 "(3 bootmeths)" : "(2 bootmeths)");
67 ut_assert_console_end();
69 /* Check the -a flag with the reverse order */
70 ut_assertok(run_command("bootmeth order \"efi syslinux\"", 0));
71 ut_assert_console_end();
72 ut_assertok(run_command("bootmeth list -a", 0));
73 ut_assert_nextline("Order Seq Name Description");
74 ut_assert_nextlinen("---");
75 ut_assert_nextline(" 1 0 syslinux Syslinux boot from a block device");
76 ut_assert_nextline(" 0 1 efi EFI boot from an .efi file");
77 if (IS_ENABLED(CONFIG_BOOTMETH_GLOBAL))
78 ut_assert_nextline(" glob 2 firmware0 VBE simple");
79 ut_assert_nextlinen("---");
80 ut_assert_nextline(IS_ENABLED(CONFIG_BOOTMETH_GLOBAL) ?
81 "(3 bootmeths)" : "(2 bootmeths)");
82 ut_assert_console_end();
84 /* Now reset the order to empty, which should show all of them again */
85 ut_assertok(run_command("bootmeth order", 0));
86 ut_assert_console_end();
87 ut_assertnull(env_get("bootmeths"));
88 ut_assertok(run_command("bootmeth list", 0));
89 ut_assert_skip_to_line(IS_ENABLED(CONFIG_BOOTMETH_GLOBAL) ?
90 "(3 bootmeths)" : "(2 bootmeths)");
92 /* Try reverse order */
93 ut_assertok(run_command("bootmeth order \"efi syslinux\"", 0));
94 ut_assert_console_end();
95 ut_assertok(run_command("bootmeth list", 0));
96 ut_assert_nextline("Order Seq Name Description");
97 ut_assert_nextlinen("---");
98 ut_assert_nextline(" 0 1 efi EFI boot from an .efi file");
99 ut_assert_nextline(" 1 0 syslinux Syslinux boot from a block device");
100 ut_assert_nextlinen("---");
101 ut_assert_nextline("(2 bootmeths)");
102 ut_assertnonnull(env_get("bootmeths"));
103 ut_asserteq_str("efi syslinux", env_get("bootmeths"));
104 ut_assert_console_end();
106 /* Try with global bootmeths */
107 if (!IS_ENABLED(CONFIG_BOOTMETH_GLOBAL))
110 ut_assertok(run_command("bootmeth order \"efi firmware0\"", 0));
111 ut_assert_console_end();
112 ut_assertok(run_command("bootmeth list", 0));
113 ut_assert_nextline("Order Seq Name Description");
114 ut_assert_nextlinen("---");
115 ut_assert_nextline(" 0 1 efi EFI boot from an .efi file");
116 ut_assert_nextline(" glob 2 firmware0 VBE simple");
117 ut_assert_nextlinen("---");
118 ut_assert_nextline("(2 bootmeths)");
119 ut_assertnonnull(env_get("bootmeths"));
120 ut_asserteq_str("efi firmware0", env_get("bootmeths"));
121 ut_assert_console_end();
125 BOOTSTD_TEST(bootmeth_cmd_order, UT_TESTF_DM | UT_TESTF_SCAN_FDT);
127 /* Check 'bootmeths' env var */
128 static int bootmeth_env(struct unit_test_state *uts)
130 struct bootstd_priv *std;
132 ut_assertok(bootstd_get_priv(&std));
134 /* Select just one bootmethod */
135 console_record_reset_enable();
136 ut_assertok(env_set("bootmeths", "syslinux"));
137 ut_asserteq(1, std->bootmeth_count);
139 /* Select an invalid bootmethod */
140 ut_asserteq(1, run_command("setenv bootmeths fred", 0));
141 ut_assert_nextline("Unknown bootmeth 'fred'");
142 ut_assert_nextlinen("## Error inserting");
143 ut_assert_console_end();
145 ut_assertok(env_set("bootmeths", "efi syslinux"));
146 ut_asserteq(2, std->bootmeth_count);
147 ut_assert_console_end();
151 BOOTSTD_TEST(bootmeth_env, UT_TESTF_DM | UT_TESTF_SCAN_FDT);
153 /* Check the get_state_desc() method */
154 static int bootmeth_state(struct unit_test_state *uts)
159 ut_assertok(uclass_first_device(UCLASS_BOOTMETH, &dev));
160 ut_assertnonnull(dev);
162 ut_assertok(bootmeth_get_state_desc(dev, buf, sizeof(buf)));
163 ut_asserteq_str("OK", buf);
167 BOOTSTD_TEST(bootmeth_state, UT_TESTF_DM | UT_TESTF_SCAN_FDT);