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/parser/utils.c | |
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/parser/utils.c')
-rw-r--r-- | test/parser/utils.c | 34 |
1 files changed, 34 insertions, 0 deletions
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); +} |