1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

testsc: fix disorganised alloc/free in test_hash().

These tests also failed when I reran testsc, and looking at the code,
no wonder: in each test iteration, the hash object is allocated
_before_ logging begins, rather than after, so that its addresses
aren't normalised by the test suite to 'n bytes after allocation #0'.
So these tests only pass as long as all the allocations get lucky in
reusing the same address. I guess we got lucky on all previous
occasions and didn't notice until now.

Easy fix: now each iteration does alloc / do stuff / free within the
logged section.
This commit is contained in:
Simon Tatham 2024-04-01 11:10:24 +01:00
parent c193fe9848
commit 4aa5d88fdb

View File

@ -1567,6 +1567,7 @@ static void test_hash(const ssh_hashalg *halg)
test_skipped = true; test_skipped = true;
return; return;
} }
ssh_hash_free(h);
size_t datalen = 256; size_t datalen = 256;
uint8_t *data = snewn(datalen, uint8_t); uint8_t *data = snewn(datalen, uint8_t);
@ -1576,16 +1577,14 @@ static void test_hash(const ssh_hashalg *halg)
random_read(data, datalen); random_read(data, datalen);
log_start(); log_start();
h = ssh_hash_new(halg);
put_data(h, data, datalen); put_data(h, data, datalen);
ssh_hash_final(h, hash); ssh_hash_final(h, hash);
log_end(); log_end();
h = ssh_hash_new(halg);
} }
sfree(data); sfree(data);
sfree(hash); sfree(hash);
ssh_hash_free(h);
} }
#define HASH_TESTFN(Y_unused, hash) \ #define HASH_TESTFN(Y_unused, hash) \