Welcome to mirror list, hosted at ThFree Co, Russian Federation.

BLI_array_utils_test.cc « blenlib « gtests « tests - git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 2a1c18366727d6479a0da15d7e8939e7d1e77a5d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
/* Apache License, Version 2.0 */

#include "testing/testing.h"

extern "C" {
#include "BLI_utildefines.h"
#include "BLI_array_utils.h"
}

/* -------------------------------------------------------------------- */
/* tests */

/* BLI_array_reverse */
TEST(array_utils, Reverse)
{
	{
		char data[] = "";
		BLI_array_reverse(data, ARRAY_SIZE(data) - 1);
		EXPECT_STREQ("", data);
	}

	{
		char data[] = "0";
		BLI_array_reverse(data, ARRAY_SIZE(data) - 1);
		EXPECT_STREQ("0", data);
	}

	{
		char data[] = "0123";
		BLI_array_reverse(data, ARRAY_SIZE(data) - 1);
		EXPECT_STREQ("3210", data);
	}

	{
		const std::vector<int> data_cmp  = {3, 2, 1, 0};
		std::vector<int> data            = {0, 1, 2, 3};
		BLI_array_reverse(data.data(), data.size());
		EXPECT_EQ(data, data_cmp);
	}
}

/* BLI_array_findindex */
TEST(array_utils, FindIndex)
{
	{
		char data[] = "", find = '0';
		EXPECT_EQ(-1, BLI_array_findindex(data, ARRAY_SIZE(data) - 1, &find));
	}

	{
		char data[] = "0", find = '0';
		EXPECT_EQ(0, BLI_array_findindex(data, ARRAY_SIZE(data) - 1, &find));
	}

	{
		char data[] = "1", find = '0';
		EXPECT_EQ(-1, BLI_array_findindex(data, ARRAY_SIZE(data) - 1, &find));
	}

	{
		char data[] = "0123", find = '3';
		EXPECT_EQ(3, BLI_array_findindex(data, ARRAY_SIZE(data) - 1, &find));
	}

	{
		int data[] = {0, 1, 2, 3}, find = 2;
		EXPECT_EQ(2, BLI_array_findindex(data, ARRAY_SIZE(data) - 1, &find));
	}
}

/* BLI_array_binary_and */
TEST(array_utils, BinaryAnd)
{
#define BINARY_AND_TEST(data_cmp, data_a, data_b, data_combine) \
	{ \
		data_combine.resize(data_cmp.size()); \
		BLI_array_binary_and(data_combine.data(), data_a.data(), data_b.data(), data_cmp.size()); \
		EXPECT_EQ(data_combine, data_cmp); \
	} ((void)0)

	{
		std::vector<int> data_a = {0, 1, 0, 1}, data_b = {1, 0, 1, 0}, data_cmp = {0, 0, 0, 0};
		std::vector<int> data_combine;
		BINARY_AND_TEST(data_cmp, data_a, data_b, data_combine);
	}

	{
		std::vector<int> data_a = {1, 1, 1, 1}, data_b = {1, 0, 1, 0}, data_cmp = {1, 0, 1, 0};
		std::vector<int> data_combine;
		BINARY_AND_TEST(data_cmp, data_a, data_b, data_combine);
	}
#undef BINARY_AND_TEST
}

/* BLI_array_binary_or */
TEST(array_utils, BinaryOr)
{
#define BINARY_OR_TEST(data_cmp, data_a, data_b, data_combine) \
	{ \
		data_combine.resize(data_cmp.size()); \
		BLI_array_binary_or(data_combine.data(), data_a.data(), data_b.data(), data_cmp.size()); \
		EXPECT_EQ(data_combine, data_cmp); \
	} ((void)0)

	{
		std::vector<int> data_a = {0, 1, 0, 1}, data_b = {1, 0, 1, 0}, data_cmp = {1, 1, 1, 1};
		std::vector<int> data_combine;
		BINARY_OR_TEST(data_cmp, data_a, data_b, data_combine);
	}

	{
		std::vector<int> data_a = {1, 1, 0, 0}, data_b = {0, 0, 1, 0}, data_cmp = {1, 1, 1, 0};
		std::vector<int> data_combine;
		BINARY_OR_TEST(data_cmp, data_a, data_b, data_combine);
	}
#undef BINARY_OR_TEST
}