diff options
Diffstat (limited to 'linden/indra/test/lljoint_tut.cpp')
-rw-r--r-- | linden/indra/test/lljoint_tut.cpp | 244 |
1 files changed, 244 insertions, 0 deletions
diff --git a/linden/indra/test/lljoint_tut.cpp b/linden/indra/test/lljoint_tut.cpp new file mode 100644 index 0000000..5be81ae --- /dev/null +++ b/linden/indra/test/lljoint_tut.cpp | |||
@@ -0,0 +1,244 @@ | |||
1 | /** | ||
2 | * @file lljoint_tut.cpp | ||
3 | * @author Adroit | ||
4 | * @date 2007=-03 | ||
5 | * @brief lljoint test cases. | ||
6 | * | ||
7 | * Copyright (c) 2007-2007, Linden Research, Inc. | ||
8 | * | ||
9 | * Second Life Viewer Source Code | ||
10 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
11 | * to you under the terms of the GNU General Public License, version 2.0 | ||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
15 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
16 | * | ||
17 | * There are special exceptions to the terms and conditions of the GPL as | ||
18 | * it is applied to this Source Code. View the full text of the exception | ||
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
20 | * online at http://secondlife.com/developers/opensource/flossexception | ||
21 | * | ||
22 | * By copying, modifying or distributing this software, you acknowledge | ||
23 | * that you have read and understood your obligations described above, | ||
24 | * and agree to abide by those obligations. | ||
25 | * | ||
26 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
27 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
28 | * COMPLETENESS OR PERFORMANCE. | ||
29 | */ | ||
30 | |||
31 | #ifdef THIS_DOESNT_LINK | ||
32 | // THIS DOESN'T LINK! | ||
33 | |||
34 | #include <tut/tut.h> | ||
35 | #include "lltut.h" | ||
36 | #include "linden_common.h" | ||
37 | #include "m4math.h" | ||
38 | #include "v3math.h" | ||
39 | #include "lljoint.h" | ||
40 | |||
41 | |||
42 | namespace tut | ||
43 | { | ||
44 | struct lljoint_data | ||
45 | { | ||
46 | }; | ||
47 | typedef test_group<lljoint_data> lljoint_test; | ||
48 | typedef lljoint_test::object lljoint_object; | ||
49 | tut::lljoint_test lljoint_testcase("lljoint"); | ||
50 | |||
51 | template<> template<> | ||
52 | void lljoint_object::test<1>() | ||
53 | { | ||
54 | LLJoint lljoint; | ||
55 | LLJoint* jnt = lljoint.getParent(); | ||
56 | ensure("getParent() failed ", (NULL == jnt)); | ||
57 | ensure("getRoot() failed ", (&lljoint == lljoint.getRoot())); | ||
58 | } | ||
59 | |||
60 | template<> template<> | ||
61 | void lljoint_object::test<2>() | ||
62 | { | ||
63 | std::string str = "LLJoint"; | ||
64 | LLJoint parent(str), child; | ||
65 | child.setup(str, &parent); | ||
66 | LLJoint* jnt = child.getParent(); | ||
67 | ensure("setup() failed ", (&parent == jnt)); | ||
68 | } | ||
69 | |||
70 | template<> template<> | ||
71 | void lljoint_object::test<3>() | ||
72 | { | ||
73 | LLJoint parent, child; | ||
74 | std::string str = "LLJoint"; | ||
75 | child.setup(str, &parent); | ||
76 | LLJoint* jnt = parent.findJoint(str); | ||
77 | ensure("findJoint() failed ", (&child == jnt)); | ||
78 | } | ||
79 | |||
80 | template<> template<> | ||
81 | void lljoint_object::test<4>() | ||
82 | { | ||
83 | LLJoint parent; | ||
84 | std::string str1 = "LLJoint", str2; | ||
85 | parent.setName(str1); | ||
86 | str2 = parent.getName(); | ||
87 | ensure("setName() failed ", (str1 == str2)); | ||
88 | } | ||
89 | |||
90 | template<> template<> | ||
91 | void lljoint_object::test<5>() | ||
92 | { | ||
93 | LLJoint lljoint; | ||
94 | LLVector3 vec3(2.3f,30.f,10.f); | ||
95 | lljoint.setPosition(vec3); | ||
96 | LLVector3 pos = lljoint.getPosition(); | ||
97 | ensure("setPosition()/getPosition() failed ", (vec3 == pos)); | ||
98 | } | ||
99 | |||
100 | template<> template<> | ||
101 | void lljoint_object::test<6>() | ||
102 | { | ||
103 | LLJoint lljoint; | ||
104 | LLVector3 vec3(2.3f,30.f,10.f); | ||
105 | lljoint.setWorldPosition(vec3); | ||
106 | LLVector3 pos = lljoint.getWorldPosition(); | ||
107 | ensure("1:setWorldPosition()/getWorldPosition() failed ", (vec3 == pos)); | ||
108 | LLVector3 lastPos = lljoint.getLastWorldPosition(); | ||
109 | ensure("2:getLastWorldPosition failed ", (vec3 == lastPos)); | ||
110 | } | ||
111 | |||
112 | template<> template<> | ||
113 | void lljoint_object::test<7>() | ||
114 | { | ||
115 | LLJoint lljoint("LLJoint"); | ||
116 | LLQuaternion q(2.3f,30.f,10.f,1.f); | ||
117 | lljoint.setRotation(q); | ||
118 | LLQuaternion rot = lljoint.getRotation(); | ||
119 | ensure("setRotation()/getRotation() failed ", (q == rot)); | ||
120 | } | ||
121 | template<> template<> | ||
122 | void lljoint_object::test<8>() | ||
123 | { | ||
124 | LLJoint lljoint("LLJoint"); | ||
125 | LLQuaternion q(2.3f,30.f,10.f,1.f); | ||
126 | lljoint.setWorldRotation(q); | ||
127 | LLQuaternion rot = lljoint.getWorldRotation(); | ||
128 | ensure("1:setWorldRotation()/getWorldRotation() failed ", (q == rot)); | ||
129 | LLQuaternion lastRot = lljoint.getLastWorldRotation(); | ||
130 | ensure("2:getLastWorldRotation failed ", (q == lastRot)); | ||
131 | } | ||
132 | |||
133 | template<> template<> | ||
134 | void lljoint_object::test<9>() | ||
135 | { | ||
136 | LLJoint lljoint; | ||
137 | LLVector3 vec3(2.3f,30.f,10.f); | ||
138 | lljoint.setScale(vec3); | ||
139 | LLVector3 scale = lljoint.getScale(); | ||
140 | ensure("setScale()/getScale failed ", (vec3 == scale)); | ||
141 | } | ||
142 | |||
143 | template<> template<> | ||
144 | void lljoint_object::test<10>() | ||
145 | { | ||
146 | LLJoint lljoint("LLJoint"); | ||
147 | LLMatrix4 mat; | ||
148 | mat.identity(); | ||
149 | lljoint.setWorldMatrix(mat);//giving warning setWorldMatrix not correctly implemented; | ||
150 | LLMatrix4 mat4 = lljoint.getWorldMatrix(); | ||
151 | ensure("setWorldMatrix()/getWorldMatrix failed ", (mat4 == mat)); | ||
152 | } | ||
153 | |||
154 | template<> template<> | ||
155 | void lljoint_object::test<11>() | ||
156 | { | ||
157 | LLJoint lljoint("parent"); | ||
158 | S32 joint_num = 12; | ||
159 | lljoint.setJointNum(joint_num); | ||
160 | S32 jointNum = lljoint.getJointNum(); | ||
161 | ensure("setJointNum()/getJointNum failed ", (jointNum == joint_num)); | ||
162 | } | ||
163 | |||
164 | template<> template<> | ||
165 | void lljoint_object::test<12>() | ||
166 | { | ||
167 | LLJoint lljoint; | ||
168 | LLVector3 vec3(2.3f,30.f,10.f); | ||
169 | lljoint.setSkinOffset(vec3); | ||
170 | LLVector3 offset = lljoint.getSkinOffset(); | ||
171 | ensure("1:setSkinOffset()/getSkinOffset() failed ", (vec3 == offset)); | ||
172 | } | ||
173 | |||
174 | template<> template<> | ||
175 | void lljoint_object::test<13>() | ||
176 | { | ||
177 | LLJoint lljointgp("gparent"); | ||
178 | LLJoint lljoint("parent"); | ||
179 | LLJoint lljoint1("child1"); | ||
180 | lljoint.addChild(&lljoint1); | ||
181 | LLJoint lljoint2("child2"); | ||
182 | lljoint.addChild(&lljoint2); | ||
183 | LLJoint lljoint3("child3"); | ||
184 | lljoint.addChild(&lljoint3); | ||
185 | |||
186 | LLJoint* jnt = NULL; | ||
187 | jnt = lljoint2.getParent(); | ||
188 | ensure("addChild() failed ", (&lljoint == jnt)); | ||
189 | LLJoint* jnt1 = lljoint.findJoint("child3"); | ||
190 | ensure("findJoint() failed ", (&lljoint3 == jnt1)); | ||
191 | lljoint.removeChild(&lljoint3); | ||
192 | LLJoint* jnt2 = lljoint.findJoint("child3"); | ||
193 | ensure("removeChild() failed ", (NULL == jnt2)); | ||
194 | |||
195 | lljointgp.addChild(&lljoint); | ||
196 | ensure("GetParent() failed ", (&lljoint== lljoint2.getParent())); | ||
197 | ensure("getRoot() failed ", (&lljointgp == lljoint2.getRoot())); | ||
198 | |||
199 | ensure("getRoot() failed ", &lljoint1 == lljoint.findJoint("child1")); | ||
200 | |||
201 | lljointgp.removeAllChildren(); | ||
202 | // parent removed from grandparent - so should not be able to locate child | ||
203 | ensure("removeAllChildren() failed ", (NULL == lljointgp.findJoint("child1"))); | ||
204 | // it should still exist in parent though | ||
205 | ensure("removeAllChildren() failed ", (&lljoint1 == lljoint.findJoint("child1"))); | ||
206 | } | ||
207 | |||
208 | template<> template<> | ||
209 | void lljoint_object::test<14>() | ||
210 | { | ||
211 | LLJoint lljointgp("gparent"); | ||
212 | |||
213 | LLJoint llparent1("parent1"); | ||
214 | LLJoint llparent2("parent2"); | ||
215 | |||
216 | LLJoint llchild("child1"); | ||
217 | LLJoint lladoptedchild("child2"); | ||
218 | llparent1.addChild(&llchild); | ||
219 | llparent1.addChild(&lladoptedchild); | ||
220 | |||
221 | llparent2.addChild(&lladoptedchild); | ||
222 | ensure("1. addChild failed to remove prior parent", lladoptedchild.getParent() == &llparent2); | ||
223 | ensure("2. addChild failed to remove prior parent", llparent1.findJoint("child2") == NULL); | ||
224 | } | ||
225 | |||
226 | |||
227 | //* | ||
228 | Test cases for the following not added. They perform operations | ||
229 | on underlying LLXformMatrix and LLVector3 elements which have | ||
230 | been unit tested separately. | ||
231 | Unit Testing these functions will basically require re-implementing | ||
232 | logic of these function in the test case itself | ||
233 | |||
234 | 1) void WorldMatrixChildren(); | ||
235 | 2) void updateWorldMatrixParent(); | ||
236 | 3) void updateWorldPRSParent(); | ||
237 | 4) void updateWorldMatrix(); | ||
238 | 5) LLXformMatrix *getXform() { return &mXform; } | ||
239 | 6) void setConstraintSilhouette(LLDynamicArray<LLVector3>& silhouette); | ||
240 | 7) void clampRotation(LLQuaternion old_rot, LLQuaternion new_rot); | ||
241 | |||
242 | //* | ||
243 | } | ||
244 | #endif // THIS_DOESNT_LINK | ||