From 03a5c955fdada22bbfae50dadfa0004fa80821f5 Mon Sep 17 00:00:00 2001 From: Jeremy Kerr Date: Wed, 8 May 2013 11:26:46 +0800 Subject: [PATCH 1/1] test/parser: Add simple GRUB2 parser test Signed-off-by: Jeremy Kerr --- test/parser/Makefile.am | 2 ++ test/parser/test-grub2-single.c | 29 +++++++++++++++++++++++++++++ 2 files changed, 31 insertions(+) create mode 100644 test/parser/test-grub2-single.c diff --git a/test/parser/Makefile.am b/test/parser/Makefile.am index 3733039..cd8da4a 100644 --- a/test/parser/Makefile.am +++ b/test/parser/Makefile.am @@ -25,6 +25,7 @@ AM_CPPFLAGS = \ AM_CFLAGS = -O0 -ggdb -Wall -Wextra -Werror TESTS = test-null \ + test-grub2-single \ test-kboot-single \ test-yaboot-single \ test-yaboot-external @@ -42,6 +43,7 @@ libtest.o: $(libtest_o_OBJECTS) # objects under test parser_test_objs = $(top_srcdir)/discover/yaboot-parser.c \ $(top_srcdir)/discover/kboot-parser.c \ + $(top_srcdir)/discover/grub2-parser.c \ $(top_srcdir)/discover/resource.c \ $(top_srcdir)/discover/paths.c \ $(top_srcdir)/discover/device-handler.c \ diff --git a/test/parser/test-grub2-single.c b/test/parser/test-grub2-single.c new file mode 100644 index 0000000..7db8eb9 --- /dev/null +++ b/test/parser/test-grub2-single.c @@ -0,0 +1,29 @@ + +#include "parser-test.h" + +#if 0 /* PARSER_EMBEDDED_CONFIG */ +menuentry 'Linux' --class test-class $menuentry_id_option 'test-id' { + linux /vmlinux arg1=value1 arg2 + initrd /initrd +} +#endif + +void run_test(struct parser_test *test) +{ + struct discover_boot_option *opt; + struct discover_context *ctx; + + test_read_conf_embedded(test); + test_run_parser(test, "grub2"); + + ctx = test->ctx; + + check_boot_option_count(ctx, 1); + opt = get_boot_option(ctx, 0); + + check_name(opt, "Linux"); + check_resolved_local_resource(opt->boot_image, ctx->device, "/vmlinux"); + check_resolved_local_resource(opt->initrd, ctx->device, "/initrd"); + + check_args(opt, "arg1=value1 arg2"); +} -- 2.39.2