X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=test%2Fparser%2Fparser-test.h;h=df9670fed8c0188657a9e8577a5cbe07c4e4ffa9;hp=5baa4588588fdd9e4f9c65f75105d21fbfbf45ea;hb=d6166b471a9356355ed16747de3c0febd4b8cd3e;hpb=a5a787c5d170708be5d15ee9418520917653a104 diff --git a/test/parser/parser-test.h b/test/parser/parser-test.h index 5baa458..df9670f 100644 --- a/test/parser/parser-test.h +++ b/test/parser/parser-test.h @@ -28,7 +28,93 @@ struct discover_device *test_create_device(struct discover_context *ctx, void __test_read_conf_data(struct parser_test *test, const char *buf, size_t len); void test_read_conf_file(struct parser_test *test, const char *filename); +void test_set_conf_source(struct parser_test *test, const char *url); int test_run_parser(struct parser_test *test, const char *parser_name); +void test_hotplug_device(struct parser_test *test, struct discover_device *dev); + +struct discover_boot_option *get_boot_option(struct discover_context *ctx, + int idx); + +/* embedded config */ +extern const char __embedded_config[]; +extern const size_t __embedded_config_size; +#define test_read_conf_embedded(t) \ + __test_read_conf_data(t, __embedded_config, __embedded_config_size) + +/** + * Checks for parser results. + * + * These return void, but will respond to check failures by printing a reason + * for the failure, and exit the test with a non-zero exit status. + */ + +/** + * Check that we have an expected number of boot options parsed. If not, + * print out what we did find, then exit. + */ +#define check_boot_option_count(ctx, count) \ + __check_boot_option_count(ctx, count, __FILE__, __LINE__) +void __check_boot_option_count(struct discover_context *ctx, int count, + const char *file, int line); +/* + * Check that a boot option @opt has args @args + */ +void __check_args(struct discover_boot_option *opt, const char *args, + const char *file, int line); +#define check_args(opt, args) \ + __check_args(opt, args, __FILE__, __LINE__) + +/** + * Check that a boot option @opt has name @name + */ +void __check_name(struct discover_boot_option *opt, const char *name, + const char *file, int line); +#define check_name(opt, name) \ + __check_name(opt, name, __FILE__, __LINE__) + +/** + * Check that a boot option @opt is marked as default + */ +void __check_is_default(struct discover_boot_option *opt, + const char *file, int line); +#define check_is_default(opt) \ + __check_is_default(opt, __FILE__, __LINE__) + +/** + * Check that a resource (@res) is present, resolved, and has a local path + * (within @dev's mount point) of @path. + */ +#define check_resolved_local_resource(res, dev, path) \ + __check_resolved_local_resource(res, dev, path, __FILE__, __LINE__) + +void __check_resolved_local_resource(struct resource *res, + struct discover_device *dev, const char *local_path, + const char *file, int line); + +/** + * Check that a resource (@res) is present, resolved, and has a URL of + * @url. + */ +#define check_resolved_url_resource(res, url) \ + __check_resolved_url_resource(res, url, __FILE__, __LINE__) +void __check_resolved_url_resource(struct resource *res, + const char *url, const char *file, int line); +/** + * Check that a resource (@res) is present but not resolved + */ +void __check_unresolved_resource(struct resource *res, + const char *file, int line); +#define check_unresolved_resource(res) \ + __check_unresolved_resource(res, __FILE__, __LINE__) + +/** + * Check that a resource (@res) is not present + */ +void __check_not_present_resource(struct resource *res, + const char *file, int line); +#define check_not_present_resource(res) \ + __check_not_present_resource(res, __FILE__, __LINE__) + #endif /* PARSER_TEST_H */