// Copyright (c) 2011 The LevelDB Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. See the AUTHORS file for names of contributors. #include "port/port.h" #include "util/testharness.h" namespace leveldb { namespace port { class SHA1 { }; static std::string TestSHA1(const char* data, size_t len) { char hash_val[20]; SHA1_Hash(data, len, hash_val); char buf[41]; for (int i = 0; i < 20; i++) { snprintf(buf + i * 2, 41 - i * 2, "%02x", static_cast(static_cast( hash_val[i]))); } return std::string(buf, 40); } TEST(SHA1, Simple) { ASSERT_EQ("da39a3ee5e6b4b0d3255bfef95601890afd80709", TestSHA1("", 0)); ASSERT_EQ("aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d", TestSHA1("hello", 5)); std::string x(10000, 'x'); ASSERT_EQ("f8c5cde791c5056cf515881e701c8a9ecb439a75", TestSHA1(x.data(), x.size())); } TEST(SHA1, Benchmark) { std::string data(1048576 * 100, 'x'); double start = Env::Default()->NowMicros() * 1e-6; static const int kIters = 10; uint32_t sha1 = 0; for (int i = 0; i < kIters; i++) { char hash_val[20]; SHA1_Hash(data.data(), data.size(), hash_val); sha1 |= hash_val[0]; } double finish = Env::Default()->NowMicros() * 1e-6; double mb = (static_cast(data.size()) * kIters) / 1048576.0; fprintf(stderr, "SHA1 %0.0f MB: %.3f secs; %.1f MB/s, dummy=0x%02x\n", mb, (finish - start), mb / (finish - start), sha1); } } } int main(int argc, char** argv) { return leveldb::test::RunAllTests(); }