1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
#include "libutil/hash.hh"
#include <gmock/gmock.h>
#include <gtest/gtest.h>
class HashTest : public ::testing::Test {};
using testing::EndsWith;
using testing::HasSubstr;
namespace nix {
TEST(HashTest, SHA256) {
auto hash = hashString(HashType::htSHA256, "foo");
ASSERT_EQ(hash.base64Len(), 44);
ASSERT_EQ(hash.base32Len(), 52);
ASSERT_EQ(hash.base16Len(), 64);
ASSERT_EQ(hash.to_string(Base16),
"sha256:"
"2c26b46b68ffc68ff99b453c1d30413413422d706483bfa0f98a5e886266e7ae");
ASSERT_EQ(hash.to_string(Base32),
"sha256:1bp7cri8hplaz6hbz0v4f0nl44rl84q1sg25kgwqzipzd1mv89ic");
ASSERT_EQ(hash.to_string(Base64),
"sha256:LCa0a2j/xo/5m0U8HTBBNBNCLXBkg7+g+YpeiGJm564=");
}
TEST(HashTest, SHA256Decode) {
auto hash = hashString(HashType::htSHA256, "foo");
std::unique_ptr<Hash> base16 = std::make_unique<Hash>(
"sha256:"
"2c26b46b68ffc68ff99b453c1d30413413422d706483bfa0f98a5e886266e7ae",
HashType::htSHA256);
std::unique_ptr<Hash> base32 = std::make_unique<Hash>(
"sha256:1bp7cri8hplaz6hbz0v4f0nl44rl84q1sg25kgwqzipzd1mv89ic",
HashType::htSHA256);
std::unique_ptr<Hash> base64 = std::make_unique<Hash>(
"sha256:LCa0a2j/xo/5m0U8HTBBNBNCLXBkg7+g+YpeiGJm564=",
HashType::htSHA256);
ASSERT_EQ(hash, *base16);
ASSERT_EQ(hash, *base32);
ASSERT_EQ(hash, *base64);
}
TEST(HashTest, SHA256DecodeFail) {
EXPECT_THAT(
Hash::deserialize("sha256:LCa0a2j/xo/5m0U8HTBBNBNCLXBkg7+g+YpeiGJm56==",
HashType::htSHA256)
.status()
.message(),
HasSubstr("wrong length"));
EXPECT_THAT(
Hash::deserialize("sha256:LCa0a2j/xo/5m0U8HTBBNBNCLXBkg7+g+YpeiGJm56,=",
HashType::htSHA256)
.status()
.message(),
HasSubstr("invalid base-64"));
EXPECT_THAT(Hash::deserialize(
"sha256:1bp7cri8hplaz6hbz0v4f0nl44rl84q1sg25kgwqzipzd1mv89i",
HashType::htSHA256)
.status()
.message(),
HasSubstr("wrong length"));
absl::StatusOr<Hash> badB32Char = Hash::deserialize(
"sha256:1bp7cri8hplaz6hbz0v4f0nl44rl84q1sg25kgwqzipzd1mv89i,",
HashType::htSHA256);
EXPECT_THAT(badB32Char.status().message(), HasSubstr("invalid base-32"));
EXPECT_THAT(badB32Char.status().message(), EndsWith(","));
EXPECT_THAT(
Hash::deserialize(
"sha256:"
"2c26b46b68ffc68ff99b453c1d30413413422d706483bfa0f98a5e886266e7 ",
HashType::htSHA256)
.status()
.message(),
HasSubstr("invalid base-16"));
}
TEST(HashSink, SHA256) {
HashSink sink(htSHA256);
sink.write(reinterpret_cast<const unsigned char*>("fo"), 2);
HashResult partial = sink.currentHash();
EXPECT_EQ(partial.first.to_string(Base16),
"sha256:"
"9c3aee7110b787f0fb5f81633a36392bd277ea945d44c874a9a23601aefe20cf");
EXPECT_EQ(partial.second, 2);
sink.write(reinterpret_cast<const unsigned char*>("o"), 1);
HashResult end = sink.finish();
EXPECT_EQ(end.first.to_string(Base16),
"sha256:"
"2c26b46b68ffc68ff99b453c1d30413413422d706483bfa0f98a5e886266e7ae");
EXPECT_EQ(end.second, 3);
}
} // namespace nix
|