+ assert(0);
+
+ return NULL;
+}
+
+void __check_boot_option_count(struct discover_context *ctx, int count,
+ const char *file, int line)
+{
+ struct discover_boot_option *opt;
+ int defaults = 0, i = 0;
+
+ list_for_each_entry(&ctx->boot_options, opt, list) {
+ i++;
+ if (opt->option->is_default)
+ defaults++;
+ }
+
+ if (defaults > 1) {
+ fprintf(stderr, "%s:%d: parser returned multiple default "
+ "options\n", file, line);
+ exit(EXIT_FAILURE);
+ }
+
+ if (i == count)
+ return;
+
+ fprintf(stderr, "%s:%d: boot option count check failed\n", file, line);
+ fprintf(stderr, "expected %d options, got %d:\n", count, i);
+
+ i = 1;
+ list_for_each_entry(&ctx->boot_options, opt, list)
+ fprintf(stderr, " %2d: %s [%s]\n", i++, opt->option->name,
+ opt->option->id);
+
+ exit(EXIT_FAILURE);
+}
+
+void __check_args(struct discover_boot_option *opt, const char *args,
+ const char *file, int line)
+{
+ int rc;
+
+ if (!opt->option->boot_args && !args)
+ return;
+
+ if (!opt->option->boot_args) {
+ fprintf(stderr, "%s:%d: arg check failed\n", file, line);
+ fprintf(stderr, " no arguments parsed\n");
+ fprintf(stderr, " expected '%s'\n", args);
+ exit(EXIT_FAILURE);
+ }
+
+ rc = strcmp(opt->option->boot_args, args);
+ if (rc) {
+ fprintf(stderr, "%s:%d: arg check failed\n", file, line);
+ fprintf(stderr, " got '%s'\n", opt->option->boot_args);
+ fprintf(stderr, " expected '%s'\n", args);
+ exit(EXIT_FAILURE);
+ }
+}
+
+void __check_name(struct discover_boot_option *opt, const char *name,
+ const char *file, int line)
+{
+ int rc;
+
+ rc = strcmp(opt->option->name, name);
+ if (rc) {
+ fprintf(stderr, "%s:%d: name check failed\n", file, line);
+ fprintf(stderr, " got '%s'\n", opt->option->name);
+ fprintf(stderr, " expected '%s'\n", name);
+ exit(EXIT_FAILURE);
+ }
+}
+
+void __check_is_default(struct discover_boot_option *opt,
+ const char *file, int line)
+{
+ if (opt->option->is_default)
+ return;
+
+ fprintf(stderr, "%s:%d: default check failed\n", file, line);
+ 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)) {
+ fprintf(stderr, "%s:%d: Resource mismatch\n", file, line);
+ fprintf(stderr, " got '%s'\n", got_url);
+ fprintf(stderr, " expected '%s'\n", exp_url);
+ exit(EXIT_FAILURE);
+ }
+}
+
+void __check_resolved_url_resource(struct resource *res,
+ const char *url, const char *file, int line)
+{
+ char *res_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);
+
+ res_url = pb_url_to_string(res->url);
+ if (strcmp(url, res_url)) {
+ fprintf(stderr, "%s:%d: Resource mismatch\n", file, line);
+ fprintf(stderr, " got '%s'\n", res_url);
+ fprintf(stderr, " expected '%s'\n", url);
+ exit(EXIT_FAILURE);
+ }
+}
+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);
+}
+
+void __check_not_present_resource(struct resource *res,
+ const char *file, int line)
+{
+ if (res)
+ errx(EXIT_FAILURE, "%s:%d: Resource present", file, line);
+}
+
+static void dump_file_data(const void *buf, int len)
+{
+ int i, j, hex_len = strlen("00 ");
+ const int row_len = 16;
+
+ for (i = 0; i < len; i += row_len) {
+ char hbuf[row_len * hex_len + 1];
+ char cbuf[row_len + strlen("|") + 1];
+
+ for (j = 0; (j < row_len) && ((i+j) < len); j++) {
+ char c = ((const char *)buf)[i + j];
+
+ snprintf(hbuf + j * hex_len, hex_len + 1, "%02x ", c);
+
+ if (!isprint(c))
+ c = '.';
+
+ snprintf(cbuf + j, hex_len + 1, "%c", c);
+ }
+
+ strcat(cbuf, "|");
+
+ fprintf(stderr, "%08x %*s |%s\n", i,
+ 0 - (int)sizeof(hbuf) + 1, hbuf, cbuf);
+ }
+}
+
+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)
+{
+ struct test_file *f, *file = NULL;
+
+ list_for_each_entry(&test->files, f, list) {
+ if (f->dev != dev)
+ continue;
+ if (strcmp(f->name, filename))
+ continue;
+
+ file = f;
+ break;
+ }
+
+ if (!file)
+ errx(EXIT_FAILURE, "%s:%d: File '%s' not found",
+ srcfile, srcline, filename);
+
+ if (file->size != len || memcmp(file->data, buf, len)) {
+ fprintf(stderr, "%s:%d: File '%s' data/size mismatch\n",
+ srcfile, srcline, filename);
+ fprintf(stderr, "Expected:\n");
+ dump_file_data(buf, len);
+ fprintf(stderr, "Got:\n");
+ dump_file_data(file->data, file->size);
+ exit(EXIT_FAILURE);
+ }