diff options
author | Jeremy Kerr <jk@ozlabs.org> | 2014-02-27 16:52:20 +0800 |
---|---|---|
committer | Jeremy Kerr <jk@ozlabs.org> | 2014-02-27 16:52:20 +0800 |
commit | 5a604632c54671d65ccb3398a928c0c38c5f13ad (patch) | |
tree | 2f87875f5a624e9521ee8a2adce244576902e047 /test/parser/test-pxe-discover-bootfile-absolute-conffile.c | |
parent | f94ca3311758854670d25ba4e7853d76c2113402 (diff) | |
download | petitboot-5a604632c54671d65ccb3398a928c0c38c5f13ad.zip petitboot-5a604632c54671d65ccb3398a928c0c38c5f13ad.tar.gz |
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.c | 42 |
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"); +} |