20#include <xrpl/basics/Buffer.h>
21#include <xrpl/beast/unit_test.h>
35 return b.
data() ==
nullptr;
37 return b.
data() !=
nullptr;
44 0xa8, 0xa1, 0x38, 0x45, 0x23, 0xec, 0xe4, 0x23, 0x71, 0x6d, 0x2a,
45 0x18, 0xb4, 0x70, 0xcb, 0xf5, 0xac, 0x2d, 0x89, 0x4d, 0x19, 0x9c,
46 0xf0, 0x2c, 0x15, 0xd1, 0xf9, 0x9b, 0x66, 0xd2, 0x30, 0xd3};
49 BEAST_EXPECT(
sane(b0));
50 BEAST_EXPECT(b0.
empty());
53 BEAST_EXPECT(
sane(b1));
54 BEAST_EXPECT(b1.empty());
56 BEAST_EXPECT(
sane(b1));
57 BEAST_EXPECT(!b1.empty());
58 BEAST_EXPECT(b1.size() == 16);
61 BEAST_EXPECT(
sane(b2));
62 BEAST_EXPECT(!b2.empty());
63 BEAST_EXPECT(b2.size() == b1.size());
66 Buffer b3{data,
sizeof(data)};
67 BEAST_EXPECT(
sane(b3));
68 BEAST_EXPECT(!b3.empty());
69 BEAST_EXPECT(b3.size() ==
sizeof(data));
70 BEAST_EXPECT(
std::memcmp(b3.data(), data, b3.size()) == 0);
73 BEAST_EXPECT(b0 == b0);
74 BEAST_EXPECT(b0 != b1);
75 BEAST_EXPECT(b1 == b1);
76 BEAST_EXPECT(b1 != b2);
77 BEAST_EXPECT(b2 != b3);
81 testcase(
"Copy Construction / Assignment");
84 BEAST_EXPECT(x == b0);
85 BEAST_EXPECT(
sane(x));
87 BEAST_EXPECT(y == b1);
88 BEAST_EXPECT(
sane(y));
90 BEAST_EXPECT(x == b2);
91 BEAST_EXPECT(
sane(x));
94 BEAST_EXPECT(
sane(x));
96 BEAST_EXPECT(y == b3);
97 BEAST_EXPECT(
sane(y));
99 BEAST_EXPECT(x == b0);
100 BEAST_EXPECT(
sane(x));
101#if defined(__clang__)
102#pragma clang diagnostic push
103#pragma clang diagnostic ignored "-Wself-assign-overloaded"
107 BEAST_EXPECT(x == b0);
108 BEAST_EXPECT(
sane(x));
110 BEAST_EXPECT(y == b3);
111 BEAST_EXPECT(
sane(y));
113#if defined(__clang__)
114#pragma clang diagnostic pop
120 testcase(
"Move Construction / Assignment");
129 BEAST_EXPECT(
sane(x));
130 BEAST_EXPECT(x.
empty());
131 BEAST_EXPECT(
sane(y));
132 BEAST_EXPECT(y.empty());
133 BEAST_EXPECT(x == y);
139 BEAST_EXPECT(
sane(x));
140 BEAST_EXPECT(x.empty());
141 BEAST_EXPECT(
sane(y));
142 BEAST_EXPECT(y == b1);
150 BEAST_EXPECT(
sane(x));
151 BEAST_EXPECT(x.
empty());
152 BEAST_EXPECT(
sane(y));
153 BEAST_EXPECT(y.
empty());
161 BEAST_EXPECT(
sane(x));
162 BEAST_EXPECT(x == b1);
163 BEAST_EXPECT(
sane(y));
164 BEAST_EXPECT(y.empty());
172 BEAST_EXPECT(
sane(x));
173 BEAST_EXPECT(x.empty());
174 BEAST_EXPECT(
sane(y));
175 BEAST_EXPECT(y.
empty());
184 BEAST_EXPECT(
sane(x));
185 BEAST_EXPECT(!x.empty());
186 BEAST_EXPECT(
sane(y));
187 BEAST_EXPECT(y.empty());
190 BEAST_EXPECT(
sane(x));
191 BEAST_EXPECT(!x.empty());
192 BEAST_EXPECT(
sane(z));
193 BEAST_EXPECT(z.empty());
198 testcase(
"Slice Conversion / Construction / Assignment");
201 BEAST_EXPECT(
sane(w));
202 BEAST_EXPECT(w == b0);
205 BEAST_EXPECT(
sane(x));
206 BEAST_EXPECT(x == b1);
209 BEAST_EXPECT(
sane(y));
210 BEAST_EXPECT(y == b2);
213 BEAST_EXPECT(
sane(z));
214 BEAST_EXPECT(z == b3);
217 w =
static_cast<Slice>(b0);
218 BEAST_EXPECT(
sane(w));
219 BEAST_EXPECT(w == b0);
222 w =
static_cast<Slice>(b1);
223 BEAST_EXPECT(
sane(w));
224 BEAST_EXPECT(w == b1);
227 x =
static_cast<Slice>(b2);
228 BEAST_EXPECT(
sane(x));
229 BEAST_EXPECT(x == b2);
232 y =
static_cast<Slice>(z);
233 BEAST_EXPECT(
sane(y));
234 BEAST_EXPECT(y == z);
237 z =
static_cast<Slice>(b0);
238 BEAST_EXPECT(
sane(z));
239 BEAST_EXPECT(z == b0);
243 testcase(
"Allocation, Deallocation and Clearing");
251 BEAST_EXPECT(
sane(x));
252 BEAST_EXPECT(x.size() == i);
253 BEAST_EXPECT((x.data() ==
nullptr) == (i == 0));
257 BEAST_EXPECT(
sane(x));
258 BEAST_EXPECT(x.size() == i + 1);
259 BEAST_EXPECT(x.data() !=
nullptr);
263 BEAST_EXPECT(
sane(x));
264 BEAST_EXPECT(x.size() == 0);
265 BEAST_EXPECT(x.data() ==
nullptr);
269 BEAST_EXPECT(
sane(x));
270 BEAST_EXPECT(x.size() == 0);
271 BEAST_EXPECT(x.data() ==
nullptr);
testcase_t testcase
Memberspace for declaring test cases.
Like std::vector<char> but better.
std::size_t size() const noexcept
Returns the number of bytes in the buffer.
bool empty() const noexcept
std::uint8_t const * data() const noexcept
Return a pointer to beginning of the storage.
An immutable linear range of bytes.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
bool sane(Buffer const &b) const
void run() override
Runs the suite.