2020-07-08 15:01:33 +02:00
|
|
|
/* Apache License, Version 2.0 */
|
|
|
|
|
2020-04-21 17:31:56 +02:00
|
|
|
#include "BLI_array.hh"
|
2020-06-09 10:10:56 +02:00
|
|
|
#include "BLI_strict_flags.h"
|
2020-03-19 09:33:03 +01:00
|
|
|
#include "testing/testing.h"
|
2019-09-12 14:23:21 +02:00
|
|
|
|
2020-07-23 15:23:55 +02:00
|
|
|
namespace blender::tests {
|
2019-09-12 14:23:21 +02:00
|
|
|
|
|
|
|
TEST(array, DefaultConstructor)
|
|
|
|
{
|
|
|
|
Array<int> array;
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(array.size(), 0);
|
2020-06-09 10:10:56 +02:00
|
|
|
EXPECT_TRUE(array.is_empty());
|
2019-09-12 14:23:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(array, SizeConstructor)
|
|
|
|
{
|
|
|
|
Array<int> array(5);
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(array.size(), 5);
|
2020-06-09 10:10:56 +02:00
|
|
|
EXPECT_FALSE(array.is_empty());
|
2019-09-12 14:23:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(array, FillConstructor)
|
|
|
|
{
|
|
|
|
Array<int> array(5, 8);
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(array.size(), 5);
|
2019-09-12 14:23:21 +02:00
|
|
|
EXPECT_EQ(array[0], 8);
|
|
|
|
EXPECT_EQ(array[1], 8);
|
|
|
|
EXPECT_EQ(array[2], 8);
|
|
|
|
EXPECT_EQ(array[3], 8);
|
|
|
|
EXPECT_EQ(array[4], 8);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(array, InitializerListConstructor)
|
|
|
|
{
|
|
|
|
Array<int> array = {4, 5, 6, 7};
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(array.size(), 4);
|
2019-09-12 14:23:21 +02:00
|
|
|
EXPECT_EQ(array[0], 4);
|
|
|
|
EXPECT_EQ(array[1], 5);
|
|
|
|
EXPECT_EQ(array[2], 6);
|
|
|
|
EXPECT_EQ(array[3], 7);
|
|
|
|
}
|
|
|
|
|
2020-06-09 11:58:47 +02:00
|
|
|
TEST(array, SpanConstructor)
|
2019-09-12 14:23:21 +02:00
|
|
|
{
|
|
|
|
int stackarray[4] = {6, 7, 8, 9};
|
2020-06-09 11:58:47 +02:00
|
|
|
Span<int> span(stackarray, ARRAY_SIZE(stackarray));
|
|
|
|
Array<int> array(span);
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(array.size(), 4);
|
2019-09-12 14:23:21 +02:00
|
|
|
EXPECT_EQ(array[0], 6);
|
|
|
|
EXPECT_EQ(array[1], 7);
|
|
|
|
EXPECT_EQ(array[2], 8);
|
|
|
|
EXPECT_EQ(array[3], 9);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(array, CopyConstructor)
|
|
|
|
{
|
|
|
|
Array<int> array = {5, 6, 7, 8};
|
|
|
|
Array<int> new_array(array);
|
|
|
|
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(array.size(), 4);
|
|
|
|
EXPECT_EQ(new_array.size(), 4);
|
2020-06-09 10:10:56 +02:00
|
|
|
EXPECT_NE(array.data(), new_array.data());
|
2019-09-12 14:23:21 +02:00
|
|
|
EXPECT_EQ(new_array[0], 5);
|
|
|
|
EXPECT_EQ(new_array[1], 6);
|
|
|
|
EXPECT_EQ(new_array[2], 7);
|
|
|
|
EXPECT_EQ(new_array[3], 8);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(array, MoveConstructor)
|
|
|
|
{
|
|
|
|
Array<int> array = {5, 6, 7, 8};
|
|
|
|
Array<int> new_array(std::move(array));
|
|
|
|
|
2020-07-23 15:23:55 +02:00
|
|
|
EXPECT_EQ(array.size(), 0); /* NOLINT: bugprone-use-after-move */
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(new_array.size(), 4);
|
2019-09-12 14:23:21 +02:00
|
|
|
EXPECT_EQ(new_array[0], 5);
|
|
|
|
EXPECT_EQ(new_array[1], 6);
|
|
|
|
EXPECT_EQ(new_array[2], 7);
|
|
|
|
EXPECT_EQ(new_array[3], 8);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(array, CopyAssignment)
|
|
|
|
{
|
|
|
|
Array<int> array = {1, 2, 3};
|
|
|
|
Array<int> new_array = {4};
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(new_array.size(), 1);
|
2019-09-12 14:23:21 +02:00
|
|
|
new_array = array;
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(new_array.size(), 3);
|
|
|
|
EXPECT_EQ(array.size(), 3);
|
2020-06-09 10:10:56 +02:00
|
|
|
EXPECT_NE(array.data(), new_array.data());
|
2019-09-12 14:23:21 +02:00
|
|
|
EXPECT_EQ(new_array[0], 1);
|
|
|
|
EXPECT_EQ(new_array[1], 2);
|
|
|
|
EXPECT_EQ(new_array[2], 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(array, MoveAssignment)
|
|
|
|
{
|
|
|
|
Array<int> array = {1, 2, 3};
|
|
|
|
Array<int> new_array = {4};
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(new_array.size(), 1);
|
2019-09-12 14:23:21 +02:00
|
|
|
new_array = std::move(array);
|
2020-07-20 12:16:20 +02:00
|
|
|
EXPECT_EQ(new_array.size(), 3);
|
2020-07-23 15:23:55 +02:00
|
|
|
EXPECT_EQ(array.size(), 0); /* NOLINT: bugprone-use-after-move */
|
2019-09-12 14:23:21 +02:00
|
|
|
EXPECT_EQ(new_array[0], 1);
|
|
|
|
EXPECT_EQ(new_array[1], 2);
|
|
|
|
EXPECT_EQ(new_array[2], 3);
|
|
|
|
}
|
2020-06-09 10:10:56 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests that the trivially constructible types are not zero-initialized. We do not want that for
|
|
|
|
* performance reasons.
|
|
|
|
*/
|
|
|
|
TEST(array, TrivialTypeSizeConstructor)
|
|
|
|
{
|
|
|
|
Array<char, 1> *array = new Array<char, 1>(1);
|
|
|
|
char *ptr = &(*array)[0];
|
|
|
|
array->~Array();
|
|
|
|
|
|
|
|
const char magic = 42;
|
|
|
|
*ptr = magic;
|
|
|
|
EXPECT_EQ(*ptr, magic);
|
|
|
|
|
|
|
|
new (array) Array<char, 1>(1);
|
|
|
|
EXPECT_EQ((*array)[0], magic);
|
|
|
|
EXPECT_EQ(*ptr, magic);
|
|
|
|
delete array;
|
|
|
|
}
|
2020-06-30 15:58:14 +02:00
|
|
|
|
|
|
|
struct ConstructibleType {
|
|
|
|
char value;
|
|
|
|
|
|
|
|
ConstructibleType()
|
|
|
|
{
|
|
|
|
value = 42;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST(array, NoInitializationSizeConstructor)
|
|
|
|
{
|
|
|
|
using MyArray = Array<ConstructibleType>;
|
|
|
|
|
2020-07-06 10:56:26 +02:00
|
|
|
TypedBuffer<MyArray> buffer;
|
2020-07-23 15:23:55 +02:00
|
|
|
memset((void *)&buffer, 100, sizeof(MyArray));
|
2020-06-30 15:58:14 +02:00
|
|
|
|
|
|
|
/* Doing this to avoid some compiler optimization. */
|
2020-07-20 12:16:20 +02:00
|
|
|
for (int64_t i : IndexRange(sizeof(MyArray))) {
|
2020-07-06 10:56:26 +02:00
|
|
|
EXPECT_EQ(((char *)buffer.ptr())[i], 100);
|
2020-06-30 15:58:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
{
|
2020-07-06 10:56:26 +02:00
|
|
|
MyArray &array = *new (buffer) MyArray(1, NoInitialization());
|
2020-06-30 15:58:14 +02:00
|
|
|
EXPECT_EQ(array[0].value, 100);
|
|
|
|
array.clear_without_destruct();
|
|
|
|
array.~Array();
|
|
|
|
}
|
|
|
|
{
|
2020-07-06 10:56:26 +02:00
|
|
|
MyArray &array = *new (buffer) MyArray(1);
|
2020-06-30 15:58:14 +02:00
|
|
|
EXPECT_EQ(array[0].value, 42);
|
|
|
|
array.~Array();
|
|
|
|
}
|
|
|
|
}
|
2020-06-30 16:46:46 +02:00
|
|
|
|
2020-07-20 13:02:10 +02:00
|
|
|
TEST(array, Fill)
|
|
|
|
{
|
|
|
|
Array<int> array(5);
|
|
|
|
array.fill(3);
|
|
|
|
EXPECT_EQ(array.size(), 5u);
|
|
|
|
EXPECT_EQ(array[0], 3);
|
|
|
|
EXPECT_EQ(array[1], 3);
|
|
|
|
EXPECT_EQ(array[2], 3);
|
|
|
|
EXPECT_EQ(array[3], 3);
|
|
|
|
EXPECT_EQ(array[4], 3);
|
|
|
|
}
|
|
|
|
|
2020-07-23 15:23:55 +02:00
|
|
|
} // namespace blender::tests
|