|
ferencd@0
|
1 //
|
|
ferencd@0
|
2 // VMime library (http://www.vmime.org)
|
|
ferencd@0
|
3 // Copyright (C) 2002-2013 Vincent Richard <vincent@vmime.org>
|
|
ferencd@0
|
4 //
|
|
ferencd@0
|
5 // This program is free software; you can redistribute it and/or
|
|
ferencd@0
|
6 // modify it under the terms of the GNU General Public License as
|
|
ferencd@0
|
7 // published by the Free Software Foundation; either version 3 of
|
|
ferencd@0
|
8 // the License, or (at your option) any later version.
|
|
ferencd@0
|
9 //
|
|
ferencd@0
|
10 // This program is distributed in the hope that it will be useful,
|
|
ferencd@0
|
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
ferencd@0
|
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
ferencd@0
|
13 // General Public License for more details.
|
|
ferencd@0
|
14 //
|
|
ferencd@0
|
15 // You should have received a copy of the GNU General Public License along
|
|
ferencd@0
|
16 // with this program; if not, write to the Free Software Foundation, Inc.,
|
|
ferencd@0
|
17 // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
ferencd@0
|
18 //
|
|
ferencd@0
|
19 // Linking this library statically or dynamically with other modules is making
|
|
ferencd@0
|
20 // a combined work based on this library. Thus, the terms and conditions of
|
|
ferencd@0
|
21 // the GNU General Public License cover the whole combination.
|
|
ferencd@0
|
22 //
|
|
ferencd@0
|
23
|
|
ferencd@0
|
24 #include "tests/testUtils.hpp"
|
|
ferencd@0
|
25
|
|
ferencd@0
|
26 #include "vmime/security/digest/messageDigestFactory.hpp"
|
|
ferencd@0
|
27
|
|
ferencd@0
|
28
|
|
ferencd@0
|
29 #define INIT_DIGEST(var, algo) \
|
|
ferencd@0
|
30 vmime::shared_ptr <vmime::security::digest::messageDigest> var = \
|
|
ferencd@0
|
31 vmime::security::digest::messageDigestFactory::getInstance()->create(algo)
|
|
ferencd@0
|
32
|
|
ferencd@0
|
33
|
|
ferencd@0
|
34
|
|
ferencd@0
|
35 VMIME_TEST_SUITE_BEGIN(md5Test)
|
|
ferencd@0
|
36
|
|
ferencd@0
|
37 VMIME_TEST_LIST_BEGIN
|
|
ferencd@0
|
38 VMIME_TEST(testRFC1321_1)
|
|
ferencd@0
|
39 VMIME_TEST(testRFC1321_2)
|
|
ferencd@0
|
40 VMIME_TEST(testRFC1321_3)
|
|
ferencd@0
|
41 VMIME_TEST(testRFC1321_4)
|
|
ferencd@0
|
42 VMIME_TEST(testRFC1321_5)
|
|
ferencd@0
|
43 VMIME_TEST(testRFC1321_6)
|
|
ferencd@0
|
44 VMIME_TEST(testRFC1321_7)
|
|
ferencd@0
|
45 VMIME_TEST(testUpdate1)
|
|
ferencd@0
|
46 VMIME_TEST(testUpdate2)
|
|
ferencd@0
|
47 VMIME_TEST(testUpdate3)
|
|
ferencd@0
|
48 VMIME_TEST(testUpdate4)
|
|
ferencd@0
|
49 VMIME_TEST(testUpdate5)
|
|
ferencd@0
|
50 VMIME_TEST(testUpdate6)
|
|
ferencd@0
|
51 VMIME_TEST(testUpdate7)
|
|
ferencd@0
|
52 VMIME_TEST_LIST_END
|
|
ferencd@0
|
53
|
|
ferencd@0
|
54
|
|
ferencd@0
|
55 // Test suites from RFC #1321
|
|
ferencd@0
|
56
|
|
ferencd@0
|
57 void testRFC1321_1()
|
|
ferencd@0
|
58 {
|
|
ferencd@0
|
59 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
60
|
|
ferencd@0
|
61 algo->update("");
|
|
ferencd@0
|
62 algo->finalize();
|
|
ferencd@0
|
63
|
|
ferencd@0
|
64 VASSERT_EQ("*", "d41d8cd98f00b204e9800998ecf8427e", algo->getHexDigest());
|
|
ferencd@0
|
65 }
|
|
ferencd@0
|
66
|
|
ferencd@0
|
67 void testRFC1321_2()
|
|
ferencd@0
|
68 {
|
|
ferencd@0
|
69 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
70
|
|
ferencd@0
|
71 algo->update("a");
|
|
ferencd@0
|
72 algo->finalize();
|
|
ferencd@0
|
73
|
|
ferencd@0
|
74 VASSERT_EQ("*", "0cc175b9c0f1b6a831c399e269772661", algo->getHexDigest());
|
|
ferencd@0
|
75 }
|
|
ferencd@0
|
76
|
|
ferencd@0
|
77 void testRFC1321_3()
|
|
ferencd@0
|
78 {
|
|
ferencd@0
|
79 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
80
|
|
ferencd@0
|
81 algo->update("abc");
|
|
ferencd@0
|
82 algo->finalize();
|
|
ferencd@0
|
83
|
|
ferencd@0
|
84 VASSERT_EQ("*", "900150983cd24fb0d6963f7d28e17f72", algo->getHexDigest());
|
|
ferencd@0
|
85 }
|
|
ferencd@0
|
86
|
|
ferencd@0
|
87 void testRFC1321_4()
|
|
ferencd@0
|
88 {
|
|
ferencd@0
|
89 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
90
|
|
ferencd@0
|
91 algo->update("message digest");
|
|
ferencd@0
|
92 algo->finalize();
|
|
ferencd@0
|
93
|
|
ferencd@0
|
94 VASSERT_EQ("*", "f96b697d7cb7938d525a2f31aaf161d0", algo->getHexDigest());
|
|
ferencd@0
|
95 }
|
|
ferencd@0
|
96
|
|
ferencd@0
|
97 void testRFC1321_5()
|
|
ferencd@0
|
98 {
|
|
ferencd@0
|
99 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
100
|
|
ferencd@0
|
101 algo->update("abcdefghijklmnopqrstuvwxyz");
|
|
ferencd@0
|
102 algo->finalize();
|
|
ferencd@0
|
103
|
|
ferencd@0
|
104 VASSERT_EQ("*", "c3fcd3d76192e4007dfb496cca67e13b", algo->getHexDigest());
|
|
ferencd@0
|
105 }
|
|
ferencd@0
|
106
|
|
ferencd@0
|
107 void testRFC1321_6()
|
|
ferencd@0
|
108 {
|
|
ferencd@0
|
109 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
110
|
|
ferencd@0
|
111 algo->update("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789");
|
|
ferencd@0
|
112 algo->finalize();
|
|
ferencd@0
|
113
|
|
ferencd@0
|
114 VASSERT_EQ("*", "d174ab98d277d9f5a5611c2c9f419d9f", algo->getHexDigest());
|
|
ferencd@0
|
115 }
|
|
ferencd@0
|
116
|
|
ferencd@0
|
117 void testRFC1321_7()
|
|
ferencd@0
|
118 {
|
|
ferencd@0
|
119 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
120
|
|
ferencd@0
|
121 algo->update("12345678901234567890123456789012345678901234567890123456789012345678901234567890");
|
|
ferencd@0
|
122 algo->finalize();
|
|
ferencd@0
|
123
|
|
ferencd@0
|
124 VASSERT_EQ("*", "57edf4a22be3c955ac49da2e2107b67a", algo->getHexDigest());
|
|
ferencd@0
|
125 }
|
|
ferencd@0
|
126
|
|
ferencd@0
|
127 void testReset()
|
|
ferencd@0
|
128 {
|
|
ferencd@0
|
129 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
130
|
|
ferencd@0
|
131 algo->update("foo");
|
|
ferencd@0
|
132 algo->update("bar");
|
|
ferencd@0
|
133 algo->finalize();
|
|
ferencd@0
|
134
|
|
ferencd@0
|
135 algo->reset();
|
|
ferencd@0
|
136 algo->finalize();
|
|
ferencd@0
|
137
|
|
ferencd@0
|
138 VASSERT_EQ("*", "d41d8cd98f00b204e9800998ecf8427e", algo->getHexDigest()); // empty string
|
|
ferencd@0
|
139 }
|
|
ferencd@0
|
140
|
|
ferencd@0
|
141 void testUpdate1()
|
|
ferencd@0
|
142 {
|
|
ferencd@0
|
143 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
144
|
|
ferencd@0
|
145 algo->update("");
|
|
ferencd@0
|
146 algo->finalize();
|
|
ferencd@0
|
147
|
|
ferencd@0
|
148 VASSERT_EQ("*", "d41d8cd98f00b204e9800998ecf8427e", algo->getHexDigest());
|
|
ferencd@0
|
149 }
|
|
ferencd@0
|
150
|
|
ferencd@0
|
151 void testUpdate2()
|
|
ferencd@0
|
152 {
|
|
ferencd@0
|
153 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
154
|
|
ferencd@0
|
155 algo->update("a");
|
|
ferencd@0
|
156 algo->update("");
|
|
ferencd@0
|
157 algo->finalize();
|
|
ferencd@0
|
158
|
|
ferencd@0
|
159 VASSERT_EQ("2", "0cc175b9c0f1b6a831c399e269772661", algo->getHexDigest());
|
|
ferencd@0
|
160 }
|
|
ferencd@0
|
161
|
|
ferencd@0
|
162 void testUpdate3()
|
|
ferencd@0
|
163 {
|
|
ferencd@0
|
164 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
165
|
|
ferencd@0
|
166 algo->update("ab");
|
|
ferencd@0
|
167 algo->update("c");
|
|
ferencd@0
|
168 algo->finalize();
|
|
ferencd@0
|
169
|
|
ferencd@0
|
170 VASSERT_EQ("3", "900150983cd24fb0d6963f7d28e17f72", algo->getHexDigest());
|
|
ferencd@0
|
171 }
|
|
ferencd@0
|
172
|
|
ferencd@0
|
173 void testUpdate4()
|
|
ferencd@0
|
174 {
|
|
ferencd@0
|
175 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
176
|
|
ferencd@0
|
177 algo->update("");
|
|
ferencd@0
|
178 algo->update("message");
|
|
ferencd@0
|
179 algo->update(" ");
|
|
ferencd@0
|
180 algo->update("digest");
|
|
ferencd@0
|
181 algo->finalize();
|
|
ferencd@0
|
182
|
|
ferencd@0
|
183 VASSERT_EQ("4", "f96b697d7cb7938d525a2f31aaf161d0", algo->getHexDigest());
|
|
ferencd@0
|
184 }
|
|
ferencd@0
|
185
|
|
ferencd@0
|
186 void testUpdate5()
|
|
ferencd@0
|
187 {
|
|
ferencd@0
|
188 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
189
|
|
ferencd@0
|
190 algo->update("abcd");
|
|
ferencd@0
|
191 algo->update("");
|
|
ferencd@0
|
192 algo->update("efghijklmnop");
|
|
ferencd@0
|
193 algo->update("qrstuvwx");
|
|
ferencd@0
|
194 algo->update("yz");
|
|
ferencd@0
|
195 algo->finalize();
|
|
ferencd@0
|
196
|
|
ferencd@0
|
197 VASSERT_EQ("5", "c3fcd3d76192e4007dfb496cca67e13b", algo->getHexDigest());
|
|
ferencd@0
|
198 }
|
|
ferencd@0
|
199
|
|
ferencd@0
|
200 void testUpdate6()
|
|
ferencd@0
|
201 {
|
|
ferencd@0
|
202 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
203
|
|
ferencd@0
|
204 algo->update("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz012");
|
|
ferencd@0
|
205 algo->update("345");
|
|
ferencd@0
|
206 algo->update("6");
|
|
ferencd@0
|
207 algo->update("7");
|
|
ferencd@0
|
208 algo->update("89");
|
|
ferencd@0
|
209 algo->finalize();
|
|
ferencd@0
|
210
|
|
ferencd@0
|
211 VASSERT_EQ("6", "d174ab98d277d9f5a5611c2c9f419d9f", algo->getHexDigest());
|
|
ferencd@0
|
212 }
|
|
ferencd@0
|
213
|
|
ferencd@0
|
214 void testUpdate7()
|
|
ferencd@0
|
215 {
|
|
ferencd@0
|
216 INIT_DIGEST(algo, "md5");
|
|
ferencd@0
|
217
|
|
ferencd@0
|
218 algo->update("12345678901234567890123456789");
|
|
ferencd@0
|
219 algo->update("01234567890123456789012345678901");
|
|
ferencd@0
|
220 algo->update("234567890123456789");
|
|
ferencd@0
|
221 algo->update("");
|
|
ferencd@0
|
222 algo->update("0");
|
|
ferencd@0
|
223 algo->finalize();
|
|
ferencd@0
|
224
|
|
ferencd@0
|
225 VASSERT_EQ("7", "57edf4a22be3c955ac49da2e2107b67a", algo->getHexDigest());
|
|
ferencd@0
|
226 }
|
|
ferencd@0
|
227
|
|
ferencd@0
|
228 VMIME_TEST_SUITE_END
|
|
ferencd@0
|
229
|