annotate 3rdparty/vmime/tests/security/digest/md5Test.cpp @ 0:a4671277546c tip

created the repository for the thymian project
author ferencd
date Tue, 17 Aug 2021 11:19:54 +0200
parents
children
rev   line source
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