11#include <boost/test/unit_test.hpp>
18template<
unsigned int N,
typename T>
34 template <
typename A,
typename B>
44 const pretype& const_pre_vector = pre_vector;
47 for (
Size s = 0; s < real_vector.size(); s++) {
51 local_check(&(pre_vector[s]) == &*((pre_vector.
end() + s) - real_vector.size()));
57 for (
const T& v : pre_vector) {
60 for (
const T& v : pre_vector | std::views::reverse) {
63 for (
const T& v : const_pre_vector) {
66 for (
const T& v : const_pre_vector | std::views::reverse) {
74 for (
Size s = 0; s < ss1.size(); s++) {
81 real_vector.resize(s);
89 real_vector.reserve(s);
97 real_vector.insert(real_vector.begin() + position, value);
98 pre_vector.
insert(pre_vector.
begin() + position, value);
103 real_vector.insert(real_vector.begin() + position,
count, value);
110 real_vector.insert(real_vector.begin() + position, first, last);
111 pre_vector.
insert(pre_vector.
begin() + position, first, last);
116 real_vector.erase(real_vector.begin() + position);
117 pre_vector.
erase(pre_vector.
begin() + position);
122 real_vector.erase(real_vector.begin() + first, real_vector.begin() + last);
123 pre_vector.
erase(pre_vector.
begin() + first, pre_vector.
begin() + last);
128 real_vector[pos] = value;
129 pre_vector[pos] = value;
134 real_vector.push_back(value);
140 real_vector.pop_back();
151 real_vector.assign(n, value);
152 pre_vector.
assign(n, value);
156 return real_vector.size();
170 real_vector.swap(real_vector_alt);
171 pre_vector.
swap(pre_vector_alt);
176 real_vector = std::move(real_vector_alt);
177 real_vector_alt.clear();
178 pre_vector = std::move(pre_vector_alt);
179 pre_vector_alt.
clear();
183 real_vector = real_vector_alt;
184 pre_vector = pre_vector_alt;
189 size_t s = real_vector.size() / 2;
190 if (real_vector.capacity() < s + r) {
191 real_vector.reserve(s + r);
193 real_vector.resize(s);
196 real_vector.push_back(v);
198 auto p = pre_vector.
size();
208 BOOST_CHECK_MESSAGE(passed,
"insecure_rand: " + rand_seed.
ToString());
214 rand_cache.
Reseed(rand_seed);
220 for (
int j = 0; j < 64; j++) {
221 prevector_tester<8, int> test;
222 for (
int i = 0; i < 2048; i++) {
230 int new_size = std::max(0, std::min(30, (
int)test.size() + (
int)
InsecureRandRange(5) - 2));
231 test.resize(new_size);
239 test.erase(beg, beg + del);
250 for (
int k = 0;
k < num;
k++) {
258 test.erase(beg, beg + del);
264 test.shrink_to_fit();
266 if (test.size() > 0) {
286 std::vector<int>
values(num);
290 test.resize_uninitialized(
values);
Double ended buffer combining vector and stream-like interfaces.
void Reseed(const uint256 &seed) noexcept
Reseed with explicit seed (only for testing).
std::string ToString() const
void erase(Size position)
void update(Size pos, const T &value)
void local_check_equal(A a, B b)
void insert(Size position, Size count, const T &value)
void erase(Size first, Size last)
void insert(Size position, const T &value)
void assign(Size n, const T &value)
FastRandomContext rand_cache
void insert_range(Size position, I first, I last)
prevector< N, T > pretype
void resize_uninitialized(realtype values)
void push_back(const T &value)
std::vector< T > realtype
Implements a drop-in replacement for std::vector<T> which stores up to N elements directly (without h...
void swap(prevector< N, T, Size, Diff > &other) noexcept
iterator erase(iterator pos)
void reserve(size_type new_capacity)
void resize_uninitialized(size_type new_size)
void resize(size_type new_size)
iterator insert(iterator pos, const T &value)
void assign(size_type n, const T &val)
void push_back(const T &value)
BOOST_AUTO_TEST_SUITE_END()
#define T(expected, seed, data)
BOOST_AUTO_TEST_CASE(PrevectorTestInt)
static const int64_t values[]
A selection of numbers that do not trigger int64_t overflow when added/subtracted.
Testing setup that configures a complete environment.
void SeedRandomForTest(SeedRand seedtype)
Seed the RNG for testing.
static uint64_t InsecureRandRange(uint64_t range)
static uint256 InsecureRand256()
static uint64_t InsecureRandBits(int bits)
static uint32_t InsecureRand32()
static bool InsecureRandBool()