summaryrefslogtreecommitdiffstats
path: root/test/parser/test-pxe-discover-bootfile-absolute-conffile.c
diff options
context:
space:
mode:
authorJeremy Kerr <jk@ozlabs.org>2014-02-27 16:52:20 +0800
committerJeremy Kerr <jk@ozlabs.org>2014-02-27 16:52:20 +0800
commit5a604632c54671d65ccb3398a928c0c38c5f13ad (patch)
tree2f87875f5a624e9521ee8a2adce244576902e047 /test/parser/test-pxe-discover-bootfile-absolute-conffile.c
parentf94ca3311758854670d25ba4e7853d76c2113402 (diff)
downloadtalos-petitboot-5a604632c54671d65ccb3398a928c0c38c5f13ad.tar.gz
talos-petitboot-5a604632c54671d65ccb3398a928c0c38c5f13ad.zip
test/parser: Add pxe discovery tests
Add tests to cover pxlinux-style configuration autodiscovery. Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
Diffstat (limited to 'test/parser/test-pxe-discover-bootfile-absolute-conffile.c')
-rw-r--r--test/parser/test-pxe-discover-bootfile-absolute-conffile.c42
1 files changed, 42 insertions, 0 deletions
diff --git a/test/parser/test-pxe-discover-bootfile-absolute-conffile.c b/test/parser/test-pxe-discover-bootfile-absolute-conffile.c
new file mode 100644
index 0000000..8326690
--- /dev/null
+++ b/test/parser/test-pxe-discover-bootfile-absolute-conffile.c
@@ -0,0 +1,42 @@
+
+#include "parser-test.h"
+
+#if 0 /* PARSER_EMBEDDED_CONFIG */
+label linux
+kernel vmlinux
+initrd initrd
+#endif
+
+/**
+ * Test that a pxeconffile option (DHCP opt 209) takes precedence over
+ * configuration discovery, and is resolved as an absolute path, overriding
+ * any prefix in bootfile.
+ */
+
+void run_test(struct parser_test *test)
+{
+ struct discover_boot_option *opt;
+ struct discover_context *ctx;
+
+ /* fixme: we should have a normalised URL here */
+ test_read_conf_embedded_url(test, "tftp://host//dir1/conf");
+
+ test_set_event_source(test);
+ test_set_event_param(test->ctx->event, "bootfile", "dir2/binary");
+ test_set_event_param(test->ctx->event, "pxeconffile", "/dir1/conf");
+ test_set_event_param(test->ctx->event, "tftp", "host");
+
+ test_run_parser(test, "pxe");
+
+ ctx = test->ctx;
+
+ check_boot_option_count(ctx, 1);
+ opt = get_boot_option(ctx, 0);
+
+ check_name(opt, "linux");
+
+ check_resolved_url_resource(opt->boot_image,
+ "tftp://host/dir1/vmlinux");
+ check_resolved_url_resource(opt->initrd,
+ "tftp://host/dir1/initrd");
+}
OpenPOWER on IntegriCloud