aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2017-04-07 09:47:29 -0400
committerNick Mathewson <nickm@torproject.org>2017-04-07 09:47:29 -0400
commit30b13fd82e243713c6a0d7bfbfc97d5faf8ee9c8 (patch)
tree894a064fffdc199b88af8f7c9dddd605b5385302
parent489ef6b38ba66f59bb6562a4702c0500478a7495 (diff)
downloadtor-30b13fd82e243713c6a0d7bfbfc97d5faf8ee9c8.tar.gz
tor-30b13fd82e243713c6a0d7bfbfc97d5faf8ee9c8.zip
Add test for expected output from encode{,d}_length functions
-rw-r--r--src/test/test_util_format.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/test/test_util_format.c b/src/test/test_util_format.c
index a689b2de6c..96ebada202 100644
--- a/src/test/test_util_format.c
+++ b/src/test/test_util_format.c
@@ -370,6 +370,34 @@ test_util_format_base32_decode(void *arg)
tor_free(dst);
}
+static void
+test_util_format_encoded_size(void *arg)
+{
+ (void)arg;
+ uint8_t inbuf[256];
+ char outbuf[1024];
+ unsigned i;
+
+ crypto_rand((char *)inbuf, sizeof(inbuf));
+ for (i = 0; i <= sizeof(inbuf); ++i) {
+ /* XXXX (Once the return values are consistent, check them too.) */
+
+ base32_encode(outbuf, sizeof(outbuf), (char *)inbuf, i);
+ /* The "+ 1" below is an API inconsistency. */
+ tt_int_op(strlen(outbuf) + 1, OP_EQ, base32_encoded_size(i));
+
+ base64_encode(outbuf, sizeof(outbuf), (char *)inbuf, i, 0);
+ tt_int_op(strlen(outbuf), OP_EQ, base64_encode_size(i, 0));
+ base64_encode(outbuf, sizeof(outbuf), (char *)inbuf, i,
+ BASE64_ENCODE_MULTILINE);
+ tt_int_op(strlen(outbuf), OP_EQ,
+ base64_encode_size(i, BASE64_ENCODE_MULTILINE));
+ }
+
+ done:
+ ;
+}
+
struct testcase_t util_format_tests[] = {
{ "unaligned_accessors", test_util_format_unaligned_accessors, 0,
NULL, NULL },
@@ -382,6 +410,7 @@ struct testcase_t util_format_tests[] = {
NULL, NULL },
{ "base32_decode", test_util_format_base32_decode, 0,
NULL, NULL },
+ { "encoded_size", test_util_format_encoded_size, 0, NULL, NULL },
END_OF_TESTCASES
};