X-Git-Url: https://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=test%2Fparser%2Fparser-test.h;h=ab3424c7e676c371f9f5f6cf23831c605965399b;hp=3a4382ad2226e65de8fcd7df6e2f1afe2516138f;hb=b08de841267546726f452c89cc326a493ec6549c;hpb=31998343c5eb5533ef85b97f5bb2ffe200eb2ad0 diff --git a/test/parser/parser-test.h b/test/parser/parser-test.h index 3a4382a..ab3424c 100644 --- a/test/parser/parser-test.h +++ b/test/parser/parser-test.h @@ -9,6 +9,8 @@ struct parser_test { struct device_handler *handler; struct discover_context *ctx; + struct list files; + struct config *config; struct { void *buf; size_t size; @@ -19,7 +21,7 @@ struct parser_test { void __register_parser(struct parser *parser); /* test functions */ -struct discover_device *test_create_device(struct discover_context *ctx, +struct discover_device *test_create_device(struct parser_test *test, const char *name); #define test_read_conf_data(t, d) \ @@ -28,9 +30,18 @@ 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); + +void test_add_file_data(struct parser_test *test, struct discover_device *dev, + const char *filename, const void *data, int size); + +#define test_add_file_string(test, dev, filename, str) \ + test_add_file_data(test, dev, filename, str, sizeof(str) - 1) + struct discover_boot_option *get_boot_option(struct discover_context *ctx, int idx); @@ -71,6 +82,14 @@ void __check_name(struct discover_boot_option *opt, const char *name, #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. @@ -82,6 +101,14 @@ 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 */ @@ -90,4 +117,23 @@ void __check_unresolved_resource(struct resource *res, #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__) + +/** + * Check the contents of a file - file @filename must be present on @dev, + * and match the @len bytes of @buf. + */ +void __check_file_contents(struct parser_test *test, + struct discover_device *dev, const char *filename, + const char *buf, int len, + const char *srcfile, int srcline); +#define check_file_contents(test, dev, filename, buf, len) \ + __check_file_contents(test, dev, filename, buf, len, __FILE__, __LINE__) + #endif /* PARSER_TEST_H */