static int equalBN(const char *op, const BIGNUM *expected, const BIGNUM *actual)
{
- char *exstr = NULL;
- char *actstr = NULL;
-
if (BN_cmp(expected, actual) == 0)
return 1;
- if (BN_is_zero(expected) && BN_is_negative(expected))
- exstr = OPENSSL_strdup("-0");
- else
- exstr = BN_bn2hex(expected);
- if (BN_is_zero(actual) && BN_is_negative(actual))
- actstr = OPENSSL_strdup("-0");
- else
- actstr = BN_bn2hex(actual);
- if (!TEST_ptr(exstr) || !TEST_ptr(actstr))
- goto err;
-
- TEST_error("Got %s =\n\t%s\nwanted:\n\t%s", op, actstr, exstr);
-
-err:
- OPENSSL_free(exstr);
- OPENSSL_free(actstr);
+ TEST_error("unexpected %s value", op);
+ TEST_BN_eq(expected, actual);
return 0;
}
BN_sub(c, a, b);
BN_add(c, c, b);
BN_sub(c, c, a);
- if (!TEST_true(BN_is_zero(c)))
+ if (!TEST_BN_eq_zero(c))
goto err;
}
st = 1;
BN_mul(e, d, b, ctx);
BN_add(d, e, c);
BN_sub(d, d, a);
- if (!TEST_true(BN_is_zero(d)))
+ if (!TEST_BN_eq_zero(d))
goto err;
}
st = 1;
BN_mod(c, a, b, ctx);
BN_div(d, e, a, b, ctx);
BN_sub(e, e, c);
- if (!TEST_true(BN_is_zero(e)))
+ if (!TEST_BN_eq_zero(e))
goto err;
}
st = 1;
BN_zero(p);
if (!TEST_true(BN_mod_exp_mont_consttime(d, a, p, m, ctx, NULL)))
goto err;
- if (!TEST_true(BN_is_one(d)))
+ if (!TEST_BN_eq_one(d))
goto err;
/* Regression test for carry bug in mulx4x_mont */
BN_MONT_CTX_set(mont, n, ctx);
BN_mod_mul_montgomery(c, a, b, mont, ctx);
BN_mod_mul_montgomery(d, b, a, mont, ctx);
- if (!TEST_int_eq(BN_cmp(c, d), 0))
+ if (!TEST_BN_eq(c, d))
goto err;
/* Regression test for carry bug in sqr[x]8x_mont */
BN_MONT_CTX_set(mont, n, ctx);
BN_mod_mul_montgomery(c, a, a, mont, ctx);
BN_mod_mul_montgomery(d, a, b, mont, ctx);
- if (!TEST_int_eq(BN_cmp(c, d), 0))
+ if (!TEST_BN_eq(c, d))
goto err;
/* Zero input */
BN_bntest_rand(p, 1024, 0, 0);
BN_zero(a);
if (!TEST_true(BN_mod_exp_mont_consttime(d, a, p, m, ctx, NULL))
- || !TEST_true(BN_is_zero(d)))
+ || !TEST_BN_eq_zero(d))
goto err;
/*
if (!TEST_true(BN_from_montgomery(e, a, mont, ctx))
|| !TEST_true(BN_mod_exp_mont_consttime(d, e, p, m, ctx, NULL))
|| !TEST_true(BN_mod_exp_simple(a, e, p, m, ctx))
- || !TEST_int_eq(BN_cmp(a, d), 0))
+ || !TEST_BN_eq(a, d))
goto err;
/* Finally, some regular test vectors. */
BN_bntest_rand(e, 1024, 0, 0);
if (!TEST_true(BN_mod_exp_mont_consttime(d, e, p, m, ctx, NULL))
|| !TEST_true(BN_mod_exp_simple(a, e, p, m, ctx))
- || !TEST_int_eq(BN_cmp(a, d), 0))
+ || !TEST_BN_eq(a, d))
goto err;
st = 1;
goto err;
BN_GF2m_add(c, c, c);
/* Test that c + c = 0. */
- if (!TEST_true(BN_is_zero(c)))
+ if (!TEST_BN_eq_zero(c))
goto err;
}
st = 1;
BN_GF2m_add(d, a, c);
BN_GF2m_mod(e, d, b[j]);
/* Test that a + (a mod p) mod p == 0. */
- if (!TEST_true(BN_is_zero(e)))
+ if (!TEST_BN_eq_zero(e))
goto err;
}
}
BN_GF2m_add(f, e, g);
BN_GF2m_add(f, f, h);
/* Test that (a+d)*c = a*c + d*c. */
- if (!TEST_true(BN_is_zero(f)))
+ if (!TEST_BN_eq_zero(f))
goto err;
}
}
BN_GF2m_mod_mul(d, a, d, b[j], ctx);
BN_GF2m_add(d, c, d);
/* Test that a*a = a^2. */
- if (!TEST_true(BN_is_zero(d)))
+ if (!TEST_BN_eq_zero(d))
goto err;
}
}
BN_GF2m_mod_inv(c, a, b[j], ctx);
BN_GF2m_mod_mul(d, a, c, b[j], ctx);
/* Test that ((1/a)*a) = 1. */
- if (!TEST_true(BN_is_one(d)))
+ if (!TEST_BN_eq_one(d))
goto err;
}
}
BN_GF2m_mod_mul(e, d, c, b[j], ctx);
BN_GF2m_mod_div(f, a, e, b[j], ctx);
/* Test that ((a/c)*c)/a = 1. */
- if (!TEST_true(BN_is_one(f)))
+ if (!TEST_BN_eq_one(f))
goto err;
}
}
BN_GF2m_mod_exp(f, a, f, b[j], ctx);
BN_GF2m_add(f, e, f);
/* Test that a^(c+d)=a^c*a^d. */
- if (!TEST_true(BN_is_zero(f)))
+ if (!TEST_BN_eq_zero(f))
goto err;
}
}
BN_GF2m_mod_sqr(e, d, b[j], ctx);
BN_GF2m_add(f, c, e);
/* Test that d^2 = a, where d = sqrt(a). */
- if (!TEST_true(BN_is_zero(f)))
+ if (!TEST_BN_eq_zero(f))
goto err;
}
}
/*
* Test that solution of quadratic c satisfies c^2 + c = a.
*/
- if (!TEST_true(BN_is_zero(e)))
+ if (!TEST_BN_eq_zero(e))
goto err;
}
}
goto err;
/* BN_sqrt should fail on non-squares and negative numbers. */
- if (!TEST_true(BN_is_zero(square))) {
- if (!TEST_ptr(tmp = BN_new()) || !TEST_true(BN_copy(tmp, square)))
+ if (!TEST_BN_eq_zero(square)) {
+ if (!TEST_ptr(tmp = BN_new())
+ || !TEST_true(BN_copy(tmp, square)))
goto err;
BN_set_negative(tmp, 1);
"0000000000000000000000000000000000000000000000000000000001");
BN_mod_exp(d, a, b, c, ctx);
BN_mul(e, a, a, ctx);
- if (!TEST_int_eq(BN_cmp(d, e), 0))
+ if (!TEST_BN_eq(d, e))
goto err;
st = 1;
int st = 0;
if (!TEST_int_eq(parsedecBN(&bn, "0"), 1)
- || !TEST_true(BN_is_zero(bn))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_word(bn, 0)
+ || !TEST_BN_eq_zero(bn)
+ || !TEST_BN_le_zero(bn)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
BN_free(bn);
+ bn = NULL;
if (!TEST_int_eq(parsedecBN(&bn, "256"), 3)
- || !TEST_true(BN_is_word(bn, 256))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_word(bn, 256)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_gt_zero(bn)
+ || !TEST_BN_ne_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
BN_free(bn);
+ bn = NULL;
if (!TEST_int_eq(parsedecBN(&bn, "-42"), 3)
- || !TEST_true(BN_abs_is_word(bn, 42))
- || !TEST_true(BN_is_negative(bn)))
+ || !TEST_BN_abs_eq_word(bn, 42)
+ || !TEST_BN_lt_zero(bn)
+ || !TEST_BN_le_zero(bn)
+ || !TEST_BN_ne_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
BN_free(bn);
+ bn = NULL;
+
+ if (!TEST_int_eq(parsedecBN(&bn, "1"), 1)
+ || !TEST_BN_eq_word(bn, 1)
+ || !TEST_BN_ne_zero(bn)
+ || !TEST_BN_gt_zero(bn)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_eq_one(bn)
+ || !TEST_BN_odd(bn))
+ goto err;
+ BN_free(bn);
+ bn = NULL;
if (!TEST_int_eq(parsedecBN(&bn, "-0"), 2)
- || !TEST_true(BN_is_zero(bn))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_zero(bn)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_le_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
BN_free(bn);
+ bn = NULL;
if (!TEST_int_eq(parsedecBN(&bn, "42trailing garbage is ignored"), 2)
- || !TEST_true(BN_abs_is_word(bn, 42))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_abs_eq_word(bn, 42)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_gt_zero(bn)
+ || !TEST_BN_ne_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
st = 1;
int st = 0;
if (!TEST_int_eq(parseBN(&bn, "0"), 1)
- || !TEST_true(BN_is_zero(bn))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_zero(bn)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
BN_free(bn);
+ bn = NULL;
if (!TEST_int_eq(parseBN(&bn, "256"), 3)
- || !TEST_true(BN_is_word(bn, 0x256))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_word(bn, 0x256)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_gt_zero(bn)
+ || !TEST_BN_ne_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
BN_free(bn);
+ bn = NULL;
if (!TEST_int_eq(parseBN(&bn, "-42"), 3)
- || !TEST_true(BN_abs_is_word(bn, 0x42))
- || !TEST_true(BN_is_negative(bn)))
+ || !TEST_BN_abs_eq_word(bn, 0x42)
+ || !TEST_BN_lt_zero(bn)
+ || !TEST_BN_le_zero(bn)
+ || !TEST_BN_ne_zero(bn)
+ || !TEST_BN_even(bn))
+ goto err;
+ BN_free(bn);
+ bn = NULL;
+
+ if (!TEST_int_eq(parseBN(&bn, "cb"), 2)
+ || !TEST_BN_eq_word(bn, 0xCB)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_gt_zero(bn)
+ || !TEST_BN_ne_zero(bn)
+ || !TEST_BN_odd(bn))
goto err;
BN_free(bn);
+ bn = NULL;
if (!TEST_int_eq(parseBN(&bn, "-0"), 2)
- || !TEST_true(BN_is_zero(bn))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_zero(bn)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_le_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
BN_free(bn);
+ bn = NULL;
if (!TEST_int_eq(parseBN(&bn, "abctrailing garbage is ignored"), 3)
- || !TEST_true(BN_is_word(bn, 0xabc))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_word(bn, 0xabc)
+ || !TEST_BN_ge_zero(bn)
+ || !TEST_BN_gt_zero(bn)
+ || !TEST_BN_ne_zero(bn)
+ || !TEST_BN_even(bn))
goto err;
st = 1;
goto err;
if (!TEST_true(BN_asc2bn(&bn, "0"))
- || !TEST_true(BN_is_zero(bn))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_zero(bn)
+ || !TEST_BN_ge_zero(bn))
goto err;
if (!TEST_true(BN_asc2bn(&bn, "256"))
- || !TEST_true(BN_is_word(bn, 256))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_word(bn, 256)
+ || !TEST_BN_ge_zero(bn))
goto err;
if (!TEST_true(BN_asc2bn(&bn, "-42"))
- || !TEST_true(BN_abs_is_word(bn, 42))
- || !TEST_true(BN_is_negative(bn)))
+ || !TEST_BN_abs_eq_word(bn, 42)
+ || !TEST_BN_lt_zero(bn))
goto err;
if (!TEST_true(BN_asc2bn(&bn, "0x1234"))
- || !TEST_true(BN_is_word(bn, 0x1234))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_word(bn, 0x1234)
+ || !TEST_BN_ge_zero(bn))
goto err;
if (!TEST_true(BN_asc2bn(&bn, "0X1234"))
- || !TEST_true(BN_is_word(bn, 0x1234))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_word(bn, 0x1234)
+ || !TEST_BN_ge_zero(bn))
goto err;
if (!TEST_true(BN_asc2bn(&bn, "-0xabcd"))
- || !TEST_true(BN_abs_is_word(bn, 0xabcd))
- || !TEST_true(BN_is_negative(bn)))
+ || !TEST_BN_abs_eq_word(bn, 0xabcd)
+ || !TEST_BN_lt_zero(bn))
goto err;
if (!TEST_true(BN_asc2bn(&bn, "-0"))
- || !TEST_true(BN_is_zero(bn))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_zero(bn)
+ || !TEST_BN_ge_zero(bn))
goto err;
if (!TEST_true(BN_asc2bn(&bn, "123trailing garbage is ignored"))
- || !TEST_true(BN_is_word(bn, 123))
- || !TEST_false(BN_is_negative(bn)))
+ || !TEST_BN_eq_word(bn, 123)
+ || !TEST_BN_ge_zero(bn))
goto err;
st = 1;
if (!TEST_ptr(bn2 = BN_mpi2bn(scratch, mpi_len, NULL)))
goto err;
- if (!TEST_int_eq(BN_cmp(bn, bn2), 0)) {
+ if (!TEST_BN_eq(bn, bn2)) {
BN_free(bn2);
goto err;
}
if (!TEST_false(BN_rand(bn, 0, 0 /* top */ , 0 /* bottom */ ))
|| !TEST_false(BN_rand(bn, 0, 1 /* top */ , 1 /* bottom */ ))
|| !TEST_true(BN_rand(bn, 1, 0 /* top */ , 0 /* bottom */ ))
- || !TEST_true(BN_is_word(bn, 1))
+ || !TEST_BN_eq_one(bn)
|| !TEST_false(BN_rand(bn, 1, 1 /* top */ , 0 /* bottom */ ))
|| !TEST_true(BN_rand(bn, 1, -1 /* top */ , 1 /* bottom */ ))
- || !TEST_true(BN_is_word(bn, 1))
+ || !TEST_BN_eq_one(bn)
|| !TEST_true(BN_rand(bn, 2, 1 /* top */ , 0 /* bottom */ ))
- || !TEST_true(BN_is_word(bn, 3)))
+ || !TEST_BN_eq_word(bn, 3))
goto err;
st = 1;
BN_zero(b);
if (!TEST_true(BN_mul(c, a, b, ctx)))
goto err;
- if (!TEST_true(BN_is_zero(c))
- || !TEST_false(BN_is_negative(c)))
+ if (!TEST_BN_eq_zero(c)
+ || !TEST_BN_ge_zero(c))
goto err;
for (consttime = 0; consttime < 2; consttime++) {
goto err;
BN_set_negative(numerator, 1);
if (!TEST_true(BN_div(a, b, numerator, denominator, ctx))
- || !TEST_true(BN_is_zero(a))
- || !TEST_false(BN_is_negative(a)))
+ || !TEST_BN_eq_zero(a)
+ || !TEST_BN_ge_zero(a))
goto err;
/* Test that BN_div never gives negative zero in the remainder. */
if (!TEST_true(BN_set_word(denominator, 1))
|| !TEST_true(BN_div(a, b, numerator, denominator, ctx))
- || !TEST_true(BN_is_zero(b))
- || !TEST_false(BN_is_negative(b)))
+ || !TEST_BN_eq_zero(b)
+ || !TEST_BN_ge_zero(b))
goto err;
BN_free(numerator);
BN_free(denominator);
BN_zero(zero);
if (!TEST_true(BN_mod_exp(r, a, zero, BN_value_one(), NULL))
- || !TEST_true(BN_is_zero(r))
+ || !TEST_BN_eq_zero(r)
|| !TEST_true(BN_mod_exp_mont(r, a, zero, BN_value_one(),
NULL, NULL))
- || !TEST_true(BN_is_zero(r))
+ || !TEST_BN_eq_zero(r)
|| !TEST_true(BN_mod_exp_mont_consttime(r, a, zero,
BN_value_one(),
NULL, NULL))
- || !TEST_true(BN_is_zero(r))
+ || !TEST_BN_eq_zero(r)
|| !TEST_true(BN_mod_exp_mont_word(r, 42, zero,
BN_value_one(), NULL, NULL))
- || !TEST_true(BN_is_zero(r)))
+ || !TEST_BN_eq_zero(r))
goto err;
st = 1;
if (!TEST_true(BN_dec2bn(&r, r_in)) || !TEST_true(BN_dec2bn(&s, s_in)))
goto x962_int_err;
ECDSA_SIG_get0(signature, &sig_r, &sig_s);
- if (!TEST_int_eq(BN_cmp(sig_r, r), 0)
- || !TEST_int_eq(BN_cmp(sig_s, s), 0))
+ if (!TEST_BN_eq(sig_r, r)
+ || !TEST_BN_eq(sig_s, s))
goto x962_int_err;
/* verify the signature */
/* G_y value taken from the standard: */
if (!TEST_true(BN_hex2bn(&z, "23a62855"
"3168947d59dcc912042351377ac5fb32"))
- || !TEST_int_eq(0, BN_cmp(y, z))
+ || !TEST_BN_eq(y, z)
|| !TEST_int_eq(EC_GROUP_get_degree(group), 160)
|| !group_order_tests(group)
|| !TEST_ptr(P_160 = EC_GROUP_new(EC_GROUP_method_of(group)))
/* G_y value taken from the standard: */
if (!TEST_true(BN_hex2bn(&z, "07192B95FFC8DA78"
"631011ED6B24CDD573F977A11E794811"))
- || !TEST_int_eq(0, BN_cmp(y, z))
+ || !TEST_BN_eq(y, z)
|| !TEST_true(BN_add(yplusone, y, BN_value_one()))
/*
* When (x, y) is on the curve, (x, y + 1) is, as it happens, not,
/* G_y value taken from the standard: */
if (!TEST_true(BN_hex2bn(&z, "BD376388B5F723FB4C22DFE6"
"CD4375A05A07476444D5819985007E34"))
- || !TEST_int_eq(0, BN_cmp(y, z))
+ || !TEST_BN_eq(y, z)
|| !TEST_true(BN_add(yplusone, y, BN_value_one()))
/*
* When (x, y) is on the curve, (x, y + 1) is, as it happens, not,
/* G_y value taken from the standard: */
if (!TEST_true(BN_hex2bn(&z, "4FE342E2FE1A7F9B8EE7EB4A7C0F9E16"
"2BCE33576B315ECECBB6406837BF51F5"))
- || !TEST_int_eq(0, BN_cmp(y, z))
+ || !TEST_BN_eq(y, z)
|| !TEST_true(BN_add(yplusone, y, BN_value_one()))
/*
* When (x, y) is on the curve, (x, y + 1) is, as it happens, not,
if (!TEST_true(BN_hex2bn(&z, "3617DE4A96262C6F5D9E98BF9292DC29"
"F8F41DBD289A147CE9DA3113B5F0B8C0"
"0A60B1CE1D7E819D7A431D7C90EA0E5F"))
- || !TEST_int_eq(0, BN_cmp(y, z))
+ || !TEST_BN_eq(y, z)
|| !TEST_true(BN_add(yplusone, y, BN_value_one()))
/*
* When (x, y) is on the curve, (x, y + 1) is, as it happens, not,
"98F54449579B446817AFBD17273E662C"
"97EE72995EF42640C550B9013FAD0761"
"353C7086A272C24088BE94769FD16650"))
- || !TEST_int_eq(0, BN_cmp(y, z))
+ || !TEST_BN_eq(y, z)
|| !TEST_true(BN_add(yplusone, y, BN_value_one()))
/*
* When (x, y) is on the curve, (x, y + 1) is, as it happens, not,
if (!TEST_true(EC_GROUP_get_order(group, z, ctx))
|| !TEST_true(BN_add(y, z, BN_value_one()))
- || !TEST_false(BN_is_odd(y))
+ || !TEST_BN_even(y)
|| !TEST_true(BN_rshift1(y, y)))
goto err;
scalars[0] = y; /* (group order + 1)/2, so y*Q + y*Q = Q */
BIO_printf(bio_out, "\n");
/* G_y value taken from the standard: */
if (!TEST_true(BN_hex2bn(&z, test->y))
- || !TEST_int_eq(0, BN_cmp(y, z)))
+ || !TEST_BN_eq(y, z))
goto err;
# else
/*
points[2] = Q;
if (!TEST_true(BN_add(y, z, BN_value_one()))
- || !TEST_false(BN_is_odd(y))
+ || !TEST_BN_even(y)
|| !TEST_true(BN_rshift1(y, y)))
goto err;
scalars[0] = y; /* (group order + 1)/2, so y*Q + y*Q = Q */
if (!TEST_true(BN_mod_exp_mont_word(r, one_word, p, m, ctx, NULL)))
goto err;
- if (!TEST_true(BN_is_zero(r))) {
+ if (!TEST_BN_eq_zero(r)) {
fprintf(stderr, "BN_mod_exp_mont_word failed:\n");
fprintf(stderr, "1 ** 0 mod 1 = r (should be 0)\n");
BN_print_var(r);
|| !TEST_true(BN_mod_exp_mont_consttime(r_mont_const, a, b, m, ctx, NULL)))
goto err;
- if (!TEST_int_eq(BN_cmp(r_simple, r_mont), 0)
- || !TEST_int_eq(BN_cmp(r_simple, r_recp), 0)
- || !TEST_int_eq(BN_cmp(r_simple, r_mont_const), 0)) {
+ if (!TEST_BN_eq(r_simple, r_mont)
+ || !TEST_BN_eq(r_simple, r_recp)
+ || !TEST_BN_eq(r_simple, r_mont_const)) {
if (BN_cmp(r_simple, r_mont) != 0)
- fprintf(stderr, "simple and mont results differ\n");
+ TEST_info("simple and mont results differ");
if (BN_cmp(r_simple, r_mont_const) != 0)
- fprintf(stderr, "simple and mont const time results differ\n");
+ TEST_info("simple and mont const time results differ");
if (BN_cmp(r_simple, r_recp) != 0)
- fprintf(stderr, "simple and recp results differ\n");
+ TEST_info("simple and recp results differ");
BN_print_var(a);
BN_print_var(b);
/* Server random */
RAND_bytes(rand_tmp, sizeof(rand_tmp));
b = BN_bin2bn(rand_tmp, sizeof(rand_tmp), NULL);
- if (!TEST_false(BN_is_zero(b)))
+ if (!TEST_BN_ne_zero(b))
goto end;
showbn("b", b);
/* Client random */
RAND_bytes(rand_tmp, sizeof(rand_tmp));
a = BN_bin2bn(rand_tmp, sizeof(rand_tmp), NULL);
- if (!TEST_false(BN_is_zero(a)))
+ if (!TEST_BN_ne_zero(a))
goto end;
showbn("a", a);
Kserver = SRP_Calc_server_key(Apub, v, u, b, GN->N);
showbn("Server's key", Kserver);
- if (!TEST_int_eq(BN_cmp(Kclient, Kserver), 0))
+ if (!TEST_BN_eq(Kclient, Kserver))
goto end;
ret = 1;
static int check_bn(const char *name, const BIGNUM *bn, const char *hexbn)
{
BIGNUM *tmp = NULL;
+ int r;
if (!TEST_true(BN_hex2bn(&tmp, hexbn)))
return 0;
- if (!TEST_int_eq(BN_cmp(bn, tmp), 0)) {
- TEST_info("Unexpected %s value", name);
- showbn("expecting", tmp);
- showbn("received", bn);
- BN_free(tmp);
- return 0;
- }
+ if (BN_cmp(bn, tmp) != 0)
+ TEST_error("unexpected %s value", name);
+ r = TEST_BN_eq(bn, tmp);
BN_free(tmp);
- return 1;
+ return r;
}
/* SRP test vectors from RFC5054 */
#include <openssl/err.h>
#include <openssl/e_os2.h>
+#include <openssl/bn.h>
/*-
* Simple unit tests should implement register_tests().
int test_true(const char *file, int line, const char *s, int b);
int test_false(const char *file, int line, const char *s, int b);
+/*
+ * Comparisons between BIGNUMs.
+ * BIGNUMS can be compared against other BIGNUMs or zero.
+ * Some additional equality tests against 1 & specific values are provided.
+ * Tests for parity are included as well.
+ */
+DECLARE_COMPARISONS(BIGNUM *, BN)
+int test_BN_eq_zero(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_ne_zero(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_lt_zero(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_le_zero(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_gt_zero(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_ge_zero(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_eq_one(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_odd(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_even(const char *file, int line, const char *s, const BIGNUM *a);
+int test_BN_eq_word(const char *file, int line, const char *bns, const char *ws,
+ const BIGNUM *a, BN_ULONG w);
+int test_BN_abs_eq_word(const char *file, int line, const char *bns,
+ const char *ws, const BIGNUM *a, BN_ULONG w);
+
/*
* Pretty print a failure message.
* These should not be called directly, use the TEST_xxx macros below instead.
# define TEST_true(a) test_true(__FILE__, __LINE__, #a, (a) != 0)
# define TEST_false(a) test_false(__FILE__, __LINE__, #a, (a) != 0)
+# define TEST_BN_eq(a, b) test_BN_eq(__FILE__, __LINE__, #a, #b, a, b)
+# define TEST_BN_ne(a, b) test_BN_ne(__FILE__, __LINE__, #a, #b, a, b)
+# define TEST_BN_eq_zero(a) test_BN_eq_zero(__FILE__, __LINE__, #a, a)
+# define TEST_BN_ne_zero(a) test_BN_ne_zero(__FILE__, __LINE__, #a, a)
+# define TEST_BN_lt_zero(a) test_BN_lt_zero(__FILE__, __LINE__, #a, a)
+# define TEST_BN_gt_zero(a) test_BN_gt_zero(__FILE__, __LINE__, #a, a)
+# define TEST_BN_le_zero(a) test_BN_le_zero(__FILE__, __LINE__, #a, a)
+# define TEST_BN_ge_zero(a) test_BN_ge_zero(__FILE__, __LINE__, #a, a)
+# define TEST_BN_eq_one(a) test_BN_eq_one(__FILE__, __LINE__, #a, a)
+# define TEST_BN_eq_word(a, w) test_BN_eq_word(__FILE__, __LINE__, #a, #w, a, w)
+# define TEST_BN_abs_eq_word(a, w) test_BN_abs_eq_word(__FILE__, __LINE__, #a, #w, a, w)
+# define TEST_BN_odd(a) test_BN_odd(__FILE__, __LINE__, #a, a)
+# define TEST_BN_even(a) test_BN_even(__FILE__, __LINE__, #a, a)
+
/*
* TEST_error(desc, ...) prints an informative error message in the standard
* format. |desc| is a printf format string.
#define MEM_BUFFER_SIZE (33)
#define MAX_STRING_WIDTH (80)
+/* Special representation of -0 */
+static char BN_minus_zero[] = "-0";
+
/* Output a failed test first line */
static void test_fail_message_prefix(const char *prefix, const char *file,
int line, const char *type,
test_flush_stderr();
}
+static char *convertBN(const BIGNUM *b)
+{
+ if (b == NULL)
+ return NULL;
+ if (BN_is_zero(b) && BN_is_negative(b))
+ return BN_minus_zero;
+ return BN_bn2hex(b);
+}
+
+static void test_fail_bignum_message(const char *prefix, const char *file,
+ int line, const char *type,
+ const char *left, const char *right,
+ const char *op,
+ const BIGNUM *bn1, const BIGNUM *bn2)
+{
+ char *s1 = convertBN(bn1), *s2 = convertBN(bn2);
+ size_t l1 = s1 != NULL ? strlen(s1) : 0;
+ size_t l2 = s2 != NULL ? strlen(s2) : 0;
+
+ test_fail_string_message(prefix, file, line, type, left, right, op,
+ s1, l1, s2, l2);
+ if (s1 != BN_minus_zero)
+ OPENSSL_free(s1);
+ if (s2 != BN_minus_zero)
+ OPENSSL_free(s2);
+}
+
+static void test_fail_bignum_mono_message(const char *prefix, const char *file,
+ int line, const char *type,
+ const char *left, const char *right,
+ const char *op, const BIGNUM *bn)
+{
+ char *s = convertBN(bn);
+ size_t l = s != NULL ? strlen(s) : 0;
+
+ test_fail_string_message(prefix, file, line, type, left, right, op,
+ s, l, s, l);
+ if (s != BN_minus_zero)
+ OPENSSL_free(s);
+}
+
static void hex_convert_memory(const char *m, size_t n, char *b)
{
size_t i;
}
return 1;
}
+
+#define DEFINE_BN_COMPARISONS(opname, op, zero_cond) \
+ int test_BN_ ## opname(const char *file, int line, \
+ const char *s1, const char *s2, \
+ const BIGNUM *t1, const BIGNUM *t2) \
+ { \
+ if (BN_cmp(t1, t2) op 0) \
+ return 1; \
+ test_fail_bignum_message(NULL, file, line, "BIGNUM", s1, s2, \
+ #op, t1, t2); \
+ return 0; \
+ } \
+ int test_BN_ ## opname ## _zero(const char *file, int line, \
+ const char *s, const BIGNUM *a) \
+ { \
+ if (a != NULL &&(zero_cond)) \
+ return 1; \
+ test_fail_bignum_mono_message(NULL, file, line, "BIGNUM", \
+ s, "0", #op, a); \
+ return 0; \
+ }
+
+DEFINE_BN_COMPARISONS(eq, ==, BN_is_zero(a))
+DEFINE_BN_COMPARISONS(ne, !=, !BN_is_zero(a))
+DEFINE_BN_COMPARISONS(gt, >, !BN_is_negative(a) && !BN_is_zero(a))
+DEFINE_BN_COMPARISONS(ge, >=, !BN_is_negative(a) || BN_is_zero(a))
+DEFINE_BN_COMPARISONS(lt, <, BN_is_negative(a) && !BN_is_zero(a))
+DEFINE_BN_COMPARISONS(le, <=, BN_is_negative(a) || BN_is_zero(a))
+
+int test_BN_eq_one(const char *file, int line, const char *s, const BIGNUM *a)
+{
+ if (a != NULL && BN_is_one(a))
+ return 1;
+ test_fail_bignum_mono_message(NULL, file, line, "BIGNUM", s, "1", "==", a);
+ return 0;
+}
+
+int test_BN_odd(const char *file, int line, const char *s, const BIGNUM *a)
+{
+ if (a != NULL && BN_is_odd(a))
+ return 1;
+ test_fail_bignum_mono_message(NULL, file, line, "BIGNUM", "ODD(", ")", s,
+ a);
+ return 0;
+}
+
+int test_BN_even(const char *file, int line, const char *s, const BIGNUM *a)
+{
+ if (a != NULL && !BN_is_odd(a))
+ return 1;
+ test_fail_bignum_mono_message(NULL, file, line, "BIGNUM", "EVEN(", ")", s,
+ a);
+ return 0;
+}
+
+int test_BN_eq_word(const char *file, int line, const char *bns, const char *ws,
+ const BIGNUM *a, BN_ULONG w)
+{
+ BIGNUM *bw;
+
+ if (a != NULL && BN_is_word(a, w))
+ return 1;
+ bw = BN_new();
+ BN_set_word(bw, w);
+ test_fail_bignum_message(NULL, file, line, "BIGNUM", bns, ws, "==", a, bw);
+ BN_free(bw);
+ return 0;
+}
+
+int test_BN_abs_eq_word(const char *file, int line, const char *bns,
+ const char *ws, const BIGNUM *a, BN_ULONG w)
+{
+ BIGNUM *bw, *aa;
+
+ if (a != NULL && BN_abs_is_word(a, w))
+ return 1;
+ bw = BN_new();
+ aa = BN_dup(a);
+ BN_set_negative(aa, 0);
+ BN_set_word(bw, w);
+ test_fail_bignum_message(NULL, file, line, "BIGNUM", bns, ws, "abs==",
+ aa, bw);
+ BN_free(bw);
+ BN_free(aa);
+ return 0;
+}