summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorJeremy Kerr <jk@ozlabs.org>2013-11-27 18:56:16 +0800
committerJeremy Kerr <jk@ozlabs.org>2013-11-27 18:56:16 +0800
commit13e41764a7450302b874668bc1a3fbf6be25b781 (patch)
tree430c5061b4a64ef3bc7c7c5b425d331f3fff462e /test
parentd67d5beceef94686818ce264b2ca93f82b66e8f4 (diff)
downloadpetitboot-13e41764a7450302b874668bc1a3fbf6be25b781.zip
petitboot-13e41764a7450302b874668bc1a3fbf6be25b781.tar.gz
discover/grub2: Add support for -s and -f commands
Implement -s and -f checks for grub, and test with the standard GRUB2 saved_default config. Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
Diffstat (limited to 'test')
-rw-r--r--test/parser/Makefile.am1
-rw-r--r--test/parser/test-grub2-saved-default.c47
2 files changed, 48 insertions, 0 deletions
diff --git a/test/parser/Makefile.am b/test/parser/Makefile.am
index dbf626a..e355af3 100644
--- a/test/parser/Makefile.am
+++ b/test/parser/Makefile.am
@@ -35,6 +35,7 @@ TESTS = \
test-grub2-single-line-if \
test-grub2-load-env \
test-grub2-save-env \
+ test-grub2-saved-default \
test-grub2-f18-ppc64 \
test-grub2-ubuntu-13_04-x86 \
test-grub2-lexer-error \
diff --git a/test/parser/test-grub2-saved-default.c b/test/parser/test-grub2-saved-default.c
new file mode 100644
index 0000000..c1f6478
--- /dev/null
+++ b/test/parser/test-grub2-saved-default.c
@@ -0,0 +1,47 @@
+
+#include "parser-test.h"
+
+#if 0 /* PARSER_EMBEDDED_CONFIG */
+if [ -s $prefix/grubenv ]; then
+ load_env
+fi
+if [ "${next_entry}" ] ; then
+ set default="${next_entry}"
+ set next_entry=
+ save_env next_entry
+ set boot_once=true
+else
+ set default="${saved_entry}"
+fi
+menuentry 'test saved option' {
+ linux vmlinux
+}
+#endif
+
+
+
+void run_test(struct parser_test *test)
+{
+ struct discover_boot_option *opt;
+ struct discover_context *ctx;
+
+ test_add_file_string(test, test->ctx->device,
+ "/boot/grub/grubenv",
+ "# GRUB Environment Block\n"
+ "saved_entry=test saved option\n"
+ "#############################");
+
+ test_read_conf_embedded(test, "/boot/grub/grub.cfg");
+
+ test_run_parser(test, "grub2");
+
+ ctx = test->ctx;
+
+ check_boot_option_count(ctx, 1);
+ opt = get_boot_option(ctx, 0);
+
+ check_name(opt, "test saved option");
+ check_resolved_local_resource(opt->boot_image, ctx->device,
+ "/vmlinux");
+ check_is_default(opt);
+}
OpenPOWER on IntegriCloud