sha1_unittest.cc 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. // Copyright (C) 2010 Internet Systems Consortium, Inc. ("ISC")
  2. //
  3. // Permission to use, copy, modify, and/or distribute this software for any
  4. // purpose with or without fee is hereby granted, provided that the above
  5. // copyright notice and this permission notice appear in all copies.
  6. //
  7. // THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
  8. // REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  9. // AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
  10. // INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  11. // LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
  12. // OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  13. // PERFORMANCE OF THIS SOFTWARE.
  14. // $Id$
  15. #include <stdint.h>
  16. #include <string>
  17. #include <dns/util/sha1.h>
  18. #include <gtest/gtest.h>
  19. #include <dns/tests/unittest_util.h>
  20. using isc::UnitTestUtil;
  21. using namespace std;
  22. using namespace isc::dns;
  23. namespace {
  24. class Sha1Test : public ::testing::Test {
  25. protected:
  26. Sha1Test() {}
  27. };
  28. // Tests copied from RFC 3174
  29. TEST_F(Sha1Test, Test1) {
  30. SHA1Context sha;
  31. uint8_t digest[SHA1_HASHSIZE];
  32. uint8_t expected[SHA1_HASHSIZE] = {
  33. 0xa9, 0x99, 0x3e, 0x36, 0x47, 0x06, 0x81, 0x6a, 0xba, 0x3e,
  34. 0x25, 0x71, 0x78, 0x50, 0xc2, 0x6c, 0x9c, 0xd0, 0xd8, 0x9d
  35. };
  36. EXPECT_EQ(0, SHA1Reset(&sha));
  37. EXPECT_EQ(0, SHA1Input(&sha, (const uint8_t *) "abc", 3));
  38. EXPECT_EQ(0, SHA1Result(&sha, digest));
  39. for (int i = 0; i < SHA1_HASHSIZE; i++) {
  40. EXPECT_EQ(digest[i], expected[i]);
  41. }
  42. }
  43. TEST_F(Sha1Test, Test2) {
  44. SHA1Context sha;
  45. string test("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq");
  46. uint8_t digest[SHA1_HASHSIZE];
  47. uint8_t expected[SHA1_HASHSIZE] = {
  48. 0x84, 0x98, 0x3e, 0x44, 0x1c, 0x3b, 0xd2, 0x6e, 0xba, 0xae,
  49. 0x4a, 0xa1, 0xf9, 0x51, 0x29, 0xe5, 0xe5, 0x46, 0x70, 0xf1
  50. };
  51. EXPECT_EQ(0, SHA1Reset(&sha));
  52. EXPECT_EQ(0, SHA1Input(&sha, (const uint8_t *) test.c_str(),
  53. test.length()));
  54. EXPECT_EQ(0, SHA1Result(&sha, digest));
  55. for (int i = 0; i < SHA1_HASHSIZE; i++) {
  56. EXPECT_EQ(digest[i], expected[i]);
  57. }
  58. }
  59. TEST_F(Sha1Test, Test3) {
  60. SHA1Context sha;
  61. uint8_t digest[SHA1_HASHSIZE];
  62. uint8_t expected[SHA1_HASHSIZE] = {
  63. 0x34, 0xaa, 0x97, 0x3c, 0xd4, 0xc4, 0xda, 0xa4, 0xf6, 0x1e,
  64. 0xeb, 0x2b, 0xdb, 0xad, 0x27, 0x31, 0x65, 0x34, 0x01, 0x6f
  65. };
  66. EXPECT_EQ(0, SHA1Reset(&sha));
  67. for (int i = 0; i < 1000000; i++) {
  68. EXPECT_EQ(0, SHA1Input(&sha, (const uint8_t *) "a", 1));
  69. }
  70. EXPECT_EQ(0, SHA1Result(&sha, digest));
  71. for (int i = 0; i < SHA1_HASHSIZE; i++) {
  72. EXPECT_EQ(digest[i], expected[i]);
  73. }
  74. }
  75. TEST_F(Sha1Test, Test4) {
  76. SHA1Context sha;
  77. string test("01234567012345670123456701234567"
  78. "01234567012345670123456701234567");
  79. uint8_t digest[SHA1_HASHSIZE];
  80. uint8_t expected[SHA1_HASHSIZE] = {
  81. 0xde, 0xa3, 0x56, 0xa2, 0xcd, 0xdd, 0x90, 0xc7, 0xa7, 0xec,
  82. 0xed, 0xc5, 0xeb, 0xb5, 0x63, 0x93, 0x4f, 0x46, 0x04, 0x52
  83. };
  84. EXPECT_EQ(0, SHA1Reset(&sha));
  85. for (int i = 0; i < 10; i++) {
  86. EXPECT_EQ(0, SHA1Input(&sha, (const uint8_t *) test.c_str(),
  87. test.length()));
  88. }
  89. EXPECT_EQ(0, SHA1Result(&sha, digest));
  90. for (int i = 0; i < SHA1_HASHSIZE; i++) {
  91. EXPECT_EQ(digest[i], expected[i]);
  92. }
  93. }
  94. }