summaryrefslogtreecommitdiff
path: root/src/test/test_options.c
diff options
context:
space:
mode:
authorteor (Tim Wilson-Brown) <teor2345@gmail.com>2016-01-29 08:15:14 +1100
committerNick Mathewson <nickm@torproject.org>2016-02-01 09:50:42 -0500
commitdbb5819e96e6f31a9ed5c46cda7d7ba1265a362c (patch)
tree5d494a600efb96f82719305ac4e5d1b51b8c5b8d /src/test/test_options.c
parentfe92e9bb9647123381a8428ed438283fb1a749f4 (diff)
downloadtor-dbb5819e96e6f31a9ed5c46cda7d7ba1265a362c.tar.gz
tor-dbb5819e96e6f31a9ed5c46cda7d7ba1265a362c.zip
Report malformed options in options_validate unit tests
Diffstat (limited to 'src/test/test_options.c')
-rw-r--r--src/test/test_options.c33
1 files changed, 29 insertions, 4 deletions
diff --git a/src/test/test_options.c b/src/test/test_options.c
index da8bc2128a..ea5f29e216 100644
--- a/src/test/test_options.c
+++ b/src/test/test_options.c
@@ -338,22 +338,47 @@ typedef struct {
or_options_t *def_opt;
} options_test_data_t;
+static void free_options_test_data(options_test_data_t *td);
+
static options_test_data_t *
get_options_test_data(const char *conf)
{
+ int rv = -1;
+ char *msg = NULL;
config_line_t *cl=NULL;
options_test_data_t *result = tor_malloc(sizeof(options_test_data_t));
result->opt = options_new();
result->old_opt = options_new();
result->def_opt = options_new();
- config_get_lines(conf, &cl, 1);
- config_assign(&options_format, result->opt, cl, 0, 0, NULL);
+ rv = config_get_lines(conf, &cl, 1);
+ tt_assert(rv == 0);
+ rv = config_assign(&options_format, result->opt, cl, 0, 0, &msg);
+ if (msg) {
+ /* Display the parse error message by comparing it with an empty string */
+ tt_str_op(msg, OP_EQ, "");
+ }
+ tt_assert(rv == 0);
config_free_lines(cl);
result->opt->LogTimeGranularity = 1;
result->opt->TokenBucketRefillInterval = 1;
- config_get_lines(TEST_OPTIONS_OLD_VALUES, &cl, 1);
- config_assign(&options_format, result->def_opt, cl, 0, 0, NULL);
+ rv = config_get_lines(TEST_OPTIONS_OLD_VALUES, &cl, 1);
+ tt_assert(rv == 0);
+ rv = config_assign(&options_format, result->def_opt, cl, 0, 0, &msg);
+ if (msg) {
+ /* Display the parse error message by comparing it with an empty string */
+ tt_str_op(msg, OP_EQ, "");
+ }
+ tt_assert(rv == 0);
+
+done:
config_free_lines(cl);
+ if (rv != 0) {
+ free_options_test_data(result);
+ result = NULL;
+ /* Callers expect a non-NULL result, so just die if we can't provide one.
+ */
+ tor_assert(0);
+ }
return result;
}