diff options
author | Jeremy Kerr <jk@ozlabs.org> | 2013-05-15 16:36:34 +0800 |
---|---|---|
committer | Jeremy Kerr <jk@ozlabs.org> | 2013-05-16 11:53:34 +0800 |
commit | 31998343c5eb5533ef85b97f5bb2ffe200eb2ad0 (patch) | |
tree | 39dbd6bea7af4df9008163e7be8703548d01e659 /test | |
parent | b391345ddd4d0fb3c3b6a627d834242ca14fed28 (diff) | |
download | talos-petitboot-31998343c5eb5533ef85b97f5bb2ffe200eb2ad0.tar.gz talos-petitboot-31998343c5eb5533ef85b97f5bb2ffe200eb2ad0.zip |
test/parser: Add resource check helpers
Add check_resolved_local_resource and check_unresolved_resource to
check the resources returned from parsers.
Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
Diffstat (limited to 'test')
-rw-r--r-- | test/parser/parser-test.h | 19 | ||||
-rw-r--r-- | test/parser/utils.c | 34 |
2 files changed, 53 insertions, 0 deletions
diff --git a/test/parser/parser-test.h b/test/parser/parser-test.h index 0baad94..3a4382a 100644 --- a/test/parser/parser-test.h +++ b/test/parser/parser-test.h @@ -71,4 +71,23 @@ 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 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 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__) + #endif /* PARSER_TEST_H */ diff --git a/test/parser/utils.c b/test/parser/utils.c index 8ac2060..fb558cf 100644 --- a/test/parser/utils.c +++ b/test/parser/utils.c @@ -214,3 +214,37 @@ void __check_name(struct discover_boot_option *opt, const char *name, exit(EXIT_FAILURE); } } + +void __check_resolved_local_resource(struct resource *res, + struct discover_device *dev, const char *local_path, + const char *file, int line) +{ + const char *exp_url, *got_url; + + if (!res) + errx(EXIT_FAILURE, "%s:%d: No resource", file, line); + + if (!res->resolved) + errx(EXIT_FAILURE, "%s:%d: Resource is not resolved", + file, line); + + exp_url = talloc_asprintf(res, "file://%s%s", + dev->mount_path, local_path); + got_url = pb_url_to_string(res->url); + + if (strcmp(got_url, exp_url)) { + errx(EXIT_FAILURE, + "%s:%d Resource mismatch: got %s, expected %s", + file, line, got_url, exp_url); + } +} + +void __check_unresolved_resource(struct resource *res, + const char *file, int line) +{ + if (!res) + errx(EXIT_FAILURE, "%s:%d: No resource", file, line); + + if (res->resolved) + errx(EXIT_FAILURE, "%s:%d: Resource is resolved", file, line); +} |