diff options
author | teor (Tim Wilson-Brown) <teor2345@gmail.com> | 2016-01-29 08:15:14 +1100 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2016-02-01 09:50:42 -0500 |
commit | dbb5819e96e6f31a9ed5c46cda7d7ba1265a362c (patch) | |
tree | 5d494a600efb96f82719305ac4e5d1b51b8c5b8d /src | |
parent | fe92e9bb9647123381a8428ed438283fb1a749f4 (diff) | |
download | tor-dbb5819e96e6f31a9ed5c46cda7d7ba1265a362c.tar.gz tor-dbb5819e96e6f31a9ed5c46cda7d7ba1265a362c.zip |
Report malformed options in options_validate unit tests
Diffstat (limited to 'src')
-rw-r--r-- | src/test/test_options.c | 33 |
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; } |