summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremy Kerr <jk@ozlabs.org>2013-05-15 16:52:34 +0800
committerJeremy Kerr <jk@ozlabs.org>2013-05-16 11:55:15 +0800
commitdaa56dcba2d7510666aae8d427e491acc74e8975 (patch)
tree0b42e07be79eaea4651144bdb9a0be6d08d23e58
parent22b9ca8f4b9d28b4405576b39a87d3d0c945dd07 (diff)
downloadtalos-petitboot-daa56dcba2d7510666aae8d427e491acc74e8975.tar.gz
talos-petitboot-daa56dcba2d7510666aae8d427e491acc74e8975.zip
test/parser: Add simple yaboot test
Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
-rw-r--r--test/parser/Makefile.am6
-rw-r--r--test/parser/test-yaboot-single.c29
2 files changed, 33 insertions, 2 deletions
diff --git a/test/parser/Makefile.am b/test/parser/Makefile.am
index 2e97fbe..eff3ece 100644
--- a/test/parser/Makefile.am
+++ b/test/parser/Makefile.am
@@ -24,7 +24,8 @@ AM_CPPFLAGS = \
AM_CFLAGS = -O0 -ggdb -Wall -Wextra -Werror
-TESTS = test-null
+TESTS = test-null \
+ test-yaboot-single
check_PROGRAMS = $(TESTS)
check_LIBRARIES = $(test_libs)
@@ -37,7 +38,8 @@ libtest.o: $(libtest_o_OBJECTS)
$(LD) -o $@ -r $^
# objects under test
-parser_test_objs = $(top_srcdir)/discover/resource.c \
+parser_test_objs = $(top_srcdir)/discover/yaboot-parser.c \
+ $(top_srcdir)/discover/resource.c \
$(top_srcdir)/discover/paths.c \
$(top_srcdir)/discover/device-handler.c \
$(top_srcdir)/discover/parser-conf.c
diff --git a/test/parser/test-yaboot-single.c b/test/parser/test-yaboot-single.c
new file mode 100644
index 0000000..17866e8
--- /dev/null
+++ b/test/parser/test-yaboot-single.c
@@ -0,0 +1,29 @@
+
+#include "parser-test.h"
+
+#if 0 /* PARSER_EMBEDDED_CONFIG */
+default=linux
+
+image=/vmlinux
+ label=linux
+ 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, "yaboot");
+
+ 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");
+}
OpenPOWER on IntegriCloud