diff options
Diffstat (limited to 'linden/indra/test/llpartdata_tut.cpp')
-rw-r--r-- | linden/indra/test/llpartdata_tut.cpp | 217 |
1 files changed, 217 insertions, 0 deletions
diff --git a/linden/indra/test/llpartdata_tut.cpp b/linden/indra/test/llpartdata_tut.cpp new file mode 100644 index 0000000..ce2cedc --- /dev/null +++ b/linden/indra/test/llpartdata_tut.cpp | |||
@@ -0,0 +1,217 @@ | |||
1 | /** | ||
2 | * @file llpartdata_tut.cpp | ||
3 | * @author Adroit | ||
4 | * @date March 2007 | ||
5 | * @brief LLPartData and LLPartSysData 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 | #include <tut/tut.h> | ||
32 | #include "lltut.h" | ||
33 | #include "linden_common.h" | ||
34 | #include "lldatapacker.h" | ||
35 | #include "llpartdata.h" | ||
36 | #include "v3math.h" | ||
37 | #include "llsdserialize.h" | ||
38 | #include "message.h" | ||
39 | |||
40 | namespace tut | ||
41 | { | ||
42 | |||
43 | struct partdata_test | ||
44 | { | ||
45 | }; | ||
46 | typedef test_group<partdata_test> partdata_test_t; | ||
47 | typedef partdata_test_t::object partdata_test_object_t; | ||
48 | tut::partdata_test_t tut_partdata_test("partdata_test"); | ||
49 | |||
50 | template<> template<> | ||
51 | void partdata_test_object_t::test<1>() | ||
52 | { | ||
53 | LLPartData llpdata,llpdata1; | ||
54 | U8 pkbuf[128]; | ||
55 | |||
56 | llpdata.setFlags(LLPartData::LL_PART_INTERP_COLOR_MASK | LLPartData::LL_PART_INTERP_SCALE_MASK | | ||
57 | LLPartData::LL_PART_BOUNCE_MASK | LLPartData::LL_PART_WIND_MASK | LLPartData::LL_PART_FOLLOW_SRC_MASK | | ||
58 | LLPartData::LL_PART_FOLLOW_VELOCITY_MASK | LLPartData::LL_PART_TARGET_POS_MASK | LLPartData::LL_PART_TARGET_LINEAR_MASK | | ||
59 | LLPartData::LL_PART_EMISSIVE_MASK | LLPartData::LL_PART_BEAM_MASK | LLPartData::LL_PART_DEAD_MASK); | ||
60 | |||
61 | llpdata.setMaxAge(29.3f); | ||
62 | |||
63 | LLVector3 llvec1(1.0f, .5f, .25f); | ||
64 | llpdata.setStartColor(llvec1); | ||
65 | llpdata.setStartAlpha(.7f); | ||
66 | |||
67 | LLVector3 llvec2(.2f, .3f, 1.0f); | ||
68 | llpdata.setEndColor(llvec2); | ||
69 | llpdata.setEndAlpha(1.0f); | ||
70 | |||
71 | llpdata.setStartScale(3.23f, 4.0f); | ||
72 | llpdata.setEndScale(2.4678f, 1.0f); | ||
73 | |||
74 | LLDataPackerBinaryBuffer dp((U8*)pkbuf, 128); | ||
75 | llpdata.pack(dp); | ||
76 | |||
77 | S32 cur_size = dp.getCurrentSize(); | ||
78 | |||
79 | LLDataPackerBinaryBuffer dp1((U8*)pkbuf, cur_size); | ||
80 | llpdata1.unpack(dp1); | ||
81 | |||
82 | ensure("1.mFlags values are different after unpacking", llpdata1.mFlags == llpdata.mFlags); | ||
83 | ensure_approximately_equals("2.mMaxAge values are different after unpacking", llpdata1.mMaxAge, llpdata.mMaxAge, 8); | ||
84 | |||
85 | ensure_approximately_equals("3.mStartColor[0] values are different after unpacking", llpdata1.mStartColor.mV[0], llpdata.mStartColor.mV[0], 8); | ||
86 | ensure_approximately_equals("4.mStartColor[1] values are different after unpacking", llpdata1.mStartColor.mV[1], llpdata.mStartColor.mV[1], 8); | ||
87 | ensure_approximately_equals("5.mStartColor[2] values are different after unpacking", llpdata1.mStartColor.mV[2], llpdata.mStartColor.mV[2], 8); | ||
88 | ensure_approximately_equals("6.mStartColor[3] values are different after unpacking", llpdata1.mStartColor.mV[3], llpdata.mStartColor.mV[3], 8); | ||
89 | |||
90 | ensure_approximately_equals("7.mEndColor[0] values are different after unpacking", llpdata1.mEndColor.mV[0], llpdata.mEndColor.mV[0], 8); | ||
91 | ensure_approximately_equals("8.mEndColor[1] values are different after unpacking", llpdata1.mEndColor.mV[1], llpdata.mEndColor.mV[1], 8); | ||
92 | ensure_approximately_equals("9.mEndColor[2] values are different after unpacking", llpdata1.mEndColor.mV[2], llpdata.mEndColor.mV[2], 8); | ||
93 | ensure_approximately_equals("10.mEndColor[2] values are different after unpacking", llpdata1.mEndColor.mV[3], llpdata.mEndColor.mV[3], 8); | ||
94 | |||
95 | ensure_approximately_equals("11.mStartScale[0] values are different after unpacking", llpdata1.mStartScale.mV[0], llpdata.mStartScale.mV[0], 5); | ||
96 | ensure_approximately_equals("12.mStartScale[1] values are different after unpacking", llpdata1.mStartScale.mV[1], llpdata.mStartScale.mV[1], 5); | ||
97 | |||
98 | ensure_approximately_equals("13.mEndScale[0] values are different after unpacking", llpdata1.mEndScale.mV[0], llpdata.mEndScale.mV[0], 5); | ||
99 | ensure_approximately_equals("14.mEndScale[1] values are different after unpacking", llpdata1.mEndScale.mV[1], llpdata.mEndScale.mV[1], 5); | ||
100 | } | ||
101 | |||
102 | |||
103 | template<> template<> | ||
104 | void partdata_test_object_t::test<2>() | ||
105 | { | ||
106 | LLPartData llpdata,llpdata1; | ||
107 | |||
108 | llpdata.setFlags(LLPartData::LL_PART_INTERP_COLOR_MASK | LLPartData::LL_PART_INTERP_SCALE_MASK | | ||
109 | LLPartData::LL_PART_BOUNCE_MASK | LLPartData::LL_PART_WIND_MASK | LLPartData::LL_PART_FOLLOW_SRC_MASK | | ||
110 | LLPartData::LL_PART_FOLLOW_VELOCITY_MASK | LLPartData::LL_PART_TARGET_POS_MASK | LLPartData::LL_PART_TARGET_LINEAR_MASK | | ||
111 | LLPartData::LL_PART_EMISSIVE_MASK | LLPartData::LL_PART_BEAM_MASK | LLPartData::LL_PART_DEAD_MASK); | ||
112 | |||
113 | llpdata.setMaxAge(29.3f); | ||
114 | |||
115 | LLVector3 llvec1(1.0f, .5f, .25f); | ||
116 | llpdata.setStartColor(llvec1); | ||
117 | llpdata.setStartAlpha(.7f); | ||
118 | |||
119 | LLVector3 llvec2(.2f, .3f, 1.0f); | ||
120 | llpdata.setEndColor(llvec2); | ||
121 | llpdata.setEndAlpha(1.0f); | ||
122 | |||
123 | llpdata.setStartScale(3.23f, 4.0f); | ||
124 | llpdata.setEndScale(2.4678f, 1.0f); | ||
125 | |||
126 | LLSD llsd = llpdata.asLLSD(); | ||
127 | |||
128 | llpdata1.fromLLSD(llsd); | ||
129 | |||
130 | ensure("1.mFlags values are different after unpacking", llpdata1.mFlags == llpdata.mFlags); | ||
131 | ensure_approximately_equals("2.mMaxAge values are different after unpacking", llpdata1.mMaxAge, llpdata.mMaxAge, 8); | ||
132 | |||
133 | ensure_approximately_equals("3.mStartColor[0] values are different after unpacking", llpdata1.mStartColor.mV[0], llpdata.mStartColor.mV[0], 8); | ||
134 | ensure_approximately_equals("4.mStartColor[1] values are different after unpacking", llpdata1.mStartColor.mV[1], llpdata.mStartColor.mV[1], 8); | ||
135 | ensure_approximately_equals("5.mStartColor[2] values are different after unpacking", llpdata1.mStartColor.mV[2], llpdata.mStartColor.mV[2], 8); | ||
136 | ensure_approximately_equals("6.mStartColor[3] values are different after unpacking", llpdata1.mStartColor.mV[3], llpdata.mStartColor.mV[3], 8); | ||
137 | |||
138 | ensure_approximately_equals("7.mEndColor[0] values are different after unpacking", llpdata1.mEndColor.mV[0], llpdata.mEndColor.mV[0], 8); | ||
139 | ensure_approximately_equals("8.mEndColor[1] values are different after unpacking", llpdata1.mEndColor.mV[1], llpdata.mEndColor.mV[1], 8); | ||
140 | ensure_approximately_equals("9.mEndColor[2] values are different after unpacking", llpdata1.mEndColor.mV[2], llpdata.mEndColor.mV[2], 8); | ||
141 | ensure_approximately_equals("10.mEndColor[2] values are different after unpacking", llpdata1.mEndColor.mV[3], llpdata.mEndColor.mV[3], 8); | ||
142 | |||
143 | ensure_approximately_equals("11.mStartScale[0] values are different after unpacking", llpdata1.mStartScale.mV[0], llpdata.mStartScale.mV[0], 5); | ||
144 | ensure_approximately_equals("12.mStartScale[1] values are different after unpacking", llpdata1.mStartScale.mV[1], llpdata.mStartScale.mV[1], 5); | ||
145 | |||
146 | ensure_approximately_equals("13.mEndScale[0] values are different after unpacking", llpdata1.mEndScale.mV[0], llpdata.mEndScale.mV[0], 5); | ||
147 | ensure_approximately_equals("14.mEndScale[1] values are different after unpacking", llpdata1.mEndScale.mV[1], llpdata.mEndScale.mV[1], 5); | ||
148 | } | ||
149 | |||
150 | |||
151 | //*********llpartsysdata*********** | ||
152 | |||
153 | template<> template<> | ||
154 | void partdata_test_object_t::test<3>() | ||
155 | { | ||
156 | LLPartSysData llpsysdata, llpsysdata1; | ||
157 | U8 pkbuf[256]; | ||
158 | llpsysdata.setBurstSpeedMin(33.33f); | ||
159 | ensure("1.mBurstSpeedMin coudnt be set", 33.33f == llpsysdata.mBurstSpeedMin); | ||
160 | |||
161 | llpsysdata.setBurstSpeedMax(44.44f); | ||
162 | ensure("2.mBurstSpeedMax coudnt be set", 44.44f == llpsysdata.mBurstSpeedMax); | ||
163 | |||
164 | llpsysdata.setBurstRadius(45.55f); | ||
165 | ensure("3.mBurstRadius coudnt be set", 45.55f == llpsysdata.mBurstRadius); | ||
166 | |||
167 | LLVector3 llvec(44.44f, 111.11f, -40.4f); | ||
168 | llpsysdata.setPartAccel(llvec); | ||
169 | |||
170 | llpsysdata.mCRC = 0xFFFFFFFF; | ||
171 | llpsysdata.mFlags = 0x20; | ||
172 | |||
173 | llpsysdata.mPattern = LLPartSysData::LL_PART_SRC_PATTERN_ANGLE_CONE_EMPTY; | ||
174 | |||
175 | llpsysdata.mMaxAge = 99.99f; | ||
176 | llpsysdata.mStartAge = 18.5f; | ||
177 | llpsysdata.mInnerAngle = 4.234f; | ||
178 | llpsysdata.mOuterAngle = 7.123f; | ||
179 | llpsysdata.mBurstRate = 245.53f; | ||
180 | llpsysdata.mBurstPartCount = 0xFF; | ||
181 | llpsysdata.mAngularVelocity = llvec; | ||
182 | |||
183 | llpsysdata.mPartImageID.generate(); | ||
184 | llpsysdata.mTargetUUID.generate(); | ||
185 | |||
186 | LLDataPackerBinaryBuffer dp((U8*)pkbuf, 256); | ||
187 | llpsysdata.pack(dp); | ||
188 | S32 cur_size = dp.getCurrentSize(); | ||
189 | LLDataPackerBinaryBuffer dp1((U8*)pkbuf, cur_size); | ||
190 | llpsysdata1.unpack(dp1); | ||
191 | |||
192 | ensure("1.mCRC's not equal", llpsysdata.mCRC == llpsysdata1.mCRC); | ||
193 | ensure("2.mFlags's not equal", llpsysdata.mFlags == llpsysdata1.mFlags); | ||
194 | ensure("3.mPattern's not equal", llpsysdata.mPattern == llpsysdata1.mPattern); | ||
195 | ensure_approximately_equals("4.mMaxAge's not equal", llpsysdata.mMaxAge , llpsysdata1.mMaxAge, 8); | ||
196 | ensure_approximately_equals("5.mStartAge's not equal", llpsysdata.mStartAge, llpsysdata1.mStartAge, 8); | ||
197 | ensure_approximately_equals("6.mOuterAngle's not equal", llpsysdata.mOuterAngle, llpsysdata1.mOuterAngle, 5); | ||
198 | ensure_approximately_equals("7.mInnerAngles's not equal", llpsysdata.mInnerAngle, llpsysdata1.mInnerAngle, 5); | ||
199 | ensure_approximately_equals("8.mBurstRate's not equal", llpsysdata.mBurstRate, llpsysdata1.mBurstRate, 8); | ||
200 | ensure("9.mBurstPartCount's not equal", llpsysdata.mBurstPartCount == llpsysdata1.mBurstPartCount); | ||
201 | |||
202 | ensure_approximately_equals("10.mBurstSpeedMin's not equal", llpsysdata.mBurstSpeedMin, llpsysdata1.mBurstSpeedMin, 8); | ||
203 | ensure_approximately_equals("11.mBurstSpeedMax's not equal", llpsysdata.mBurstSpeedMax, llpsysdata1.mBurstSpeedMax, 8); | ||
204 | |||
205 | ensure_approximately_equals("12.mAngularVelocity's not equal", llpsysdata.mAngularVelocity.mV[0], llpsysdata1.mAngularVelocity.mV[0], 7); | ||
206 | ensure_approximately_equals("13.mAngularVelocity's not equal", llpsysdata.mAngularVelocity.mV[1], llpsysdata1.mAngularVelocity.mV[1], 7); | ||
207 | ensure_approximately_equals("14.mAngularVelocity's not equal", llpsysdata.mAngularVelocity.mV[2], llpsysdata1.mAngularVelocity.mV[2], 7); | ||
208 | |||
209 | ensure_approximately_equals("15.mPartAccel's not equal", llpsysdata.mPartAccel.mV[0], llpsysdata1.mPartAccel.mV[0], 7); | ||
210 | ensure_approximately_equals("16.mPartAccel's not equal", llpsysdata.mPartAccel.mV[1], llpsysdata1.mPartAccel.mV[1], 7); | ||
211 | ensure_approximately_equals("17.mPartAccel's not equal", llpsysdata.mPartAccel.mV[2], llpsysdata1.mPartAccel.mV[2], 7); | ||
212 | |||
213 | ensure("18.mPartImageID's not equal", llpsysdata.mPartImageID == llpsysdata1.mPartImageID); | ||
214 | ensure("19.mTargetUUID's not equal", llpsysdata.mTargetUUID == llpsysdata1.mTargetUUID); | ||
215 | ensure_approximately_equals("20.mBurstRadius's not equal", llpsysdata.mBurstRadius, llpsysdata1.mBurstRadius, 8); | ||
216 | } | ||
217 | } | ||