Files
blender/tests/gtests/blenlib/BLI_index_range_test.cc
Jacques Lucke d8678e02ec BLI: generally improve C++ data structures
The main focus here was to improve the docs significantly. Furthermore,
I reimplemented `Set`, `Map` and `VectorSet`. They are now (usually)
faster, simpler and more customizable. I also rewrote `Stack` to make
it more efficient by avoiding unnecessary copies.

Thanks to everyone who helped with constructive feedback.

Approved by brecht and sybren.

Differential Revision: https://developer.blender.org/D7931
2020-06-09 10:15:43 +02:00

140 lines
2.7 KiB
C++

#include "BLI_index_range.hh"
#include "BLI_strict_flags.h"
#include "BLI_vector.hh"
#include "testing/testing.h"
using namespace BLI;
TEST(index_range, DefaultConstructor)
{
IndexRange range;
EXPECT_EQ(range.size(), 0);
Vector<uint> vector;
for (uint value : range) {
vector.append(value);
}
EXPECT_EQ(vector.size(), 0);
}
TEST(index_range, SingleElementRange)
{
IndexRange range(4, 1);
EXPECT_EQ(range.size(), 1);
EXPECT_EQ(*range.begin(), 4);
Vector<uint> vector;
for (uint value : range) {
vector.append(value);
}
EXPECT_EQ(vector.size(), 1);
EXPECT_EQ(vector[0], 4);
}
TEST(index_range, MultipleElementRange)
{
IndexRange range(6, 4);
EXPECT_EQ(range.size(), 4);
Vector<uint> vector;
for (uint value : range) {
vector.append(value);
}
EXPECT_EQ(vector.size(), 4);
for (uint i = 0; i < 4; i++) {
EXPECT_EQ(vector[i], i + 6);
}
}
TEST(index_range, SubscriptOperator)
{
IndexRange range(5, 5);
EXPECT_EQ(range[0], 5);
EXPECT_EQ(range[1], 6);
EXPECT_EQ(range[2], 7);
}
TEST(index_range, Before)
{
IndexRange range = IndexRange(5, 5).before(3);
EXPECT_EQ(range[0], 2);
EXPECT_EQ(range[1], 3);
EXPECT_EQ(range[2], 4);
EXPECT_EQ(range.size(), 3);
}
TEST(index_range, After)
{
IndexRange range = IndexRange(5, 5).after(4);
EXPECT_EQ(range[0], 10);
EXPECT_EQ(range[1], 11);
EXPECT_EQ(range[2], 12);
EXPECT_EQ(range[3], 13);
EXPECT_EQ(range.size(), 4);
}
TEST(index_range, Contains)
{
IndexRange range = IndexRange(5, 3);
EXPECT_TRUE(range.contains(5));
EXPECT_TRUE(range.contains(6));
EXPECT_TRUE(range.contains(7));
EXPECT_FALSE(range.contains(4));
EXPECT_FALSE(range.contains(8));
}
TEST(index_range, First)
{
IndexRange range = IndexRange(5, 3);
EXPECT_EQ(range.first(), 5);
}
TEST(index_range, Last)
{
IndexRange range = IndexRange(5, 3);
EXPECT_EQ(range.last(), 7);
}
TEST(index_range, OneAfterEnd)
{
IndexRange range = IndexRange(5, 3);
EXPECT_EQ(range.one_after_last(), 8);
}
TEST(index_range, Start)
{
IndexRange range = IndexRange(6, 2);
EXPECT_EQ(range.start(), 6);
}
TEST(index_range, Slice)
{
IndexRange range = IndexRange(5, 15);
IndexRange slice = range.slice(2, 6);
EXPECT_EQ(slice.size(), 6);
EXPECT_EQ(slice.first(), 7);
EXPECT_EQ(slice.last(), 12);
}
TEST(index_range, SliceRange)
{
IndexRange range = IndexRange(5, 15);
IndexRange slice = range.slice(IndexRange(3, 5));
EXPECT_EQ(slice.size(), 5);
EXPECT_EQ(slice.first(), 8);
EXPECT_EQ(slice.last(), 12);
}
TEST(index_range, AsArrayRef)
{
IndexRange range = IndexRange(4, 6);
ArrayRef<uint> ref = range.as_array_ref();
EXPECT_EQ(ref.size(), 6);
EXPECT_EQ(ref[0], 4);
EXPECT_EQ(ref[1], 5);
EXPECT_EQ(ref[2], 6);
EXPECT_EQ(ref[3], 7);
}