|
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(sha1Test)
|
|
ferencd@0
|
36
|
|
ferencd@0
|
37 VMIME_TEST_LIST_BEGIN
|
|
ferencd@0
|
38 VMIME_TEST(testFIPS180_1)
|
|
ferencd@0
|
39 VMIME_TEST(testFIPS180_2)
|
|
ferencd@0
|
40 VMIME_TEST(testFIPS180_3)
|
|
ferencd@0
|
41 VMIME_TEST(testReset)
|
|
ferencd@0
|
42 VMIME_TEST(testUpdate)
|
|
ferencd@0
|
43 VMIME_TEST_LIST_END
|
|
ferencd@0
|
44
|
|
ferencd@0
|
45
|
|
ferencd@0
|
46 // Test suites from FIPS PUB 180-1
|
|
ferencd@0
|
47 // http://www.itl.nist.gov/fipspubs/fip180-1.htm
|
|
ferencd@0
|
48
|
|
ferencd@0
|
49 void testFIPS180_1()
|
|
ferencd@0
|
50 {
|
|
ferencd@0
|
51 INIT_DIGEST(algo, "sha1");
|
|
ferencd@0
|
52
|
|
ferencd@0
|
53 algo->update("abc");
|
|
ferencd@0
|
54 algo->finalize();
|
|
ferencd@0
|
55
|
|
ferencd@0
|
56 VASSERT_EQ("*", "a9993e364706816aba3e25717850c26c9cd0d89d", algo->getHexDigest());
|
|
ferencd@0
|
57 }
|
|
ferencd@0
|
58
|
|
ferencd@0
|
59 void testFIPS180_2()
|
|
ferencd@0
|
60 {
|
|
ferencd@0
|
61 INIT_DIGEST(algo, "sha1");
|
|
ferencd@0
|
62
|
|
ferencd@0
|
63 algo->update("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq");
|
|
ferencd@0
|
64 algo->finalize();
|
|
ferencd@0
|
65
|
|
ferencd@0
|
66 VASSERT_EQ("*", "84983e441c3bd26ebaae4aa1f95129e5e54670f1", algo->getHexDigest());
|
|
ferencd@0
|
67 }
|
|
ferencd@0
|
68
|
|
ferencd@0
|
69 void testFIPS180_3()
|
|
ferencd@0
|
70 {
|
|
ferencd@0
|
71 INIT_DIGEST(algo, "sha1");
|
|
ferencd@0
|
72
|
|
ferencd@0
|
73 vmime::byte_t* buffer = new vmime::byte_t[1000000];
|
|
ferencd@0
|
74
|
|
ferencd@0
|
75 for (int i = 0 ; i < 1000000 ; ++i)
|
|
ferencd@0
|
76 buffer[i] = 'a';
|
|
ferencd@0
|
77
|
|
ferencd@0
|
78 algo->update(buffer, 1000000);
|
|
ferencd@0
|
79 algo->finalize();
|
|
ferencd@0
|
80
|
|
ferencd@0
|
81 delete [] buffer;
|
|
ferencd@0
|
82
|
|
ferencd@0
|
83 VASSERT_EQ("*", "34aa973cd4c4daa4f61eeb2bdbad27316534016f", algo->getHexDigest());
|
|
ferencd@0
|
84 }
|
|
ferencd@0
|
85
|
|
ferencd@0
|
86 void testReset()
|
|
ferencd@0
|
87 {
|
|
ferencd@0
|
88 INIT_DIGEST(algo, "sha1");
|
|
ferencd@0
|
89
|
|
ferencd@0
|
90 algo->update("ab");
|
|
ferencd@0
|
91 algo->update("c");
|
|
ferencd@0
|
92 algo->finalize();
|
|
ferencd@0
|
93
|
|
ferencd@0
|
94 algo->reset();
|
|
ferencd@0
|
95 algo->finalize();
|
|
ferencd@0
|
96
|
|
ferencd@0
|
97 VASSERT_EQ("*", "da39a3ee5e6b4b0d3255bfef95601890afd80709", algo->getHexDigest()); // empty string
|
|
ferencd@0
|
98 }
|
|
ferencd@0
|
99
|
|
ferencd@0
|
100 void testUpdate()
|
|
ferencd@0
|
101 {
|
|
ferencd@0
|
102 INIT_DIGEST(algo, "sha1");
|
|
ferencd@0
|
103
|
|
ferencd@0
|
104 algo->update("a");
|
|
ferencd@0
|
105 algo->update("");
|
|
ferencd@0
|
106 algo->update("bcdbcdecdefd");
|
|
ferencd@0
|
107 algo->update("efgef");
|
|
ferencd@0
|
108 algo->update("ghfghighijhijkijkljklmklmnlmnomnopnop");
|
|
ferencd@0
|
109 algo->update("");
|
|
ferencd@0
|
110 algo->update("q");
|
|
ferencd@0
|
111 algo->update("");
|
|
ferencd@0
|
112 algo->update("");
|
|
ferencd@0
|
113 algo->finalize();
|
|
ferencd@0
|
114
|
|
ferencd@0
|
115 VASSERT_EQ("*", "84983e441c3bd26ebaae4aa1f95129e5e54670f1", algo->getHexDigest());
|
|
ferencd@0
|
116 }
|
|
ferencd@0
|
117
|
|
ferencd@0
|
118 VMIME_TEST_SUITE_END
|
|
ferencd@0
|
119
|