test/parser: Add resource check helpers
authorJeremy Kerr <jk@ozlabs.org>
Wed, 15 May 2013 08:36:34 +0000 (16:36 +0800)
committerJeremy Kerr <jk@ozlabs.org>
Thu, 16 May 2013 03:53:34 +0000 (11:53 +0800)
Add check_resolved_local_resource and check_unresolved_resource to
check the resources returned from parsers.

Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
test/parser/parser-test.h
test/parser/utils.c

index 0baad949e8edae2f5086256908182962485fdc48..3a4382ad2226e65de8fcd7df6e2f1afe2516138f 100644 (file)
@@ -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 */
index 8ac2060e033a1ca1f03518e99aa8e5d5601b1d04..fb558cf2c3ec457be3d0ef63a8f399bb06b3f343 100644 (file)
@@ -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);
+}