~ubuntu-branches/ubuntu/vivid/nettle/vivid

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
}