summaryrefslogtreecommitdiff
path: root/test/buildtool/crypto/hash_function.test.cpp
diff options
context:
space:
mode:
authorOliver Reiche <oliver.reiche@huawei.com>2022-06-15 18:37:59 +0200
committerOliver Reiche <oliver.reiche@huawei.com>2022-06-20 15:23:02 +0200
commit391d982f2fbd98a2973f14e0b5969f66c2abd756 (patch)
tree52530f2b8b67bd01a4a01a9704c06e9f7624763b /test/buildtool/crypto/hash_function.test.cpp
parent1ea0b1d9ff98d8c44658046019c94f5952ad5c66 (diff)
downloadjustbuild-391d982f2fbd98a2973f14e0b5969f66c2abd756.tar.gz
Crypto: Add tests for globally used hash functions
Diffstat (limited to 'test/buildtool/crypto/hash_function.test.cpp')
-rw-r--r--test/buildtool/crypto/hash_function.test.cpp46
1 files changed, 46 insertions, 0 deletions
diff --git a/test/buildtool/crypto/hash_function.test.cpp b/test/buildtool/crypto/hash_function.test.cpp
new file mode 100644
index 00000000..b56c82a6
--- /dev/null
+++ b/test/buildtool/crypto/hash_function.test.cpp
@@ -0,0 +1,46 @@
+#include "catch2/catch.hpp"
+#include "src/buildtool/crypto/hash_function.hpp"
+
+TEST_CASE("Hash Function", "[crypto]") {
+ std::string bytes{"test"};
+
+ SECTION("Native") {
+ HashFunction::SetHashType(HashFunction::JustHash::Native);
+
+ // same as: echo -n test | sha1sum
+ CHECK(HashFunction::ComputeHash(bytes).HexString() ==
+ "a94a8fe5ccb19ba61c4c0873d391e987982fbbd3");
+ // same as: echo -n test | git hash-object --stdin
+ CHECK(HashFunction::ComputeBlobHash(bytes).HexString() ==
+ "30d74d258442c7c65512eafab474568dd706c430");
+ // same as: echo -n test | git hash-object -t "tree" --stdin --literally
+ CHECK(HashFunction::ComputeTreeHash(bytes).HexString() ==
+ "5f0ecc1a989593005e80f457446133250fcc43cc");
+
+ auto hasher = HashFunction::Hasher();
+ hasher.Update(bytes);
+ CHECK(std::move(hasher).Finalize()->HexString() == // NOLINT
+ "a94a8fe5ccb19ba61c4c0873d391e987982fbbd3");
+ }
+
+ SECTION("Compatible") {
+ HashFunction::SetHashType(HashFunction::JustHash::Compatible);
+
+ // all same as: echo -n test | sha256sum
+ CHECK(
+ HashFunction::ComputeHash(bytes).HexString() ==
+ "9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08");
+ CHECK(
+ HashFunction::ComputeBlobHash(bytes).HexString() ==
+ "9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08");
+ CHECK(
+ HashFunction::ComputeTreeHash(bytes).HexString() ==
+ "9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08");
+
+ auto hasher = HashFunction::Hasher();
+ hasher.Update(bytes);
+ CHECK(
+ std::move(hasher).Finalize()->HexString() == // NOLINT
+ "9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08");
+ }
+}