1.1.5
by Magnus Holmgren
Import upstream version 2.0 |
1 |
/* For FILE, used by gmp.h */
|
2 |
#include <cstdio> |
|
3 |
||
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
4 |
#include "testutils.h" |
5 |
#include "md5.h" |
|
6 |
||
7 |
/* Test C++ linkage */
|
|
1.5.2
by Magnus Holmgren
Import upstream version 2.6 |
8 |
void
|
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
9 |
test_main(void) |
10 |
{
|
|
11 |
struct md5_ctx md5; |
|
12 |
uint8_t digest[MD5_DIGEST_SIZE]; |
|
13 |
||
14 |
md5_init (&md5); |
|
15 |
md5_update (&md5, 14, reinterpret_cast<const uint8_t *> ("message digest")); |
|
16 |
md5_digest (&md5, MD5_DIGEST_SIZE, digest); |
|
17 |
||
1.5.2
by Magnus Holmgren
Import upstream version 2.6 |
18 |
ASSERT (MEMEQ (MD5_DIGEST_SIZE, digest, |
19 |
H("F96B697D7CB7938D 525A2F31AAF161D0"))); |
|
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
20 |
|
21 |
#if WITH_PUBLIC_KEY
|
|
22 |
||
23 |
struct rsa_public_key pub; |
|
24 |
struct rsa_private_key key; |
|
25 |
||
26 |
mpz_t expected; |
|
27 |
||
28 |
mpz_init(expected); |
|
29 |
||
30 |
rsa_private_key_init(&key); |
|
31 |
rsa_public_key_init(&pub); |
|
32 |
||
33 |
mpz_set_str(pub.n, |
|
34 |
"69abd505285af665" "36ddc7c8f027e6f0" "ed435d6748b16088" |
|
35 |
"4fd60842b3a8d7fb" "bd8a3c98f0cc50ae" "4f6a9f7dd73122cc" |
|
36 |
"ec8afa3f77134406" "f53721973115fc2d" "8cfbba23b145f28d" |
|
37 |
"84f81d3b6ae8ce1e" "2850580c026e809b" "cfbb52566ea3a3b3" |
|
38 |
"df7edf52971872a7" "e35c1451b8636d22" "279a8fb299368238" |
|
39 |
"e545fbb4cf", 16); |
|
40 |
mpz_set_str(pub.e, "0db2ad57", 16); |
|
41 |
||
1.5.2
by Magnus Holmgren
Import upstream version 2.6 |
42 |
ASSERT (rsa_public_key_prepare(&pub)); |
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
43 |
|
44 |
mpz_set_str(key.p, |
|
45 |
"0a66399919be4b4d" "e5a78c5ea5c85bf9" "aba8c013cb4a8732" |
|
46 |
"14557a12bd67711e" "bb4073fd39ad9a86" "f4e80253ad809e5b" |
|
47 |
"f2fad3bc37f6f013" "273c9552c9f489", 16); |
|
48 |
||
49 |
mpz_set_str(key.q, |
|
50 |
"0a294f069f118625" "f5eae2538db9338c" "776a298eae953329" |
|
51 |
"9fd1eed4eba04e82" "b2593bc98ba8db27" "de034da7daaea795" |
|
52 |
"2d55b07b5f9a5875" "d1ca5f6dcab897", 16); |
|
53 |
||
54 |
mpz_set_str(key.a, |
|
55 |
"011b6c48eb592eee" "e85d1bb35cfb6e07" "344ea0b5e5f03a28" |
|
56 |
"5b405396cbc78c5c" "868e961db160ba8d" "4b984250930cf79a" |
|
57 |
"1bf8a9f28963de53" "128aa7d690eb87", 16); |
|
58 |
||
59 |
mpz_set_str(key.b, |
|
60 |
"0409ecf3d2557c88" "214f1af5e1f17853" "d8b2d63782fa5628" |
|
61 |
"60cf579b0833b7ff" "5c0529f2a97c6452" "2fa1a8878a9635ab" |
|
62 |
"ce56debf431bdec2" "70b308fa5bf387", 16); |
|
63 |
||
64 |
mpz_set_str(key.c, |
|
65 |
"04e103ee925cb5e6" "6653949fa5e1a462" "c9e65e1adcd60058" |
|
66 |
"e2df9607cee95fa8" "daec7a389a7d9afc" "8dd21fef9d83805a" |
|
67 |
"40d46f49676a2f6b" "2926f70c572c00", 16); |
|
68 |
||
1.5.2
by Magnus Holmgren
Import upstream version 2.6 |
69 |
ASSERT (rsa_private_key_prepare(&key)); |
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
70 |
|
1.5.2
by Magnus Holmgren
Import upstream version 2.6 |
71 |
ASSERT (pub.size == key.size); |
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
72 |
|
73 |
mpz_set_str(expected, |
|
74 |
"53bf517009fa956e" "3daa6adc95e8663d" "3759002f488bbbad" |
|
75 |
"e49f62792d85dbcc" "293f68e2b68ef89a" "c5bd42d98f845325" |
|
76 |
"3e6c1b76fc337db5" "e0053f255c55faf3" "eb6cc568ad7f5013" |
|
77 |
"5b269a64acb9eaa7" "b7f09d9bd90310e6" "4c58f6dbe673ada2" |
|
78 |
"67c97a9d99e19f9d" "87960d9ce3f0d5ce" "84f401fe7e10fa24" |
|
79 |
"28b9bffcf9", 16); |
|
80 |
||
81 |
mpz_t signature; |
|
82 |
mpz_init(signature); |
|
83 |
||
84 |
/* Create signature */
|
|
85 |
md5_update (&md5, 39, reinterpret_cast<const uint8_t *> |
|
86 |
("The magic words are squeamish ossifrage")); |
|
1.4.2
by Magnus Holmgren
Import upstream version 2.1 |
87 |
ASSERT (rsa_md5_sign (&key, &md5, signature)); |
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
88 |
|
89 |
/* Verify it */
|
|
90 |
md5_update (&md5, 39, reinterpret_cast<const uint8_t *> |
|
91 |
("The magic words are squeamish ossifrage")); |
|
1.5.2
by Magnus Holmgren
Import upstream version 2.6 |
92 |
ASSERT (rsa_md5_verify (&pub, &md5, signature)); |
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
93 |
|
94 |
/* Try bad data */
|
|
95 |
md5_update (&md5, 39, reinterpret_cast<const uint8_t *> |
|
96 |
("The magik words are squeamish ossifrage")); |
|
1.5.2
by Magnus Holmgren
Import upstream version 2.6 |
97 |
ASSERT (!rsa_md5_verify (&pub, &md5, signature)); |
1.1.4
by Magnus Holmgren
Import upstream version 1.15 |
98 |
|
99 |
#endif /* WITH_PUBLIC_KEY */ |
|
100 |
}
|