MessageDigestTest.cc 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. #include "MessageDigest.h"
  2. #include <cppunit/extensions/HelperMacros.h>
  3. #include "util.h"
  4. namespace aria2 {
  5. class MessageDigestTest:public CppUnit::TestFixture {
  6. CPPUNIT_TEST_SUITE(MessageDigestTest);
  7. CPPUNIT_TEST(testDigest);
  8. CPPUNIT_TEST(testSupports);
  9. CPPUNIT_TEST(testGetDigestLength);
  10. CPPUNIT_TEST(testIsStronger);
  11. CPPUNIT_TEST(testIsValidHash);
  12. CPPUNIT_TEST(testGetCanonicalHashType);
  13. CPPUNIT_TEST_SUITE_END();
  14. std::unique_ptr<MessageDigest> sha1_;
  15. std::unique_ptr<MessageDigest> md5_;
  16. public:
  17. void setUp()
  18. {
  19. md5_ = MessageDigest::create("md5");
  20. sha1_ = MessageDigest::sha1();
  21. }
  22. void testDigest();
  23. void testSupports();
  24. void testGetDigestLength();
  25. void testIsStronger();
  26. void testIsValidHash();
  27. void testGetCanonicalHashType();
  28. };
  29. CPPUNIT_TEST_SUITE_REGISTRATION( MessageDigestTest );
  30. void MessageDigestTest::testDigest()
  31. {
  32. md5_->update("aria2", 5);
  33. CPPUNIT_ASSERT_EQUAL(std::string("2c90cadbef42945f0dcff2b959977ff8"),
  34. util::toHex(md5_->digest()));
  35. md5_->reset();
  36. md5_->update("abc", 3);
  37. CPPUNIT_ASSERT_EQUAL(std::string("900150983cd24fb0d6963f7d28e17f72"),
  38. util::toHex(md5_->digest()));
  39. sha1_->update("aria2", 5);
  40. CPPUNIT_ASSERT_EQUAL(std::string("f36003f22b462ffa184390533c500d8989e9f681"),
  41. util::toHex(sha1_->digest()));
  42. sha1_->reset();
  43. sha1_->update("abc", 3);
  44. CPPUNIT_ASSERT_EQUAL(std::string("a9993e364706816aba3e25717850c26c9cd0d89d"),
  45. util::toHex(sha1_->digest()));
  46. }
  47. void MessageDigestTest::testSupports()
  48. {
  49. CPPUNIT_ASSERT(MessageDigest::supports("md5"));
  50. CPPUNIT_ASSERT(MessageDigest::supports("sha-1"));
  51. // Fails because sha1 is not valid name.
  52. CPPUNIT_ASSERT(!MessageDigest::supports("sha1"));
  53. }
  54. void MessageDigestTest::testGetDigestLength()
  55. {
  56. CPPUNIT_ASSERT_EQUAL((size_t)16, MessageDigest::getDigestLength("md5"));
  57. CPPUNIT_ASSERT_EQUAL((size_t)20, MessageDigest::getDigestLength("sha-1"));
  58. CPPUNIT_ASSERT_EQUAL((size_t)20, sha1_->getDigestLength());
  59. }
  60. void MessageDigestTest::testIsStronger()
  61. {
  62. CPPUNIT_ASSERT(MessageDigest::isStronger("sha-1", "md5"));
  63. CPPUNIT_ASSERT(!MessageDigest::isStronger("md5", "sha-1"));
  64. CPPUNIT_ASSERT(!MessageDigest::isStronger("unknown", "sha-1"));
  65. CPPUNIT_ASSERT(!MessageDigest::isStronger("sha-1", "unknown"));
  66. }
  67. void MessageDigestTest::testIsValidHash()
  68. {
  69. CPPUNIT_ASSERT(MessageDigest::isValidHash
  70. ("sha-1", "f36003f22b462ffa184390533c500d8989e9f681"));
  71. CPPUNIT_ASSERT(!MessageDigest::isValidHash
  72. ("sha-1", "f36003f22b462ffa184390533c500d89"));
  73. }
  74. void MessageDigestTest::testGetCanonicalHashType()
  75. {
  76. CPPUNIT_ASSERT_EQUAL(std::string("sha-1"),
  77. MessageDigest::getCanonicalHashType("sha1"));
  78. CPPUNIT_ASSERT_EQUAL(std::string("sha-256"),
  79. MessageDigest::getCanonicalHashType("sha256"));
  80. CPPUNIT_ASSERT_EQUAL(std::string("unknown"),
  81. MessageDigest::getCanonicalHashType("unknown"));
  82. }
  83. } // namespace aria2