annotate 3rdparty/vmime/tests/security/digest/sha1Test.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(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