7#include "gtest/gtest.h"
14 EXPECT_EQ(a.size(), b.size());
15 for (
size_t i = 0; i < a.size(); ++i) {
16 EXPECT_EQ(a[i], b[i]);
30 fData = {1, 2, 3, 4, 5, 6, 7, 8, 9};
42 EXPECT_EQ(vec.
Size(0), 2);
43 EXPECT_EQ(vec[0].
size(), 2);
48 EXPECT_EQ(part.first.size(), vec.
Size(0));
49 EXPECT_EQ(part.second, vec.
Address(0));
51 EXPECT_EQ(vec.
Size(1), 4);
52 EXPECT_EQ(vec[1].
size(), 4);
53 EXPECT_EQ(vec.
Address(1), 0x100);
57 EXPECT_EQ(part.first.size(), vec.
Size(1));
58 EXPECT_EQ(part.second, vec.
Address(1));
60 EXPECT_EQ(vec.
Size(2), 3);
61 EXPECT_EQ(vec[2].
size(), 3);
62 EXPECT_EQ(vec.
Address(2), 0x200);
66 EXPECT_EQ(part.first.size(), vec.
Size(2));
67 EXPECT_EQ(part.second, vec.
Address(2));
86 EXPECT_THROW(
PartitionedVector vec(std::move(fData), fSizes, fAddressesInvalid), std::runtime_error);
91 EXPECT_THROW(
PartitionedVector vec(std::move(fData), fSizesInvalid, fAddresses), std::runtime_error);
98 EXPECT_THROW(vec[3], std::out_of_range);
99 EXPECT_THROW(vec.
Partition(3), std::out_of_range);
100 EXPECT_THROW(vec.
Address(3), std::out_of_range);
101 EXPECT_THROW(vec.
Size(3), std::out_of_range);
static constexpr size_t size()
TEST_F(PartitionedVectorTest, IsDefaultConstructable)
void EXPECT_CONTAINER_EQ(gsl::span< const T > a, std::vector< T > b)
std::vector< size_t > fSizes
std::vector< size_t > fSizesInvalid
std::vector< u32 > fAddresses
void Ensure(const PartitionedVector< i32 > &vec)
std::vector< u32 > fAddressesInvalid
A vector that is partitioned into multiple subvectors.
std::pair< gsl::span< T >, u32 > Partition(size_t i)
Get a pair of the data and the hardware address of partition i.
size_t Size(size_t i) const
Get the size of partition i.
size_t NElements() const
Get the total number of elements in the container across all partitions.
size_t NPartitions() const
Get the number of partitions.
u32 Address(size_t i) const
Get the hardware address of partition i.