forked from google/boringssl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinput_unittest.cc
107 lines (84 loc) · 2.72 KB
/
input_unittest.cc
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
102
103
104
105
106
107
// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "input.h"
#include <gtest/gtest.h>
namespace bssl::der::test {
constexpr uint8_t kInput[] = {'t', 'e', 's', 't'};
const uint8_t kInput2[] = {'t', 'e', 'a', 'l'};
TEST(InputTest, Equals) {
Input test(kInput);
Input test2(kInput);
EXPECT_EQ(test, test2);
uint8_t input_copy[std::size(kInput)] = {0};
memcpy(input_copy, kInput, std::size(kInput));
Input test_copy(input_copy);
EXPECT_EQ(test, test_copy);
Input test_truncated(kInput, std::size(kInput) - 1);
EXPECT_NE(test, test_truncated);
EXPECT_NE(test_truncated, test);
}
TEST(InputTest, LessThan) {
Input test(kInput);
EXPECT_FALSE(test < test);
Input test2(kInput2);
EXPECT_FALSE(test < test2);
EXPECT_TRUE(test2 < test);
Input test_truncated(kInput, std::size(kInput) - 1);
EXPECT_FALSE(test < test_truncated);
EXPECT_TRUE(test_truncated < test);
}
TEST(InputTest, AsString) {
Input input(kInput);
std::string expected_string(reinterpret_cast<const char *>(kInput),
std::size(kInput));
EXPECT_EQ(expected_string, input.AsString());
}
TEST(InputTest, StaticArray) {
Input input(kInput);
EXPECT_EQ(std::size(kInput), input.Length());
Input input2(kInput);
EXPECT_EQ(input, input2);
}
TEST(InputTest, ConstExpr) {
constexpr Input default_input;
static_assert(default_input.Length() == 0);
static_assert(default_input.UnsafeData() == nullptr);
constexpr Input const_array_input(kInput);
static_assert(const_array_input.Length() == 4);
static_assert(const_array_input.UnsafeData() == kInput);
static_assert(default_input < const_array_input);
constexpr Input ptr_len_input(kInput, 2);
static_assert(ptr_len_input.Length() == 2);
static_assert(ptr_len_input.UnsafeData() == kInput);
static_assert(ptr_len_input < const_array_input);
Input runtime_input(kInput2, 2);
EXPECT_EQ(runtime_input, ptr_len_input);
}
TEST(ByteReaderTest, NoReadPastEnd) {
ByteReader reader(Input(nullptr, 0));
uint8_t data;
EXPECT_FALSE(reader.ReadByte(&data));
}
TEST(ByteReaderTest, ReadToEnd) {
uint8_t out;
ByteReader reader((Input(kInput)));
for (uint8_t input : kInput) {
ASSERT_TRUE(reader.ReadByte(&out));
ASSERT_EQ(input, out);
}
EXPECT_FALSE(reader.ReadByte(&out));
}
TEST(ByteReaderTest, PartialReadFails) {
Input out;
ByteReader reader((Input(kInput)));
EXPECT_FALSE(reader.ReadBytes(5, &out));
}
TEST(ByteReaderTest, HasMore) {
Input out;
ByteReader reader((Input(kInput)));
ASSERT_TRUE(reader.HasMore());
ASSERT_TRUE(reader.ReadBytes(std::size(kInput), &out));
ASSERT_FALSE(reader.HasMore());
}
} // namespace bssl::der::test