summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Goulet <dgoulet@torproject.org>2016-07-04 11:40:06 -0400
committerDavid Goulet <dgoulet@torproject.org>2016-07-04 11:40:06 -0400
commit7d04638a608a150b80442198df401b8be5ea8a3a (patch)
tree874e760c818a649812653d3d3b8b1afa4bbf537e
parentc6de05d529dddebbdd7f9bcd36ca69d9a5e17d66 (diff)
downloadtor-7d04638a608a150b80442198df401b8be5ea8a3a.tar.gz
tor-7d04638a608a150b80442198df401b8be5ea8a3a.zip
test: Fix shared random buffer overrun
Encoded commit has an extra byte at the end for the NUL terminated byte and the test was overrunning the payload buffer by one byte. Found by Coverity issue 1362984. Fixes #19567 Signed-off-by: David Goulet <dgoulet@torproject.org>
-rw-r--r--src/test/test_shared_random.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/test/test_shared_random.c b/src/test/test_shared_random.c
index d001785340..2bdce7d2d5 100644
--- a/src/test/test_shared_random.c
+++ b/src/test/test_shared_random.c
@@ -932,13 +932,14 @@ test_utils(void *arg)
/* Testing commitments_are_the_same(). Currently, the check is to test the
* value of the encoded commit so let's make sure that actually works. */
{
- /* Payload of 55 bytes that is the length of
- * sr_commit_t->encoded_commit. */
+ /* Payload of 57 bytes that is the length of sr_commit_t->encoded_commit.
+ * 56 bytes of payload and a NUL terminated byte at the end ('\x00')
+ * which comes down to SR_COMMIT_BASE64_LEN + 1. */
const char *payload =
"\x5d\xb9\x60\xb6\xcc\x51\x68\x52\x31\xd9\x88\x88\x71\x71\xe0\x30"
"\x59\x55\x7f\xcd\x61\xc0\x4b\x05\xb8\xcd\xc1\x48\xe9\xcd\x16\x1f"
"\x70\x15\x0c\xfc\xd3\x1a\x75\xd0\x93\x6c\xc4\xe0\x5c\xbe\xe2\x18"
- "\xc7\xaf\x72\xb6\x7c\x9b\x52";
+ "\xc7\xaf\x72\xb6\x7c\x9b\x52\x00";
sr_commit_t commit1, commit2;
memcpy(commit1.encoded_commit, payload, sizeof(commit1.encoded_commit));
memcpy(commit2.encoded_commit, payload, sizeof(commit2.encoded_commit));