CbmRoot
Loading...
Searching...
No Matches
_GTestPartitionedVector.cxx
Go to the documentation of this file.
1/* Copyright (C) 2023 FIAS Frankfurt Institute for Advanced Studies, Frankfurt / Main
2 SPDX-License-Identifier: GPL-3.0-only
3 Authors: Felix Weiglhofer [committer] */
4
5#include "PODVector.h"
6#include "PartitionedVector.h"
7#include "gtest/gtest.h"
8
9using namespace cbm::algo;
10
11template<typename T>
12void EXPECT_CONTAINER_EQ(gsl::span<const T> a, std::vector<T> b)
13{
14 EXPECT_EQ(a.size(), b.size());
15 for (size_t i = 0; i < a.size(); ++i) {
16 EXPECT_EQ(a[i], b[i]);
17 }
18}
19
20class PartitionedVectorTest : public ::testing::Test {
21 protected:
22 std::vector<i32> fData;
23 std::vector<size_t> fSizes;
24 std::vector<size_t> fSizesInvalid;
25 std::vector<u32> fAddresses;
26 std::vector<u32> fAddressesInvalid;
27
28 void SetUp() override
29 {
30 fData = {1, 2, 3, 4, 5, 6, 7, 8, 9};
31 fSizes = {2, 4, 3};
32 fSizesInvalid = {2, 4, 4};
33 fAddresses = {0x0, 0x100, 0x200};
34 fAddressesInvalid = {0x0, 0x100};
35 }
36
38 {
39 EXPECT_EQ(vec.NElements(), 9);
40 EXPECT_EQ(vec.NPartitions(), 3);
41
42 EXPECT_EQ(vec.Size(0), 2);
43 EXPECT_EQ(vec[0].size(), 2);
44 EXPECT_EQ(vec.Address(0), 0x0);
45 EXPECT_CONTAINER_EQ(vec[0], {1, 2});
46
47 auto part = vec.Partition(0);
48 EXPECT_EQ(part.first.size(), vec.Size(0));
49 EXPECT_EQ(part.second, vec.Address(0));
50
51 EXPECT_EQ(vec.Size(1), 4);
52 EXPECT_EQ(vec[1].size(), 4);
53 EXPECT_EQ(vec.Address(1), 0x100);
54 EXPECT_CONTAINER_EQ(vec[1], {3, 4, 5, 6});
55
56 part = vec.Partition(1);
57 EXPECT_EQ(part.first.size(), vec.Size(1));
58 EXPECT_EQ(part.second, vec.Address(1));
59
60 EXPECT_EQ(vec.Size(2), 3);
61 EXPECT_EQ(vec[2].size(), 3);
62 EXPECT_EQ(vec.Address(2), 0x200);
63 EXPECT_CONTAINER_EQ(vec[2], {7, 8, 9});
64
65 part = vec.Partition(2);
66 EXPECT_EQ(part.first.size(), vec.Size(2));
67 EXPECT_EQ(part.second, vec.Address(2));
68 }
69};
70
71TEST_F(PartitionedVectorTest, IsDefaultConstructable)
72{
74 EXPECT_EQ(vec.NElements(), 0);
75 EXPECT_EQ(vec.NPartitions(), 0);
76}
77
78TEST_F(PartitionedVectorTest, CanCreateWithPartitions)
79{
80 PartitionedVector vec(std::move(fData), fSizes, fAddresses);
81 Ensure(vec);
82}
83
84TEST_F(PartitionedVectorTest, ThrowsOnNumAddressesMismatchesNumPartions)
85{
86 EXPECT_THROW(PartitionedVector vec(std::move(fData), fSizes, fAddressesInvalid), std::runtime_error);
87}
88
89TEST_F(PartitionedVectorTest, ThrowsOnSizesMismatchesDataSize)
90{
91 EXPECT_THROW(PartitionedVector vec(std::move(fData), fSizesInvalid, fAddresses), std::runtime_error);
92}
93
94TEST_F(PartitionedVectorTest, ThrowsOnOutOfBounds)
95{
96 PartitionedVector vec(std::move(fData), fSizes, fAddresses);
97
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);
102}
103
104TEST_F(PartitionedVectorTest, IsCopyConstructable)
105{
106 PartitionedVector vec(std::move(fData), fSizes, fAddresses);
107
108 PartitionedVector vecCopy(vec);
109 Ensure(vecCopy);
110}
static constexpr size_t size()
Definition KfSimdPseudo.h:2
TEST_F(PartitionedVectorTest, IsDefaultConstructable)
void EXPECT_CONTAINER_EQ(gsl::span< const T > a, std::vector< T > b)
std::vector< size_t > fSizesInvalid
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.