diff options
author | Jeremy Kerr <jk@ozlabs.org> | 2013-05-15 16:58:38 +0800 |
---|---|---|
committer | Jeremy Kerr <jk@ozlabs.org> | 2013-05-16 11:55:16 +0800 |
commit | 00f86a253a2058ad292f81ba09684fde9ac00539 (patch) | |
tree | c418c643af86328f1986e1297e12b0ac3af526fa | |
parent | daa56dcba2d7510666aae8d427e491acc74e8975 (diff) | |
download | talos-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>
-rw-r--r-- | test/parser/Makefile.am | 3 | ||||
-rw-r--r-- | test/parser/test-yaboot-external.c | 36 |
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"); +} |