Simplify test for ecdsa_verify
Signed-off-by: Dave Rodgman <dave.rodgman@arm.com>
This commit is contained in:
parent
34ff6a7a31
commit
5d7a235efe
2 changed files with 18 additions and 23 deletions
|
@ -364,60 +364,60 @@ ecdsa_prim_test_vectors:MBEDTLS_ECP_DP_SECP521R1:"0065FDA3409451DCAB0A0EAD454951
|
||||||
|
|
||||||
ECDSA verify invalid pub key (not on curve), zero bytes of data
|
ECDSA verify invalid pub key (not on curve), zero bytes of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"1":"1":"":0:MBEDTLS_ERR_ECP_INVALID_KEY
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"1":"1":"":MBEDTLS_ERR_ECP_INVALID_KEY
|
||||||
|
|
||||||
ECDSA verify invalid pub key (not on curve), one byte of data
|
ECDSA verify invalid pub key (not on curve), one byte of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"1":"1":"00":0:MBEDTLS_ERR_ECP_INVALID_KEY
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"1":"1":"00":MBEDTLS_ERR_ECP_INVALID_KEY
|
||||||
|
|
||||||
ECDSA verify invalid pub key (not on curve), r=1, s=1
|
ECDSA verify invalid pub key (not on curve), r=1, s=1
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"1":"1":"0000000000000000000000000000000000000000000000000000000000000000":0:MBEDTLS_ERR_ECP_INVALID_KEY
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"1":"1":"0000000000000000000000000000000000000000000000000000000000000000":MBEDTLS_ERR_ECP_INVALID_KEY
|
||||||
|
|
||||||
ECDSA verify invalid pub key (also not on curve), r=1, s=1
|
ECDSA verify invalid pub key (also not on curve), r=1, s=1
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"12345":"1":"1":"0000000000000000000000000000000000000000000000000000000000000000":0:MBEDTLS_ERR_ECP_INVALID_KEY
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"12345":"1":"1":"0000000000000000000000000000000000000000000000000000000000000000":MBEDTLS_ERR_ECP_INVALID_KEY
|
||||||
|
|
||||||
ECDSA verify invalid pub key (not on curve), r=12345, s=1
|
ECDSA verify invalid pub key (not on curve), r=12345, s=1
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"12345":"1":"0000000000000000000000000000000000000000000000000000000000000000":0:MBEDTLS_ERR_ECP_INVALID_KEY
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"12345":"1":"0000000000000000000000000000000000000000000000000000000000000000":MBEDTLS_ERR_ECP_INVALID_KEY
|
||||||
|
|
||||||
ECDSA verify invalid pub key (not on curve), r=1, s=12345
|
ECDSA verify invalid pub key (not on curve), r=1, s=12345
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"1":"12345":"0000000000000000000000000000000000000000000000000000000000000000":0:MBEDTLS_ERR_ECP_INVALID_KEY
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"1":"2":"1":"12345":"0000000000000000000000000000000000000000000000000000000000000000":MBEDTLS_ERR_ECP_INVALID_KEY
|
||||||
|
|
||||||
ECDSA verify valid pub key, invalid sig (r=0), 0 bytes of data
|
ECDSA verify valid pub key, invalid sig (r=0), 0 bytes of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"0":"1":"":1:MBEDTLS_ERR_ECP_VERIFY_FAILED
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"0":"1":"":MBEDTLS_ERR_ECP_VERIFY_FAILED
|
||||||
|
|
||||||
ECDSA verify valid pub key, invalid sig (r=0), 1 byte of data
|
ECDSA verify valid pub key, invalid sig (r=0), 1 byte of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"0":"1":"00":1:MBEDTLS_ERR_ECP_VERIFY_FAILED
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"0":"1":"00":MBEDTLS_ERR_ECP_VERIFY_FAILED
|
||||||
|
|
||||||
ECDSA verify valid pub key, invalid sig (r>n-1), 32 bytes of data
|
ECDSA verify valid pub key, invalid sig (r>n-1), 32 bytes of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141":"12":"0000000000000000000000000000000000000000000000000000000000000000":1:MBEDTLS_ERR_ECP_VERIFY_FAILED
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141":"12":"0000000000000000000000000000000000000000000000000000000000000000":MBEDTLS_ERR_ECP_VERIFY_FAILED
|
||||||
|
|
||||||
ECDSA verify valid pub key, valid/incorrect sig, 0 bytes of data
|
ECDSA verify valid pub key, valid/incorrect sig, 0 bytes of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"84eead3fb3cdbdac882412af64cc125b6784690bebf575f1c32162ab65080037":"":1:MBEDTLS_ERR_ECP_VERIFY_FAILED
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"84eead3fb3cdbdac882412af64cc125b6784690bebf575f1c32162ab65080037":"":MBEDTLS_ERR_ECP_VERIFY_FAILED
|
||||||
|
|
||||||
ECDSA verify valid pub key, valid/incorrect sig, 1 byte of data
|
ECDSA verify valid pub key, valid/incorrect sig, 1 byte of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"84eead3fb3cdbdac882412af64cc125b6784690bebf575f1c32162ab65080037":"00":1:MBEDTLS_ERR_ECP_VERIFY_FAILED
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"84eead3fb3cdbdac882412af64cc125b6784690bebf575f1c32162ab65080037":"00":MBEDTLS_ERR_ECP_VERIFY_FAILED
|
||||||
|
|
||||||
ECDSA verify valid pub key, valid/incorrect sig, 32 bytes of data
|
ECDSA verify valid pub key, valid/incorrect sig, 32 bytes of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"84eead3fb3cdbdac882412af64cc125b6784690bebf575f1c32162ab65080037":"0000000000000000000000000000000000000000000000000000000000000000":1:MBEDTLS_ERR_ECP_VERIFY_FAILED
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"84eead3fb3cdbdac882412af64cc125b6784690bebf575f1c32162ab65080037":"0000000000000000000000000000000000000000000000000000000000000000":MBEDTLS_ERR_ECP_VERIFY_FAILED
|
||||||
|
|
||||||
ECDSA verify valid public key, correct sig, 0 bytes of data
|
ECDSA verify valid public key, correct sig, 0 bytes of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"c9cc1ba95156bc103055a5d7946f3a3ae7f0657d1e53f1d5c2c9782950aa69b":"":1:0
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"c9cc1ba95156bc103055a5d7946f3a3ae7f0657d1e53f1d5c2c9782950aa69b":"":0
|
||||||
|
|
||||||
ECDSA verify valid pub key, correct sig, 1 byte of data
|
ECDSA verify valid pub key, correct sig, 1 byte of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"c9cc1ba95156bc103055a5d7946f3a3ae7f0657d1e53f1d5c2c9782950aa69b":"00":1:0
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"c9cc1ba95156bc103055a5d7946f3a3ae7f0657d1e53f1d5c2c9782950aa69b":"00":0
|
||||||
|
|
||||||
ECDSA verify valid pub key, correct sig, 32 bytes of data
|
ECDSA verify valid pub key, correct sig, 32 bytes of data
|
||||||
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
depends_on:MBEDTLS_ECP_DP_SECP256K1_ENABLED
|
||||||
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"c9cc1ba95156bc103055a5d7946f3a3ae7f0657d1e53f1d5c2c9782950aa69b":"0000000000000000000000000000000000000000000000000000000000000000":1:0
|
ecdsa_verify:MBEDTLS_ECP_DP_SECP256K1:"79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798":"483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8":"ed3bace23c5e17652e174c835fb72bf53ee306b3406a26890221b4cef7500f88":"c9cc1ba95156bc103055a5d7946f3a3ae7f0657d1e53f1d5c2c9782950aa69b":"0000000000000000000000000000000000000000000000000000000000000000":0
|
||||||
|
|
|
@ -468,7 +468,7 @@ exit:
|
||||||
/* END_CASE */
|
/* END_CASE */
|
||||||
|
|
||||||
/* BEGIN_CASE */
|
/* BEGIN_CASE */
|
||||||
void ecdsa_verify( int grp_id, char * x, char * y, char * r, char * s, data_t * content, int key_is_valid, int expected )
|
void ecdsa_verify( int grp_id, char * x, char * y, char * r, char * s, data_t * content, int expected )
|
||||||
{
|
{
|
||||||
mbedtls_ecdsa_context ctx;
|
mbedtls_ecdsa_context ctx;
|
||||||
mbedtls_mpi sig_r, sig_s;
|
mbedtls_mpi sig_r, sig_s;
|
||||||
|
@ -493,18 +493,13 @@ void ecdsa_verify( int grp_id, char * x, char * y, char * r, char * s, data_t *
|
||||||
TEST_EQUAL( mbedtls_test_read_mpi( &sig_s, s ), 0 );
|
TEST_EQUAL( mbedtls_test_read_mpi( &sig_s, s ), 0 );
|
||||||
|
|
||||||
/* Test whether public key has expected validity */
|
/* Test whether public key has expected validity */
|
||||||
TEST_EQUAL( mbedtls_ecp_check_pubkey( &ctx.grp, &ctx.Q ), key_is_valid ? 0 : MBEDTLS_ERR_ECP_INVALID_KEY );
|
TEST_EQUAL( mbedtls_ecp_check_pubkey( &ctx.grp, &ctx.Q ),
|
||||||
|
expected == MBEDTLS_ERR_ECP_INVALID_KEY ? MBEDTLS_ERR_ECP_INVALID_KEY : 0 );
|
||||||
|
|
||||||
/* Verification */
|
/* Verification */
|
||||||
int result = mbedtls_ecdsa_verify( &ctx.grp, content->x, content->len, &ctx.Q, &sig_r, &sig_s );
|
int result = mbedtls_ecdsa_verify( &ctx.grp, content->x, content->len, &ctx.Q, &sig_r, &sig_s );
|
||||||
|
|
||||||
TEST_EQUAL( result, expected );
|
TEST_EQUAL( result, expected );
|
||||||
|
|
||||||
if ( !key_is_valid ) {
|
|
||||||
/* Invalid public key must always fail */
|
|
||||||
TEST_ASSERT( result != 0 );
|
|
||||||
}
|
|
||||||
|
|
||||||
exit:
|
exit:
|
||||||
mbedtls_ecdsa_free( &ctx );
|
mbedtls_ecdsa_free( &ctx );
|
||||||
mbedtls_mpi_free( &sig_r );
|
mbedtls_mpi_free( &sig_r );
|
||||||
|
|
Loading…
Reference in a new issue