test/parser: Allow tests to provide pre-loaded config data
authorJeremy Kerr <jk@ozlabs.org>
Wed, 15 May 2013 08:01:14 +0000 (16:01 +0800)
committerJeremy Kerr <jk@ozlabs.org>
Thu, 16 May 2013 03:53:34 +0000 (11:53 +0800)
Some tests may want to use an existing buffer as config data, so add
test_read_config_data() to allow this.

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

index e17cbbc9e186b1ccf6d459ed6037113e605fcffe..5baa4588588fdd9e4f9c65f75105d21fbfbf45ea 100644 (file)
@@ -22,6 +22,11 @@ void __register_parser(struct parser *parser);
 struct discover_device *test_create_device(struct discover_context *ctx,
                const char *name);
 
+#define test_read_conf_data(t, d) \
+       __test_read_conf_data(t, d, sizeof(d))
+
+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);
 
 int test_run_parser(struct parser_test *test, const char *parser_name);
index 16c415a1ebd7477f27baa2fcfbd96cf5362fab0a..a1d0ad24b590d9938dcdd12ed00b3548137d1e97 100644 (file)
@@ -85,6 +85,13 @@ void test_fini(struct parser_test *test)
        talloc_free(test);
 }
 
+void __test_read_conf_data(struct parser_test *test,
+               const char *buf, size_t len)
+{
+       test->conf.size = len;
+       test->conf.buf = talloc_memdup(test, buf, len);
+}
+
 void test_read_conf_file(struct parser_test *test, const char *filename)
 {
        struct stat stat;