Blender V4.3
object_identifier_test.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2019 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
5
6#include "testing/testing.h"
7
8#include "BLI_utildefines.h"
9
10#include <climits>
11
12namespace blender::io {
13
14namespace {
15
16/* Return object pointer for use in tests. This makes it possible to reliably test for
17 * order/equality functions while using hard-coded values for simplicity. */
18Object *fake_pointer(int value)
19{
20 return static_cast<Object *>(POINTER_FROM_INT(value));
21}
22
23/* PersistentID subclass for use in tests, making it easier to construct test values. */
24class TestPersistentID : public PersistentID {
25 public:
26 TestPersistentID(int value0,
27 int value1,
28 int value2,
29 int value3,
30 int value4,
31 int value5,
32 int value6,
33 int value7)
34 {
35 persistent_id_[0] = value0;
36 persistent_id_[1] = value1;
37 persistent_id_[2] = value2;
38 persistent_id_[3] = value3;
39 persistent_id_[4] = value4;
40 persistent_id_[5] = value5;
41 persistent_id_[6] = value6;
42 persistent_id_[7] = value7;
43 }
44 TestPersistentID(int value0, int value1, int value2)
45 : TestPersistentID(value0, value1, value2, INT_MAX, INT_MAX, INT_MAX, INT_MAX, INT_MAX)
46 {
47 }
48 TestPersistentID(int value0, int value1) : TestPersistentID(value0, value1, INT_MAX) {}
49 explicit TestPersistentID(int value0) : TestPersistentID(value0, INT_MAX) {}
50};
51
52/* ObjectIdentifier subclass for use in tests, making it easier to construct test values. */
53class TestObjectIdentifier : public ObjectIdentifier {
54 public:
55 TestObjectIdentifier(Object *object, Object *duplicated_by, const PersistentID &persistent_id)
56 : ObjectIdentifier(object, duplicated_by, persistent_id)
57 {
58 }
59};
60
61} // namespace
62
63class ObjectIdentifierOrderTest : public testing::Test {};
64
66{
69 EXPECT_TRUE(id_root_1 == id_root_2);
70 EXPECT_FALSE(id_root_1 < id_root_2);
71 EXPECT_FALSE(id_root_2 < id_root_1);
72
74 EXPECT_FALSE(id_root_1 == id_a);
75 EXPECT_TRUE(id_root_1 < id_a);
76 EXPECT_FALSE(id_a < id_root_1);
77
78 ObjectIdentifier id_accidental_root = ObjectIdentifier::for_real_object(nullptr);
79 EXPECT_TRUE(id_root_1 == id_accidental_root);
80 EXPECT_FALSE(id_root_1 < id_accidental_root);
81 EXPECT_FALSE(id_accidental_root < id_root_1);
82}
83
85{
88 EXPECT_FALSE(id_a == id_b);
89 EXPECT_TRUE(id_a < id_b);
90}
91
93{
94 ObjectIdentifier id_real_a = ObjectIdentifier::for_real_object(fake_pointer(1));
95 TestObjectIdentifier id_dupli_a(fake_pointer(1), fake_pointer(2), TestPersistentID(0));
96 TestObjectIdentifier id_dupli_b(fake_pointer(1), fake_pointer(3), TestPersistentID(0));
97 TestObjectIdentifier id_different_dupli_b(fake_pointer(1), fake_pointer(3), TestPersistentID(1));
98
99 EXPECT_FALSE(id_real_a == id_dupli_a);
100 EXPECT_FALSE(id_dupli_a == id_dupli_b);
101 EXPECT_TRUE(id_real_a < id_dupli_a);
102 EXPECT_TRUE(id_real_a < id_dupli_b);
103 EXPECT_TRUE(id_dupli_a < id_dupli_b);
104 EXPECT_TRUE(id_dupli_a < id_different_dupli_b);
105
106 EXPECT_FALSE(id_dupli_b == id_different_dupli_b);
107 EXPECT_FALSE(id_dupli_a == id_different_dupli_b);
108 EXPECT_TRUE(id_dupli_b < id_different_dupli_b);
109 EXPECT_FALSE(id_different_dupli_b < id_dupli_b);
110}
111
112TEST_F(ObjectIdentifierOrderTest, behavior_as_map_keys)
113{
116 ObjectIdentifier id_real_a = ObjectIdentifier::for_real_object(fake_pointer(1));
117 TestObjectIdentifier id_dupli_a(fake_pointer(1), fake_pointer(2), TestPersistentID(0));
118 TestObjectIdentifier id_dupli_b(fake_pointer(1), fake_pointer(3), TestPersistentID(0));
120
121 /* This inserts the keys with default values. */
122 graph[id_root];
123 graph[id_real_a];
124 graph[id_dupli_a];
125 graph[id_dupli_b];
126 graph[id_another_root];
127
128 EXPECT_EQ(4, graph.size());
129
130 graph.erase(id_another_root);
131 EXPECT_EQ(3, graph.size());
132
133 TestObjectIdentifier id_another_dupli_b(fake_pointer(1), fake_pointer(3), TestPersistentID(0));
134 graph.erase(id_another_dupli_b);
135 EXPECT_EQ(2, graph.size());
136}
137
139{
141 ObjectIdentifier id_real_a = ObjectIdentifier::for_real_object(fake_pointer(1));
142 TestObjectIdentifier id_dupli_a(fake_pointer(1), fake_pointer(2), TestPersistentID(0));
143 TestObjectIdentifier id_dupli_b(fake_pointer(1), fake_pointer(3), TestPersistentID(0));
144 TestObjectIdentifier id_dupli_c(fake_pointer(1), fake_pointer(3), TestPersistentID(1));
146
147 /* This inserts the keys with default values. */
148 graph[id_root];
149 graph[id_real_a];
150 graph[id_dupli_a];
151 graph[id_dupli_b];
152 graph[id_dupli_c];
153 EXPECT_EQ(5, graph.size());
154
156 EXPECT_EQ(5, graph_copy.size());
157
158 /* Updating a value in a copy should not update the original. */
159 HierarchyContext ctx1;
160 HierarchyContext ctx2;
161 ctx1.object = fake_pointer(1);
162 ctx2.object = fake_pointer(2);
163
164 graph_copy[id_root].insert(&ctx1);
165 EXPECT_EQ(0, graph[id_root].size());
166
167 /* Deleting a key in the copy should not update the original. */
168 graph_copy.erase(id_dupli_c);
169 EXPECT_EQ(4, graph_copy.size());
170 EXPECT_EQ(5, graph.size());
171}
172
173class PersistentIDTest : public testing::Test {};
174
175TEST_F(PersistentIDTest, is_from_same_instancer)
176{
177 PersistentID child_id_a = TestPersistentID(42, 327);
178 PersistentID child_id_b = TestPersistentID(17, 327);
179 PersistentID child_id_c = TestPersistentID(17);
180
181 EXPECT_TRUE(child_id_a.is_from_same_instancer_as(child_id_b));
182 EXPECT_FALSE(child_id_a.is_from_same_instancer_as(child_id_c));
183}
184
186{
187 PersistentID child_id = TestPersistentID(42, 327);
188
189 PersistentID expect_instancer_id = TestPersistentID(327);
190 EXPECT_EQ(expect_instancer_id, child_id.instancer_pid());
191
192 PersistentID empty_id;
193 EXPECT_EQ(empty_id, child_id.instancer_pid().instancer_pid());
194
195 EXPECT_LT(child_id, expect_instancer_id);
196 EXPECT_LT(expect_instancer_id, empty_id);
197}
198
199TEST_F(PersistentIDTest, as_object_name_suffix)
200{
201 EXPECT_EQ("", PersistentID().as_object_name_suffix());
202 EXPECT_EQ("47", TestPersistentID(47).as_object_name_suffix());
203 EXPECT_EQ("327-47", TestPersistentID(47, 327).as_object_name_suffix());
204 EXPECT_EQ("42-327-47", TestPersistentID(47, 327, 42).as_object_name_suffix());
205
206 EXPECT_EQ("7-6-5-4-3-2-1-0", TestPersistentID(0, 1, 2, 3, 4, 5, 6, 7).as_object_name_suffix());
207
208 EXPECT_EQ("0-0-0", TestPersistentID(0, 0, 0).as_object_name_suffix());
209 EXPECT_EQ("0-0", TestPersistentID(0, 0).as_object_name_suffix());
210 EXPECT_EQ("-3--2--1", TestPersistentID(-1, -2, -3).as_object_name_suffix());
211}
212
213} // namespace blender::io
EXPECT_EQ(BLI_expr_pylike_eval(expr, nullptr, 0, &result), EXPR_PYLIKE_INVALID)
#define POINTER_FROM_INT(i)
static DBVT_INLINE btScalar size(const btDbvtVolume &a)
Definition btDbvt.cpp:52
std::map< ObjectIdentifier, ExportChildren > ExportGraph
static ObjectIdentifier for_graph_root()
static ObjectIdentifier for_real_object(Object *object)
PersistentID instancer_pid() const
bool is_from_same_instancer_as(const PersistentID &other) const
Depsgraph * graph
TEST_F(AbstractHierarchyIteratorTest, ExportHierarchyTest)