Fix some issues raise by coverity in the tests.

Reviewed-by: Matt Caswell <matt@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/3846)
This commit is contained in:
Pauli 2017-07-06 09:10:28 +10:00
parent d72a00416a
commit 9e206ce5f8
5 changed files with 26 additions and 23 deletions

View file

@ -1367,9 +1367,9 @@ static int file_modexp(STANZA *s)
"0000000000000000000000000000000000000000000000000000000000000000" "0000000000000000000000000000000000000000000000000000000000000000"
"0000000000000000000000000000000000000000000000000000000000000000" "0000000000000000000000000000000000000000000000000000000000000000"
"0000000000000000000000000000000000000000000000000000000001"); "0000000000000000000000000000000000000000000000000000000001");
BN_mod_exp(d, a, b, c, ctx); if (!TEST_true(BN_mod_exp(d, a, b, c, ctx))
BN_mul(e, a, a, ctx); || !TEST_true(BN_mul(e, a, a, ctx))
if (!TEST_BN_eq(d, e)) || !TEST_BN_eq(d, e))
goto err; goto err;
st = 1; st = 1;

View file

@ -133,6 +133,8 @@ static STACK_OF(X509) *load_chain(BIO *fp, int nelem)
OPENSSL_free(name); OPENSSL_free(name);
OPENSSL_free(header); OPENSSL_free(header);
OPENSSL_free(data); OPENSSL_free(data);
name = header = NULL;
data = NULL;
} }
if (count == nelem) { if (count == nelem) {

View file

@ -1023,8 +1023,11 @@ static int pkey_test_init(EVP_TEST *t, const char *name,
return 0; return 0;
} }
kdata->keyop = keyop; kdata->keyop = keyop;
if (!TEST_ptr(kdata->ctx = EVP_PKEY_CTX_new(pkey, NULL))) if (!TEST_ptr(kdata->ctx = EVP_PKEY_CTX_new(pkey, NULL))) {
EVP_PKEY_free(pkey);
OPENSSL_free(kdata);
return 0; return 0;
}
if (keyopinit(kdata->ctx) <= 0) if (keyopinit(kdata->ctx) <= 0)
t->err = "KEYOP_INIT_ERROR"; t->err = "KEYOP_INIT_ERROR";
t->data = kdata; t->data = kdata;
@ -1624,10 +1627,15 @@ static int kdf_test_init(EVP_TEST *t, const char *name)
if (!TEST_ptr(kdata = OPENSSL_zalloc(sizeof(*kdata)))) if (!TEST_ptr(kdata = OPENSSL_zalloc(sizeof(*kdata))))
return 0; return 0;
kdata->ctx = EVP_PKEY_CTX_new_id(OBJ_sn2nid(name), NULL); kdata->ctx = EVP_PKEY_CTX_new_id(OBJ_sn2nid(name), NULL);
if (kdata->ctx == NULL) if (kdata->ctx == NULL) {
OPENSSL_free(kdata);
return 0; return 0;
if (EVP_PKEY_derive_init(kdata->ctx) <= 0) }
if (EVP_PKEY_derive_init(kdata->ctx) <= 0) {
EVP_PKEY_CTX_free(kdata->ctx);
OPENSSL_free(kdata);
return 0; return 0;
}
t->data = kdata; t->data = kdata;
return 1; return 1;
} }

View file

@ -156,10 +156,9 @@ static int test_mod_exp(int round)
c = (c % BN_BITS) - BN_BITS2; c = (c % BN_BITS) - BN_BITS2;
BN_rand(m, NUM_BITS + c, BN_RAND_TOP_ONE, BN_RAND_BOTTOM_ODD); BN_rand(m, NUM_BITS + c, BN_RAND_TOP_ONE, BN_RAND_BOTTOM_ODD);
BN_mod(a, a, m, ctx); if (!TEST_true(BN_mod(a, a, m, ctx))
BN_mod(b, b, m, ctx); || !TEST_true(BN_mod(b, b, m, ctx))
|| !TEST_true(BN_mod_exp_mont(r_mont, a, b, m, ctx, NULL))
if (!TEST_true(BN_mod_exp_mont(r_mont, a, b, m, ctx, NULL))
|| !TEST_true(BN_mod_exp_recp(r_recp, a, b, m, ctx)) || !TEST_true(BN_mod_exp_recp(r_recp, a, b, m, ctx))
|| !TEST_true(BN_mod_exp_simple(r_simple, a, b, m, ctx)) || !TEST_true(BN_mod_exp_simple(r_simple, a, b, m, ctx))
|| !TEST_true(BN_mod_exp_mont_consttime(r_mont_const, a, b, m, ctx, NULL))) || !TEST_true(BN_mod_exp_mont_consttime(r_mont_const, a, b, m, ctx, NULL)))

View file

@ -17,12 +17,12 @@
static int test_pbelu(void) static int test_pbelu(void)
{ {
int i, failed = 0, ok; int i, failed = 0;
int pbe_type, pbe_nid, last_type = -1, last_nid = -1; int pbe_type, pbe_nid, last_type = -1, last_nid = -1;
for (i = 0; EVP_PBE_get(&pbe_type, &pbe_nid, i) != 0; i++) { for (i = 0; EVP_PBE_get(&pbe_type, &pbe_nid, i) != 0; i++) {
if (!TEST_true(EVP_PBE_find(pbe_type, pbe_nid, NULL, NULL, 0))) { if (!TEST_true(EVP_PBE_find(pbe_type, pbe_nid, NULL, NULL, 0))) {
TEST_info("i=%d, pbe_type=%d, pbe_nid=%d", i, pbe_type, pbe_nid); TEST_note("i=%d, pbe_type=%d, pbe_nid=%d", i, pbe_type, pbe_nid);
failed = 1; failed = 1;
break; break;
} }
@ -33,20 +33,14 @@ static int test_pbelu(void)
/* Error: print out whole table */ /* Error: print out whole table */
for (i = 0; EVP_PBE_get(&pbe_type, &pbe_nid, i) != 0; i++) { for (i = 0; EVP_PBE_get(&pbe_type, &pbe_nid, i) != 0; i++) {
if (pbe_type > last_type) failed = pbe_type < last_type
ok = 0; || (pbe_type == last_type && pbe_nid < last_nid);
else if (pbe_type < last_type || pbe_nid < last_nid) TEST_note("PBE type=%d %d (%s): %s\n", pbe_type, pbe_nid,
ok = 1; OBJ_nid2sn(pbe_nid), failed ? "ERROR" : "OK");
else
ok = 0;
if (!ok)
failed = 1;
TEST_info("PBE type=%d %d (%s): %s\n", pbe_type, pbe_nid,
OBJ_nid2sn(pbe_nid), ok ? "ERROR" : "OK");
last_type = pbe_type; last_type = pbe_type;
last_nid = pbe_nid; last_nid = pbe_nid;
} }
return failed ? 0 : 1; return 0;
} }
void register_tests(void) void register_tests(void)