~ubuntu-branches/ubuntu/quantal/nettle/quantal

« back to all changes in this revision

Viewing changes to testsuite/rsa-test.c

  • Committer: Bazaar Package Importer
  • Author(s): Marek Habersack
  • Date: 2004-05-04 15:56:02 UTC
  • Revision ID: james.westby@ubuntu.com-20040504155602-7jbhw5mabvwksl3j
Tags: upstream-1.10
ImportĀ upstreamĀ versionĀ 1.10

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#include "testutils.h"
 
2
 
 
3
int
 
4
test_main(void)
 
5
{
 
6
#if WITH_PUBLIC_KEY
 
7
 
 
8
  struct rsa_public_key pub;
 
9
  struct rsa_private_key key;
 
10
 
 
11
  mpz_t expected;
 
12
  
 
13
  mpz_init(expected);
 
14
  
 
15
  rsa_private_key_init(&key);
 
16
  rsa_public_key_init(&pub);
 
17
 
 
18
  test_rsa_set_key_1(&pub, &key);
 
19
  
 
20
  /* Test md5 signatures */
 
21
  mpz_set_str(expected,
 
22
              "53bf517009fa956e" "3daa6adc95e8663d" "3759002f488bbbad"
 
23
              "e49f62792d85dbcc" "293f68e2b68ef89a" "c5bd42d98f845325"
 
24
              "3e6c1b76fc337db5" "e0053f255c55faf3" "eb6cc568ad7f5013"
 
25
              "5b269a64acb9eaa7" "b7f09d9bd90310e6" "4c58f6dbe673ada2"
 
26
              "67c97a9d99e19f9d" "87960d9ce3f0d5ce" "84f401fe7e10fa24"
 
27
              "28b9bffcf9", 16);
 
28
 
 
29
  test_rsa_md5(&pub, &key, expected);
 
30
 
 
31
  /* Test sha1 signature */
 
32
  mpz_set_str(expected,
 
33
              "129b405ed85db88c" "55d35344c4b52854" "496516b4d63d8211"
 
34
              "80a0c24d6ced9047" "33065a564bbd33d0" "a5cdfd204b9c6d15"
 
35
              "78337207c2f1662d" "c73906c7a0f2bf5c" "af92cef9121957b1"
 
36
              "dcb111ff47b92389" "888e384d0cfd1b1e" "e5d7003a8feff3fd"
 
37
              "dd6a71d242a79272" "25234d67ba369441" "c12ae555c697754e"
 
38
              "a17f93fa92", 16);
 
39
 
 
40
  test_rsa_sha1(&pub, &key, expected);
 
41
 
 
42
  /* 777-bit key, generated by
 
43
   *
 
44
   *   lsh-keygen -a rsa -l 777 -f advanced-hex
 
45
   *
 
46
   * Interesting because the size of n doesn't equal the sum of the
 
47
   * sizes of p and q. 
 
48
   *
 
49
   * (private-key (rsa-pkcs1
 
50
   *        (n #013b04440e3eef25 d51c738d508a7fa8 b3445180c342af0f
 
51
   *            4cb5a789047300e2 cfc5c5450974cfc2 448aeaaa7f43c374
 
52
   *            c9a3b038b181f2d1 0f1a2327fd2c087b a49bf1086969fd2c
 
53
   *            d1df3fd69f81fa4b 162cc8bbb363fc95 b7b24b9c53d0c67e
 
54
   *            f52b#)
 
55
   *        (e #3f1a012d#)
 
56
   *        (d #f9bae89dacca6cca c21e0412b4df8355 6fe7c5322bbae8ad
 
57
   *            3f11494fd12bc076 d4a7da3050fe109d 2074db09cc6a93b4
 
58
   *            745479522558379e a0ddfa74f86c9e9e a22c3b0e93d51447
 
59
   *            0feb38105dd35395 63b91ee32776f40c 67b2a175690f7abb
 
60
   *            25#)
 
61
   *        (p #0b73c990eeda0a2a 2c26416052c85560 0c5c0f5ce86a8326
 
62
   *            166acea91786237a 7ff884e66dbfdd3a ab9d9801414c1506
 
63
   *            8b#)
 
64
   *        (q #1b81c19a62802a41 9c99283331b0badb 08eb0c25ffce0fbf
 
65
   *            50017850036f32f3 2132a845b91a5236 61f7b451d587383f
 
66
   *            e1#)
 
67
   *        (a #0a912fc93a6cca6b 3521725a3065b3be 3c9745e29c93303d
 
68
   *            7d29316c6cafa4a2 89945f964fcdea59 1f9d248b0b6734be
 
69
   *            c9#)
 
70
   *        (b #1658eca933251813 1eb19c77aba13d73 e0b8f4ce986d7615
 
71
   *            764c6b0b03c18146 46b7f332c43e05c5 351e09006979ca5b
 
72
   *            05#)
 
73
   *        (c #0114720dace7b27f 2bf2850c1804869f 79a0aad0ec02e6b4
 
74
   *            05e1831619db2f10 bb9b6a8fd5c95df2 eb78f303ea0c0cc8
 
75
   *            06#)))
 
76
   */
 
77
  
 
78
  mpz_set_str(pub.n,
 
79
              "013b04440e3eef25" "d51c738d508a7fa8" "b3445180c342af0f"
 
80
              "4cb5a789047300e2" "cfc5c5450974cfc2" "448aeaaa7f43c374"
 
81
              "c9a3b038b181f2d1" "0f1a2327fd2c087b" "a49bf1086969fd2c"
 
82
              "d1df3fd69f81fa4b" "162cc8bbb363fc95" "b7b24b9c53d0c67e"
 
83
              "f52b", 16);
 
84
  
 
85
  mpz_set_str(pub.e, "3f1a012d", 16);
 
86
 
 
87
  if (!rsa_public_key_prepare(&pub))
 
88
    FAIL();
 
89
 
 
90
#if 0  
 
91
  mpz_set_str(key.d,
 
92
              "f9bae89dacca6cca" "c21e0412b4df8355" "6fe7c5322bbae8ad"
 
93
              "3f11494fd12bc076" "d4a7da3050fe109d" "2074db09cc6a93b4"
 
94
              "745479522558379e" "a0ddfa74f86c9e9e" "a22c3b0e93d51447"
 
95
              "0feb38105dd35395" "63b91ee32776f40c" "67b2a175690f7abb"
 
96
              "25", 16);
 
97
#endif
 
98
  
 
99
  mpz_set_str(key.p,
 
100
              "0b73c990eeda0a2a" "2c26416052c85560" "0c5c0f5ce86a8326"
 
101
              "166acea91786237a" "7ff884e66dbfdd3a" "ab9d9801414c1506"
 
102
              "8b", 16);
 
103
  
 
104
  mpz_set_str(key.q,
 
105
              "1b81c19a62802a41" "9c99283331b0badb" "08eb0c25ffce0fbf"
 
106
              "50017850036f32f3" "2132a845b91a5236" "61f7b451d587383f"
 
107
              "e1", 16);
 
108
  
 
109
  mpz_set_str(key.a,
 
110
              "0a912fc93a6cca6b" "3521725a3065b3be" "3c9745e29c93303d"
 
111
              "7d29316c6cafa4a2" "89945f964fcdea59" "1f9d248b0b6734be"
 
112
              "c9", 16);
 
113
  
 
114
  mpz_set_str(key.b,
 
115
              "1658eca933251813" "1eb19c77aba13d73" "e0b8f4ce986d7615"
 
116
              "764c6b0b03c18146" "46b7f332c43e05c5" "351e09006979ca5b"
 
117
              "05", 16);
 
118
  
 
119
  mpz_set_str(key.c,
 
120
              "0114720dace7b27f" "2bf2850c1804869f" "79a0aad0ec02e6b4"
 
121
              "05e1831619db2f10" "bb9b6a8fd5c95df2" "eb78f303ea0c0cc8"
 
122
              "06", 16);
 
123
 
 
124
  if (!rsa_private_key_prepare(&key))
 
125
    FAIL();
 
126
 
 
127
  if (pub.size != key.size)
 
128
    FAIL();
 
129
 
 
130
  /* Test md5 signatures */
 
131
  mpz_set_str(expected,
 
132
              "011b939f6fbacf7f" "7d3217b022d07477" "e582e34d4bbddd4c"
 
133
              "31520647417fc8a6" "18b2e196d799cedd" "d8f5c062fd796b0f"
 
134
              "72ab46db2ac6ec74" "39d856be3f746cc4" "3e0a15429954736a"
 
135
              "60a8b3c6ea93d2cb" "c69085c307d72517" "07d43bf97a3b51eb"
 
136
              "9e89", 16);
 
137
 
 
138
  test_rsa_md5(&pub, &key, expected);
 
139
 
 
140
  /* Test sha1 signature */
 
141
  mpz_set_str(expected,
 
142
              "648c49e0ed045547" "08381d0bcd03b7bd" "b0f80a0e9030525d"
 
143
              "234327a1c96b8660" "f1c01c6f15ae76d0" "4f53a53806b7e4db"
 
144
              "1f789e6e89b538f6" "88fcbd2caa6abef0" "5432d52f3de463a4"
 
145
              "a9e6de94f1b7bb68" "3c07edf0924fc93f" "56e1a0dba8f7491c"
 
146
              "5c", 16);
 
147
 
 
148
  test_rsa_sha1(&pub, &key, expected);
 
149
 
 
150
  rsa_private_key_clear(&key);
 
151
  rsa_public_key_clear(&pub);
 
152
  mpz_clear(expected);
 
153
 
 
154
  SUCCESS();
 
155
  
 
156
#else /* !WITH_PUBLIC_KEY */
 
157
  SKIP();
 
158
#endif /* !WITH_PUBLIC_KEY */
 
159
}