From 6af79f3a03fe23342ff4e41d0405238905643b67 Mon Sep 17 00:00:00 2001 From: Nick Mathewson Date: Thu, 1 May 2003 00:53:46 +0000 Subject: Basic diffie-helman wrappers with fixed modulus and tests svn:r257 --- src/or/test.c | 36 +++++++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) (limited to 'src/or') diff --git a/src/or/test.c b/src/or/test.c index 8b53d7d22c..17ad0ecf6b 100644 --- a/src/or/test.c +++ b/src/or/test.c @@ -229,8 +229,41 @@ test_buffers() { buf_free(buf2); } +void +test_crypto_dh() +{ + crypto_dh_env_t *dh1, *dh2; + char p1[CRYPTO_DH_SIZE]; + char p2[CRYPTO_DH_SIZE]; + char s1[CRYPTO_DH_SIZE]; + char s2[CRYPTO_DH_SIZE]; + + dh1 = crypto_dh_new(); + dh2 = crypto_dh_new(); + test_eq(crypto_dh_get_bytes(dh1), CRYPTO_DH_SIZE); + test_eq(crypto_dh_get_bytes(dh2), CRYPTO_DH_SIZE); + + memset(p1, 0, CRYPTO_DH_SIZE); + memset(p2, 0, CRYPTO_DH_SIZE); + test_memeq(p1, p2, CRYPTO_DH_SIZE); + test_assert(! crypto_dh_get_public(dh1, p1, CRYPTO_DH_SIZE)); + test_memneq(p1, p2, CRYPTO_DH_SIZE); + test_assert(! crypto_dh_get_public(dh2, p2, CRYPTO_DH_SIZE)); + test_memneq(p1, p2, CRYPTO_DH_SIZE); + + memset(s1, 0, CRYPTO_DH_SIZE); + memset(s2, 0, CRYPTO_DH_SIZE); + test_assert(! crypto_dh_compute_secret(dh1, p2, CRYPTO_DH_SIZE, s1)); + test_assert(! crypto_dh_compute_secret(dh2, p1, CRYPTO_DH_SIZE, s2)); + test_memeq(s1, s2, CRYPTO_DH_SIZE); + + crypto_dh_free(dh1); + crypto_dh_free(dh2); +} + void -test_crypto() { +test_crypto() +{ crypto_cipher_env_t *env1, *env2; crypto_pk_env_t *pk1, *pk2; char *data1, *data2, *data3, *cp; @@ -441,6 +474,7 @@ main(int c, char**v) { puts("========================== Buffers ========================="); test_buffers(); puts("========================== Crypto =========================="); + test_crypto_dh(); test_crypto(); /* this seg faults :( */ puts("\n========================== Util ============================"); test_util(); -- cgit v1.2.3-54-g00ecf