summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorJeremy Kerr <jk@ozlabs.org>2013-05-15 16:58:38 +0800
committerJeremy Kerr <jk@ozlabs.org>2013-05-16 11:55:16 +0800
commit00f86a253a2058ad292f81ba09684fde9ac00539 (patch)
treec418c643af86328f1986e1297e12b0ac3af526fa /test
parentdaa56dcba2d7510666aae8d427e491acc74e8975 (diff)
downloadtalos-petitboot-00f86a253a2058ad292f81ba09684fde9ac00539.tar.gz
talos-petitboot-00f86a253a2058ad292f81ba09684fde9ac00539.zip
test/parser: Add yaboot test for external devices
Add a yaboot test to add boot options for an external device, then hotplug that device. Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
Diffstat (limited to 'test')
-rw-r--r--test/parser/Makefile.am3
-rw-r--r--test/parser/test-yaboot-external.c36
2 files changed, 38 insertions, 1 deletions
diff --git a/test/parser/Makefile.am b/test/parser/Makefile.am
index eff3ece..d8135d4 100644
--- a/test/parser/Makefile.am
+++ b/test/parser/Makefile.am
@@ -25,7 +25,8 @@ AM_CPPFLAGS = \
AM_CFLAGS = -O0 -ggdb -Wall -Wextra -Werror
TESTS = test-null \
- test-yaboot-single
+ test-yaboot-single \
+ test-yaboot-external
check_PROGRAMS = $(TESTS)
check_LIBRARIES = $(test_libs)
diff --git a/test/parser/test-yaboot-external.c b/test/parser/test-yaboot-external.c
new file mode 100644
index 0000000..6d48b27
--- /dev/null
+++ b/test/parser/test-yaboot-external.c
@@ -0,0 +1,36 @@
+
+#include "parser-test.h"
+
+#if 0 /* PARSER_EMBEDDED_CONFIG */
+default=
+
+image=external:/vmlinux
+ label=linux
+ initrd=external:/initrd
+#endif
+
+void run_test(struct parser_test *test)
+{
+ struct discover_boot_option *opt;
+ struct discover_context *ctx;
+ struct discover_device *dev;
+
+ 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_unresolved_resource(opt->boot_image);
+ check_unresolved_resource(opt->initrd);
+
+ dev = test_create_device(ctx, "external");
+ test_hotplug_device(test, dev);
+
+ check_resolved_local_resource(opt->boot_image, dev, "/vmlinux");
+ check_resolved_local_resource(opt->initrd, dev, "/initrd");
+}
OpenPOWER on IntegriCloud