1 | // |
---|---|
2 | // SHA2EngineTest.cpp |
3 | // |
4 | // Code of the SHA2EngineTest class. |
5 | // |
6 | // test vectors from FIPS 180-1 |
7 | // |
8 | // Copyright (c) 2017, Applied Informatics Software Engineering GmbH |
9 | // and Contributors. |
10 | // |
11 | // SPDX-License-Identifier: BSL-1.0 |
12 | // |
13 | |
14 | #include "SHA2EngineTest.h" |
15 | #include "Poco/CppUnit/TestCaller.h" |
16 | #include "Poco/CppUnit/TestSuite.h" |
17 | #include "Poco/SHA2Engine.h" |
18 | |
19 | using Poco::SHA2Engine; |
20 | using Poco::DigestEngine; |
21 | |
22 | SHA2EngineTest::SHA2EngineTest(const std::string& rName): CppUnit::TestCase(rName) |
23 | { |
24 | } |
25 | |
26 | SHA2EngineTest::~SHA2EngineTest() |
27 | { |
28 | } |
29 | |
30 | void SHA2EngineTest::testSHA224() |
31 | { |
32 | SHA2Engine engine(SHA2Engine::SHA_224); |
33 | |
34 | engine.update("abc"); |
35 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "23097d223405d8228642a477bda255b32aadbce4bda0b3f7e36c9da7"); |
36 | |
37 | engine.update("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"); |
38 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "75388b16512776cc5dba5da1fd890150b0c6455cb4f58b1952522525"); |
39 | |
40 | engine.update("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu"); |
41 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "c97ca9a559850ce97a04a96def6d99a9e0e0e2ab14e6b8df265fc0b3"); |
42 | |
43 | for (int i = 0; i < 1000000; ++i) |
44 | engine.update('a'); |
45 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "20794655980c91d8bbb4c1ea97618a4bf03f42581948b2ee4ee7ad67"); |
46 | } |
47 | |
48 | void SHA2EngineTest::testSHA256() |
49 | { |
50 | SHA2Engine engine(SHA2Engine::SHA_256); |
51 | |
52 | engine.update("abc"); |
53 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad"); |
54 | |
55 | engine.update("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"); |
56 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "248d6a61d20638b8e5c026930c3e6039a33ce45964ff2167f6ecedd419db06c1"); |
57 | |
58 | engine.update("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu"); |
59 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "cf5b16a778af8380036ce59e7b0492370b249b11e8f07a51afac45037afee9d1"); |
60 | |
61 | for (int i = 0; i < 1000000; ++i) |
62 | engine.update('a'); |
63 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "cdc76e5c9914fb9281a1c7e284d73e67f1809a48a497200e046d39ccc7112cd0"); |
64 | } |
65 | |
66 | void SHA2EngineTest::testSHA384() |
67 | { |
68 | SHA2Engine engine(SHA2Engine::SHA_384); |
69 | |
70 | engine.update("abc"); |
71 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "cb00753f45a35e8bb5a03d699ac65007272c32ab0eded1631a8b605a43ff5bed8086072ba1e7cc2358baeca134c825a7"); |
72 | |
73 | engine.update("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"); |
74 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "3391fdddfc8dc7393707a65b1b4709397cf8b1d162af05abfe8f450de5f36bc6b0455a8520bc4e6f5fe95b1fe3c8452b"); |
75 | |
76 | engine.update("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu"); |
77 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "09330c33f71147e83d192fc782cd1b4753111b173b3b05d22fa08086e3b0f712fcc7c71a557e2db966c3e9fa91746039"); |
78 | |
79 | for (int i = 0; i < 1000000; ++i) |
80 | engine.update('a'); |
81 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "9d0e1809716474cb086e834e310a4a1ced149e9c00f248527972cec5704c2a5b07b8b3dc38ecc4ebae97ddd87f3d8985"); |
82 | } |
83 | |
84 | void SHA2EngineTest::testSHA512() |
85 | { |
86 | SHA2Engine engine(SHA2Engine::SHA_512); |
87 | |
88 | engine.update("abc"); |
89 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "ddaf35a193617abacc417349ae20413112e6fa4e89a97ea20a9eeee64b55d39a2192992a274fc1a836ba3c23a3feebbd454d4423643ce80e2a9ac94fa54ca49f"); |
90 | |
91 | engine.update("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"); |
92 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "204a8fc6dda82f0a0ced7beb8e08a41657c16ef468b228a8279be331a703c33596fd15c13b1b07f9aa1d3bea57789ca031ad85c7a71dd70354ec631238ca3445"); |
93 | |
94 | engine.update("abcdefghbcdefghicdefghijdefghijkefghijklfghijklmghijklmnhijklmnoijklmnopjklmnopqklmnopqrlmnopqrsmnopqrstnopqrstu"); |
95 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "8e959b75dae313da8cf4f72814fc143f8f7779c6eb9f7fa17299aeadb6889018501d289e4900f7e4331b99dec4b5433ac7d329eeb6dd26545e96e55b874be909"); |
96 | |
97 | for (int i = 0; i < 1000000; ++i) |
98 | engine.update('a'); |
99 | assertTrue (DigestEngine::digestToHex(engine.digest()) == "e718483d0ce769644e2e42c7bc15b4638e1f98b13b2044285632a803afa973ebde0ff244877ea60a4cb0432ce577c31beb009c5c2c49aa2e4eadb217ad8cc09b"); |
100 | } |
101 | |
102 | void SHA2EngineTest::setUp() |
103 | { |
104 | } |
105 | |
106 | void SHA2EngineTest::tearDown() |
107 | { |
108 | } |
109 | |
110 | CppUnit::Test* SHA2EngineTest::suite() |
111 | { |
112 | CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("SHA2EngineTest"); |
113 | |
114 | CppUnit_addTest(pSuite, SHA2EngineTest, testSHA224); |
115 | CppUnit_addTest(pSuite, SHA2EngineTest, testSHA256); |
116 | CppUnit_addTest(pSuite, SHA2EngineTest, testSHA384); |
117 | CppUnit_addTest(pSuite, SHA2EngineTest, testSHA512); |
118 | |
119 | return pSuite; |
120 | } |
121 |