aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLFloat.cs1158
-rw-r--r--OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLString.cs224
2 files changed, 691 insertions, 691 deletions
diff --git a/OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLFloat.cs b/OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLFloat.cs
index a94370e..4af9df7 100644
--- a/OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLFloat.cs
+++ b/OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLFloat.cs
@@ -1,579 +1,579 @@
1/* 1/*
2 * Copyright (c) Contributors, http://opensimulator.org/ 2 * Copyright (c) Contributors, http://opensimulator.org/
3 * See CONTRIBUTORS.TXT for a full list of copyright holders. 3 * See CONTRIBUTORS.TXT for a full list of copyright holders.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met: 6 * modification, are permitted provided that the following conditions are met:
7 * * Redistributions of source code must retain the above copyright 7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above copyright 9 * * Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution. 11 * documentation and/or other materials provided with the distribution.
12 * * Neither the name of the OpenSim Project nor the 12 * * Neither the name of the OpenSim Project nor the
13 * names of its contributors may be used to endorse or promote products 13 * names of its contributors may be used to endorse or promote products
14 * derived from this software without specific prior written permission. 14 * derived from this software without specific prior written permission.
15 * 15 *
16 * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY 16 * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19 * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY 19 * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 20 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 22 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 23 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */ 26 */
27 27
28using System.Collections.Generic; 28using System.Collections.Generic;
29using NUnit.Framework; 29using NUnit.Framework;
30using OpenSim.Tests.Common; 30using OpenSim.Tests.Common;
31using OpenSim.Region.ScriptEngine.Common; 31using OpenSim.Region.ScriptEngine.Common;
32using System; 32using System;
33 33
34namespace OpenSim.Region.ScriptEngine.Common.Tests 34namespace OpenSim.Region.ScriptEngine.Common.Tests
35{ 35{
36 [TestFixture] 36 [TestFixture]
37 public class LSL_TypesTestLSLFloat 37 public class LSL_TypesTestLSLFloat
38 { 38 {
39 // Used for testing equality of two floats. 39 // Used for testing equality of two floats.
40 private double _lowPrecisionTolerance = 0.000001; 40 private double _lowPrecisionTolerance = 0.000001;
41 41
42 /// <summary> 42 /// <summary>
43 /// Tests constructing a LSLFloat from an integer. 43 /// Tests constructing a LSLFloat from an integer.
44 /// </summary> 44 /// </summary>
45 [Test] 45 [Test]
46 public void TestConstructFromInt() 46 public void TestConstructFromInt()
47 { 47 {
48 // The numbers we test for. 48 // The numbers we test for.
49 Dictionary<int, double> numberSet = new Dictionary<int, double>(); 49 Dictionary<int, double> numberSet = new Dictionary<int, double>();
50 numberSet.Add(2, 2.0); 50 numberSet.Add(2, 2.0);
51 numberSet.Add(-2, -2.0); 51 numberSet.Add(-2, -2.0);
52 numberSet.Add(0, 0.0); 52 numberSet.Add(0, 0.0);
53 numberSet.Add(1, 1.0); 53 numberSet.Add(1, 1.0);
54 numberSet.Add(-1, -1.0); 54 numberSet.Add(-1, -1.0);
55 numberSet.Add(999999999, 999999999.0); 55 numberSet.Add(999999999, 999999999.0);
56 numberSet.Add(-99999999, -99999999.0); 56 numberSet.Add(-99999999, -99999999.0);
57 57
58 LSL_Types.LSLFloat testFloat; 58 LSL_Types.LSLFloat testFloat;
59 59
60 foreach(KeyValuePair<int, double> number in numberSet) 60 foreach(KeyValuePair<int, double> number in numberSet)
61 { 61 {
62 testFloat = new LSL_Types.LSLFloat(number.Key); 62 testFloat = new LSL_Types.LSLFloat(number.Key);
63 Assert.That(testFloat.value, new DoubleToleranceConstraint(number.Value, _lowPrecisionTolerance)); 63 Assert.That(testFloat.value, new DoubleToleranceConstraint(number.Value, _lowPrecisionTolerance));
64 } 64 }
65 } 65 }
66 66
67 /// <summary> 67 /// <summary>
68 /// Tests constructing a LSLFloat from a double. 68 /// Tests constructing a LSLFloat from a double.
69 /// </summary> 69 /// </summary>
70 [Test] 70 [Test]
71 public void TestConstructFromDouble() 71 public void TestConstructFromDouble()
72 { 72 {
73 // The numbers we test for. 73 // The numbers we test for.
74 Dictionary<double, double> numberSet = new Dictionary<double, double>(); 74 Dictionary<double, double> numberSet = new Dictionary<double, double>();
75 numberSet.Add(2.0, 2.0); 75 numberSet.Add(2.0, 2.0);
76 numberSet.Add(-2.0, -2.0); 76 numberSet.Add(-2.0, -2.0);
77 numberSet.Add(0.0, 0.0); 77 numberSet.Add(0.0, 0.0);
78 numberSet.Add(1.0, 1.0); 78 numberSet.Add(1.0, 1.0);
79 numberSet.Add(-1.0, -1.0); 79 numberSet.Add(-1.0, -1.0);
80 numberSet.Add(999999999.0, 999999999.0); 80 numberSet.Add(999999999.0, 999999999.0);
81 numberSet.Add(-99999999.0, -99999999.0); 81 numberSet.Add(-99999999.0, -99999999.0);
82 numberSet.Add(0.5, 0.5); 82 numberSet.Add(0.5, 0.5);
83 numberSet.Add(0.0005, 0.0005); 83 numberSet.Add(0.0005, 0.0005);
84 numberSet.Add(0.6805, 0.6805); 84 numberSet.Add(0.6805, 0.6805);
85 numberSet.Add(-0.5, -0.5); 85 numberSet.Add(-0.5, -0.5);
86 numberSet.Add(-0.0005, -0.0005); 86 numberSet.Add(-0.0005, -0.0005);
87 numberSet.Add(-0.6805, -0.6805); 87 numberSet.Add(-0.6805, -0.6805);
88 numberSet.Add(548.5, 548.5); 88 numberSet.Add(548.5, 548.5);
89 numberSet.Add(2.0005, 2.0005); 89 numberSet.Add(2.0005, 2.0005);
90 numberSet.Add(349485435.6805, 349485435.6805); 90 numberSet.Add(349485435.6805, 349485435.6805);
91 numberSet.Add(-548.5, -548.5); 91 numberSet.Add(-548.5, -548.5);
92 numberSet.Add(-2.0005, -2.0005); 92 numberSet.Add(-2.0005, -2.0005);
93 numberSet.Add(-349485435.6805, -349485435.6805); 93 numberSet.Add(-349485435.6805, -349485435.6805);
94 94
95 LSL_Types.LSLFloat testFloat; 95 LSL_Types.LSLFloat testFloat;
96 96
97 foreach(KeyValuePair<double, double> number in numberSet) 97 foreach(KeyValuePair<double, double> number in numberSet)
98 { 98 {
99 testFloat = new LSL_Types.LSLFloat(number.Key); 99 testFloat = new LSL_Types.LSLFloat(number.Key);
100 Assert.That(testFloat.value, new DoubleToleranceConstraint(number.Value, _lowPrecisionTolerance)); 100 Assert.That(testFloat.value, new DoubleToleranceConstraint(number.Value, _lowPrecisionTolerance));
101 } 101 }
102 } 102 }
103 103
104 /// <summary> 104 /// <summary>
105 /// Tests LSLFloat is correctly cast implicitly to integer. 105 /// Tests LSLFloat is correctly cast implicitly to integer.
106 /// </summary> 106 /// </summary>
107 [Test] 107 [Test]
108 public void TestImplicitCastLSLFloatToInt() 108 public void TestImplicitCastLSLFloatToInt()
109 { 109 {
110 // The numbers we test for. 110 // The numbers we test for.
111 Dictionary<double, int> numberSet = new Dictionary<double, int>(); 111 Dictionary<double, int> numberSet = new Dictionary<double, int>();
112 numberSet.Add(2.0, 2); 112 numberSet.Add(2.0, 2);
113 numberSet.Add(-2.0, -2); 113 numberSet.Add(-2.0, -2);
114 numberSet.Add(0.0, 0); 114 numberSet.Add(0.0, 0);
115 numberSet.Add(1.0, 1); 115 numberSet.Add(1.0, 1);
116 numberSet.Add(-1.0, -1); 116 numberSet.Add(-1.0, -1);
117 numberSet.Add(999999999.0, 999999999); 117 numberSet.Add(999999999.0, 999999999);
118 numberSet.Add(-99999999.0, -99999999); 118 numberSet.Add(-99999999.0, -99999999);
119 numberSet.Add(0.5, 0); 119 numberSet.Add(0.5, 0);
120 numberSet.Add(0.0005, 0); 120 numberSet.Add(0.0005, 0);
121 numberSet.Add(0.6805, 0); 121 numberSet.Add(0.6805, 0);
122 numberSet.Add(-0.5, 0); 122 numberSet.Add(-0.5, 0);
123 numberSet.Add(-0.0005, 0); 123 numberSet.Add(-0.0005, 0);
124 numberSet.Add(-0.6805, 0); 124 numberSet.Add(-0.6805, 0);
125 numberSet.Add(548.5, 548); 125 numberSet.Add(548.5, 548);
126 numberSet.Add(2.0005, 2); 126 numberSet.Add(2.0005, 2);
127 numberSet.Add(349485435.6805, 349485435); 127 numberSet.Add(349485435.6805, 349485435);
128 numberSet.Add(-548.5, -548); 128 numberSet.Add(-548.5, -548);
129 numberSet.Add(-2.0005, -2); 129 numberSet.Add(-2.0005, -2);
130 numberSet.Add(-349485435.6805, -349485435); 130 numberSet.Add(-349485435.6805, -349485435);
131 131
132 int testNumber; 132 int testNumber;
133 133
134 foreach(KeyValuePair<double, int> number in numberSet) 134 foreach(KeyValuePair<double, int> number in numberSet)
135 { 135 {
136 testNumber = new LSL_Types.LSLFloat(number.Key); 136 testNumber = new LSL_Types.LSLFloat(number.Key);
137 Assert.AreEqual(number.Value, testNumber, "Converting double " + number.Key + ", expecting int " + number.Value); 137 Assert.AreEqual(number.Value, testNumber, "Converting double " + number.Key + ", expecting int " + number.Value);
138 } 138 }
139 } 139 }
140 140
141 /// <summary> 141 /// <summary>
142 /// Tests LSLFloat is correctly cast implicitly to unsigned integer. 142 /// Tests LSLFloat is correctly cast implicitly to unsigned integer.
143 /// </summary> 143 /// </summary>
144 [Test] 144 [Test]
145 public void TestImplicitCastLSLFloatToUint() 145 public void TestImplicitCastLSLFloatToUint()
146 { 146 {
147 // The numbers we test for. 147 // The numbers we test for.
148 Dictionary<double, int> numberSet = new Dictionary<double, int>(); 148 Dictionary<double, int> numberSet = new Dictionary<double, int>();
149 numberSet.Add(2.0, 2); 149 numberSet.Add(2.0, 2);
150 numberSet.Add(-2.0, 2); 150 numberSet.Add(-2.0, 2);
151 numberSet.Add(0.0, 0); 151 numberSet.Add(0.0, 0);
152 numberSet.Add(1.0, 1); 152 numberSet.Add(1.0, 1);
153 numberSet.Add(-1.0, 1); 153 numberSet.Add(-1.0, 1);
154 numberSet.Add(999999999.0, 999999999); 154 numberSet.Add(999999999.0, 999999999);
155 numberSet.Add(-99999999.0, 99999999); 155 numberSet.Add(-99999999.0, 99999999);
156 numberSet.Add(0.5, 0); 156 numberSet.Add(0.5, 0);
157 numberSet.Add(0.0005, 0); 157 numberSet.Add(0.0005, 0);
158 numberSet.Add(0.6805, 0); 158 numberSet.Add(0.6805, 0);
159 numberSet.Add(-0.5, 0); 159 numberSet.Add(-0.5, 0);
160 numberSet.Add(-0.0005, 0); 160 numberSet.Add(-0.0005, 0);
161 numberSet.Add(-0.6805, 0); 161 numberSet.Add(-0.6805, 0);
162 numberSet.Add(548.5, 548); 162 numberSet.Add(548.5, 548);
163 numberSet.Add(2.0005, 2); 163 numberSet.Add(2.0005, 2);
164 numberSet.Add(349485435.6805, 349485435); 164 numberSet.Add(349485435.6805, 349485435);
165 numberSet.Add(-548.5, 548); 165 numberSet.Add(-548.5, 548);
166 numberSet.Add(-2.0005, 2); 166 numberSet.Add(-2.0005, 2);
167 numberSet.Add(-349485435.6805, 349485435); 167 numberSet.Add(-349485435.6805, 349485435);
168 168
169 uint testNumber; 169 uint testNumber;
170 170
171 foreach(KeyValuePair<double, int> number in numberSet) 171 foreach(KeyValuePair<double, int> number in numberSet)
172 { 172 {
173 testNumber = new LSL_Types.LSLFloat(number.Key); 173 testNumber = new LSL_Types.LSLFloat(number.Key);
174 Assert.AreEqual(number.Value, testNumber, "Converting double " + number.Key + ", expecting uint " + number.Value); 174 Assert.AreEqual(number.Value, testNumber, "Converting double " + number.Key + ", expecting uint " + number.Value);
175 } 175 }
176 } 176 }
177 177
178 /// <summary> 178 /// <summary>
179 /// Tests LSLFloat is correctly cast implicitly to Boolean if non-zero. 179 /// Tests LSLFloat is correctly cast implicitly to Boolean if non-zero.
180 /// </summary> 180 /// </summary>
181 [Test] 181 [Test]
182 public void TestImplicitCastLSLFloatToBooleanTrue() 182 public void TestImplicitCastLSLFloatToBooleanTrue()
183 { 183 {
184 // A bunch of numbers to test with. 184 // A bunch of numbers to test with.
185 List<double> numberList = new List<double>(); 185 List<double> numberList = new List<double>();
186 numberList.Add(2.0); 186 numberList.Add(2.0);
187 numberList.Add(-2.0); 187 numberList.Add(-2.0);
188 numberList.Add(1.0); 188 numberList.Add(1.0);
189 numberList.Add(-1.0); 189 numberList.Add(-1.0);
190 numberList.Add(999999999.0); 190 numberList.Add(999999999.0);
191 numberList.Add(-99999999.0); 191 numberList.Add(-99999999.0);
192 numberList.Add(0.5); 192 numberList.Add(0.5);
193 numberList.Add(0.0005); 193 numberList.Add(0.0005);
194 numberList.Add(0.6805); 194 numberList.Add(0.6805);
195 numberList.Add(-0.5); 195 numberList.Add(-0.5);
196 numberList.Add(-0.0005); 196 numberList.Add(-0.0005);
197 numberList.Add(-0.6805); 197 numberList.Add(-0.6805);
198 numberList.Add(548.5); 198 numberList.Add(548.5);
199 numberList.Add(2.0005); 199 numberList.Add(2.0005);
200 numberList.Add(349485435.6805); 200 numberList.Add(349485435.6805);
201 numberList.Add(-548.5); 201 numberList.Add(-548.5);
202 numberList.Add(-2.0005); 202 numberList.Add(-2.0005);
203 numberList.Add(-349485435.6805); 203 numberList.Add(-349485435.6805);
204 204
205 LSL_Types.LSLFloat testFloat; 205 LSL_Types.LSLFloat testFloat;
206 bool testBool; 206 bool testBool;
207 207
208 foreach(double number in numberList) 208 foreach(double number in numberList)
209 { 209 {
210 testFloat = new LSL_Types.LSLFloat(number); 210 testFloat = new LSL_Types.LSLFloat(number);
211 testBool = testFloat; 211 testBool = testFloat;
212 212
213 Assert.IsTrue(testBool); 213 Assert.IsTrue(testBool);
214 } 214 }
215 } 215 }
216 216
217 /// <summary> 217 /// <summary>
218 /// Tests LSLFloat is correctly cast implicitly to Boolean if zero. 218 /// Tests LSLFloat is correctly cast implicitly to Boolean if zero.
219 /// </summary> 219 /// </summary>
220 [Test] 220 [Test]
221 public void TestImplicitCastLSLFloatToBooleanFalse() 221 public void TestImplicitCastLSLFloatToBooleanFalse()
222 { 222 {
223 LSL_Types.LSLFloat testFloat = new LSL_Types.LSLFloat(0.0); 223 LSL_Types.LSLFloat testFloat = new LSL_Types.LSLFloat(0.0);
224 bool testBool = testFloat; 224 bool testBool = testFloat;
225 225
226 Assert.IsFalse(testBool); 226 Assert.IsFalse(testBool);
227 } 227 }
228 228
229 /// <summary> 229 /// <summary>
230 /// Tests integer is correctly cast implicitly to LSLFloat. 230 /// Tests integer is correctly cast implicitly to LSLFloat.
231 /// </summary> 231 /// </summary>
232 [Test] 232 [Test]
233 public void TestImplicitCastIntToLSLFloat() 233 public void TestImplicitCastIntToLSLFloat()
234 { 234 {
235 // A bunch of numbers to test with. 235 // A bunch of numbers to test with.
236 List<int> numberList = new List<int>(); 236 List<int> numberList = new List<int>();
237 numberList.Add(2); 237 numberList.Add(2);
238 numberList.Add(-2); 238 numberList.Add(-2);
239 numberList.Add(0); 239 numberList.Add(0);
240 numberList.Add(1); 240 numberList.Add(1);
241 numberList.Add(-1); 241 numberList.Add(-1);
242 numberList.Add(999999999); 242 numberList.Add(999999999);
243 numberList.Add(-99999999); 243 numberList.Add(-99999999);
244 244
245 LSL_Types.LSLFloat testFloat; 245 LSL_Types.LSLFloat testFloat;
246 246
247 foreach(int number in numberList) 247 foreach(int number in numberList)
248 { 248 {
249 testFloat = number; 249 testFloat = number;
250 Assert.That(testFloat.value, new DoubleToleranceConstraint(number, _lowPrecisionTolerance)); 250 Assert.That(testFloat.value, new DoubleToleranceConstraint(number, _lowPrecisionTolerance));
251 } 251 }
252 } 252 }
253 253
254 /// <summary> 254 /// <summary>
255 /// Tests string is correctly cast implicitly to LSLFloat. 255 /// Tests string is correctly cast implicitly to LSLFloat.
256 /// </summary> 256 /// </summary>
257 [Test] 257 [Test]
258 public void TestImplicitCastStringToLSLFloat() 258 public void TestImplicitCastStringToLSLFloat()
259 { 259 {
260 // A bunch of numbers to test with. 260 // A bunch of numbers to test with.
261 Dictionary<string, double> numberSet = new Dictionary<string, double>(); 261 Dictionary<string, double> numberSet = new Dictionary<string, double>();
262 numberSet.Add("2", 2.0); 262 numberSet.Add("2", 2.0);
263 numberSet.Add("-2", -2.0); 263 numberSet.Add("-2", -2.0);
264 numberSet.Add("1", 1.0); 264 numberSet.Add("1", 1.0);
265 numberSet.Add("-1", -1.0); 265 numberSet.Add("-1", -1.0);
266 numberSet.Add("0", 0.0); 266 numberSet.Add("0", 0.0);
267 numberSet.Add("999999999.0", 999999999.0); 267 numberSet.Add("999999999.0", 999999999.0);
268 numberSet.Add("-99999999.0", -99999999.0); 268 numberSet.Add("-99999999.0", -99999999.0);
269 numberSet.Add("0.5", 0.5); 269 numberSet.Add("0.5", 0.5);
270 numberSet.Add("0.0005", 0.0005); 270 numberSet.Add("0.0005", 0.0005);
271 numberSet.Add("0.6805", 0.6805); 271 numberSet.Add("0.6805", 0.6805);
272 numberSet.Add("-0.5", -0.5); 272 numberSet.Add("-0.5", -0.5);
273 numberSet.Add("-0.0005", -0.0005); 273 numberSet.Add("-0.0005", -0.0005);
274 numberSet.Add("-0.6805", -0.6805); 274 numberSet.Add("-0.6805", -0.6805);
275 numberSet.Add("548.5", 548.5); 275 numberSet.Add("548.5", 548.5);
276 numberSet.Add("2.0005", 2.0005); 276 numberSet.Add("2.0005", 2.0005);
277 numberSet.Add("349485435.6805", 349485435.6805); 277 numberSet.Add("349485435.6805", 349485435.6805);
278 numberSet.Add("-548.5", -548.5); 278 numberSet.Add("-548.5", -548.5);
279 numberSet.Add("-2.0005", -2.0005); 279 numberSet.Add("-2.0005", -2.0005);
280 numberSet.Add("-349485435.6805", -349485435.6805); 280 numberSet.Add("-349485435.6805", -349485435.6805);
281 281
282 LSL_Types.LSLFloat testFloat; 282 LSL_Types.LSLFloat testFloat;
283 283
284 foreach(KeyValuePair<string, double> number in numberSet) 284 foreach(KeyValuePair<string, double> number in numberSet)
285 { 285 {
286 testFloat = number.Key; 286 testFloat = number.Key;
287 Assert.That(testFloat.value, new DoubleToleranceConstraint(number.Value, _lowPrecisionTolerance)); 287 Assert.That(testFloat.value, new DoubleToleranceConstraint(number.Value, _lowPrecisionTolerance));
288 } 288 }
289 } 289 }
290 290
291 /// <summary> 291 /// <summary>
292 /// Tests double is correctly cast implicitly to LSLFloat. 292 /// Tests double is correctly cast implicitly to LSLFloat.
293 /// </summary> 293 /// </summary>
294 [Test] 294 [Test]
295 public void TestImplicitCastDoubleToLSLFloat() 295 public void TestImplicitCastDoubleToLSLFloat()
296 { 296 {
297 // A bunch of numbers to test with. 297 // A bunch of numbers to test with.
298 List<double> numberList = new List<double>(); 298 List<double> numberList = new List<double>();
299 numberList.Add(2.0); 299 numberList.Add(2.0);
300 numberList.Add(-2.0); 300 numberList.Add(-2.0);
301 numberList.Add(1.0); 301 numberList.Add(1.0);
302 numberList.Add(-1.0); 302 numberList.Add(-1.0);
303 numberList.Add(0.0); 303 numberList.Add(0.0);
304 numberList.Add(999999999.0); 304 numberList.Add(999999999.0);
305 numberList.Add(-99999999.0); 305 numberList.Add(-99999999.0);
306 numberList.Add(0.5); 306 numberList.Add(0.5);
307 numberList.Add(0.0005); 307 numberList.Add(0.0005);
308 numberList.Add(0.6805); 308 numberList.Add(0.6805);
309 numberList.Add(-0.5); 309 numberList.Add(-0.5);
310 numberList.Add(-0.0005); 310 numberList.Add(-0.0005);
311 numberList.Add(-0.6805); 311 numberList.Add(-0.6805);
312 numberList.Add(548.5); 312 numberList.Add(548.5);
313 numberList.Add(2.0005); 313 numberList.Add(2.0005);
314 numberList.Add(349485435.6805); 314 numberList.Add(349485435.6805);
315 numberList.Add(-548.5); 315 numberList.Add(-548.5);
316 numberList.Add(-2.0005); 316 numberList.Add(-2.0005);
317 numberList.Add(-349485435.6805); 317 numberList.Add(-349485435.6805);
318 318
319 LSL_Types.LSLFloat testFloat; 319 LSL_Types.LSLFloat testFloat;
320 320
321 foreach(double number in numberList) 321 foreach(double number in numberList)
322 { 322 {
323 testFloat = number; 323 testFloat = number;
324 Assert.That(testFloat.value, new DoubleToleranceConstraint(number, _lowPrecisionTolerance)); 324 Assert.That(testFloat.value, new DoubleToleranceConstraint(number, _lowPrecisionTolerance));
325 } 325 }
326 } 326 }
327 327
328 /// <summary> 328 /// <summary>
329 /// Tests the equality (==) operator. 329 /// Tests the equality (==) operator.
330 /// </summary> 330 /// </summary>
331 [Test] 331 [Test]
332 public void TestEqualsOperator() 332 public void TestEqualsOperator()
333 { 333 {
334 // A bunch of numbers to test with. 334 // A bunch of numbers to test with.
335 List<double> numberList = new List<double>(); 335 List<double> numberList = new List<double>();
336 numberList.Add(2.0); 336 numberList.Add(2.0);
337 numberList.Add(-2.0); 337 numberList.Add(-2.0);
338 numberList.Add(1.0); 338 numberList.Add(1.0);
339 numberList.Add(-1.0); 339 numberList.Add(-1.0);
340 numberList.Add(0.0); 340 numberList.Add(0.0);
341 numberList.Add(999999999.0); 341 numberList.Add(999999999.0);
342 numberList.Add(-99999999.0); 342 numberList.Add(-99999999.0);
343 numberList.Add(0.5); 343 numberList.Add(0.5);
344 numberList.Add(0.0005); 344 numberList.Add(0.0005);
345 numberList.Add(0.6805); 345 numberList.Add(0.6805);
346 numberList.Add(-0.5); 346 numberList.Add(-0.5);
347 numberList.Add(-0.0005); 347 numberList.Add(-0.0005);
348 numberList.Add(-0.6805); 348 numberList.Add(-0.6805);
349 numberList.Add(548.5); 349 numberList.Add(548.5);
350 numberList.Add(2.0005); 350 numberList.Add(2.0005);
351 numberList.Add(349485435.6805); 351 numberList.Add(349485435.6805);
352 numberList.Add(-548.5); 352 numberList.Add(-548.5);
353 numberList.Add(-2.0005); 353 numberList.Add(-2.0005);
354 numberList.Add(-349485435.6805); 354 numberList.Add(-349485435.6805);
355 355
356 LSL_Types.LSLFloat testFloatA, testFloatB; 356 LSL_Types.LSLFloat testFloatA, testFloatB;
357 357
358 foreach(double number in numberList) 358 foreach(double number in numberList)
359 { 359 {
360 testFloatA = new LSL_Types.LSLFloat(number); 360 testFloatA = new LSL_Types.LSLFloat(number);
361 testFloatB = new LSL_Types.LSLFloat(number); 361 testFloatB = new LSL_Types.LSLFloat(number);
362 Assert.IsTrue(testFloatA == testFloatB); 362 Assert.IsTrue(testFloatA == testFloatB);
363 363
364 testFloatB = new LSL_Types.LSLFloat(number + 1.0); 364 testFloatB = new LSL_Types.LSLFloat(number + 1.0);
365 Assert.IsFalse(testFloatA == testFloatB); 365 Assert.IsFalse(testFloatA == testFloatB);
366 } 366 }
367 } 367 }
368 368
369 /// <summary> 369 /// <summary>
370 /// Tests the inequality (!=) operator. 370 /// Tests the inequality (!=) operator.
371 /// </summary> 371 /// </summary>
372 [Test] 372 [Test]
373 public void TestNotEqualOperator() 373 public void TestNotEqualOperator()
374 { 374 {
375 // A bunch of numbers to test with. 375 // A bunch of numbers to test with.
376 List<double> numberList = new List<double>(); 376 List<double> numberList = new List<double>();
377 numberList.Add(2.0); 377 numberList.Add(2.0);
378 numberList.Add(-2.0); 378 numberList.Add(-2.0);
379 numberList.Add(1.0); 379 numberList.Add(1.0);
380 numberList.Add(-1.0); 380 numberList.Add(-1.0);
381 numberList.Add(0.0); 381 numberList.Add(0.0);
382 numberList.Add(999999999.0); 382 numberList.Add(999999999.0);
383 numberList.Add(-99999999.0); 383 numberList.Add(-99999999.0);
384 numberList.Add(0.5); 384 numberList.Add(0.5);
385 numberList.Add(0.0005); 385 numberList.Add(0.0005);
386 numberList.Add(0.6805); 386 numberList.Add(0.6805);
387 numberList.Add(-0.5); 387 numberList.Add(-0.5);
388 numberList.Add(-0.0005); 388 numberList.Add(-0.0005);
389 numberList.Add(-0.6805); 389 numberList.Add(-0.6805);
390 numberList.Add(548.5); 390 numberList.Add(548.5);
391 numberList.Add(2.0005); 391 numberList.Add(2.0005);
392 numberList.Add(349485435.6805); 392 numberList.Add(349485435.6805);
393 numberList.Add(-548.5); 393 numberList.Add(-548.5);
394 numberList.Add(-2.0005); 394 numberList.Add(-2.0005);
395 numberList.Add(-349485435.6805); 395 numberList.Add(-349485435.6805);
396 396
397 LSL_Types.LSLFloat testFloatA, testFloatB; 397 LSL_Types.LSLFloat testFloatA, testFloatB;
398 398
399 foreach(double number in numberList) 399 foreach(double number in numberList)
400 { 400 {
401 testFloatA = new LSL_Types.LSLFloat(number); 401 testFloatA = new LSL_Types.LSLFloat(number);
402 testFloatB = new LSL_Types.LSLFloat(number + 1.0); 402 testFloatB = new LSL_Types.LSLFloat(number + 1.0);
403 Assert.IsTrue(testFloatA != testFloatB); 403 Assert.IsTrue(testFloatA != testFloatB);
404 404
405 testFloatB = new LSL_Types.LSLFloat(number); 405 testFloatB = new LSL_Types.LSLFloat(number);
406 Assert.IsFalse(testFloatA != testFloatB); 406 Assert.IsFalse(testFloatA != testFloatB);
407 } 407 }
408 } 408 }
409 409
410 /// <summary> 410 /// <summary>
411 /// Tests the increment operator. 411 /// Tests the increment operator.
412 /// </summary> 412 /// </summary>
413 [Test] 413 [Test]
414 public void TestIncrementOperator() 414 public void TestIncrementOperator()
415 { 415 {
416 // A bunch of numbers to test with. 416 // A bunch of numbers to test with.
417 List<double> numberList = new List<double>(); 417 List<double> numberList = new List<double>();
418 numberList.Add(2.0); 418 numberList.Add(2.0);
419 numberList.Add(-2.0); 419 numberList.Add(-2.0);
420 numberList.Add(1.0); 420 numberList.Add(1.0);
421 numberList.Add(-1.0); 421 numberList.Add(-1.0);
422 numberList.Add(0.0); 422 numberList.Add(0.0);
423 numberList.Add(999999999.0); 423 numberList.Add(999999999.0);
424 numberList.Add(-99999999.0); 424 numberList.Add(-99999999.0);
425 numberList.Add(0.5); 425 numberList.Add(0.5);
426 numberList.Add(0.0005); 426 numberList.Add(0.0005);
427 numberList.Add(0.6805); 427 numberList.Add(0.6805);
428 numberList.Add(-0.5); 428 numberList.Add(-0.5);
429 numberList.Add(-0.0005); 429 numberList.Add(-0.0005);
430 numberList.Add(-0.6805); 430 numberList.Add(-0.6805);
431 numberList.Add(548.5); 431 numberList.Add(548.5);
432 numberList.Add(2.0005); 432 numberList.Add(2.0005);
433 numberList.Add(349485435.6805); 433 numberList.Add(349485435.6805);
434 numberList.Add(-548.5); 434 numberList.Add(-548.5);
435 numberList.Add(-2.0005); 435 numberList.Add(-2.0005);
436 numberList.Add(-349485435.6805); 436 numberList.Add(-349485435.6805);
437 437
438 LSL_Types.LSLFloat testFloat; 438 LSL_Types.LSLFloat testFloat;
439 double testNumber; 439 double testNumber;
440 440
441 foreach(double number in numberList) 441 foreach(double number in numberList)
442 { 442 {
443 testFloat = new LSL_Types.LSLFloat(number); 443 testFloat = new LSL_Types.LSLFloat(number);
444 444
445 testNumber = testFloat++; 445 testNumber = testFloat++;
446 Assert.That(testNumber, new DoubleToleranceConstraint(number, _lowPrecisionTolerance)); 446 Assert.That(testNumber, new DoubleToleranceConstraint(number, _lowPrecisionTolerance));
447 447
448 testNumber = testFloat; 448 testNumber = testFloat;
449 Assert.That(testNumber, new DoubleToleranceConstraint(number + 1.0, _lowPrecisionTolerance)); 449 Assert.That(testNumber, new DoubleToleranceConstraint(number + 1.0, _lowPrecisionTolerance));
450 450
451 testNumber = ++testFloat; 451 testNumber = ++testFloat;
452 Assert.That(testNumber, new DoubleToleranceConstraint(number + 2.0, _lowPrecisionTolerance)); 452 Assert.That(testNumber, new DoubleToleranceConstraint(number + 2.0, _lowPrecisionTolerance));
453 } 453 }
454 } 454 }
455 455
456 /// <summary> 456 /// <summary>
457 /// Tests the decrement operator. 457 /// Tests the decrement operator.
458 /// </summary> 458 /// </summary>
459 [Test] 459 [Test]
460 public void TestDecrementOperator() 460 public void TestDecrementOperator()
461 { 461 {
462 // A bunch of numbers to test with. 462 // A bunch of numbers to test with.
463 List<double> numberList = new List<double>(); 463 List<double> numberList = new List<double>();
464 numberList.Add(2.0); 464 numberList.Add(2.0);
465 numberList.Add(-2.0); 465 numberList.Add(-2.0);
466 numberList.Add(1.0); 466 numberList.Add(1.0);
467 numberList.Add(-1.0); 467 numberList.Add(-1.0);
468 numberList.Add(0.0); 468 numberList.Add(0.0);
469 numberList.Add(999999999.0); 469 numberList.Add(999999999.0);
470 numberList.Add(-99999999.0); 470 numberList.Add(-99999999.0);
471 numberList.Add(0.5); 471 numberList.Add(0.5);
472 numberList.Add(0.0005); 472 numberList.Add(0.0005);
473 numberList.Add(0.6805); 473 numberList.Add(0.6805);
474 numberList.Add(-0.5); 474 numberList.Add(-0.5);
475 numberList.Add(-0.0005); 475 numberList.Add(-0.0005);
476 numberList.Add(-0.6805); 476 numberList.Add(-0.6805);
477 numberList.Add(548.5); 477 numberList.Add(548.5);
478 numberList.Add(2.0005); 478 numberList.Add(2.0005);
479 numberList.Add(349485435.6805); 479 numberList.Add(349485435.6805);
480 numberList.Add(-548.5); 480 numberList.Add(-548.5);
481 numberList.Add(-2.0005); 481 numberList.Add(-2.0005);
482 numberList.Add(-349485435.6805); 482 numberList.Add(-349485435.6805);
483 483
484 LSL_Types.LSLFloat testFloat; 484 LSL_Types.LSLFloat testFloat;
485 double testNumber; 485 double testNumber;
486 486
487 foreach(double number in numberList) 487 foreach(double number in numberList)
488 { 488 {
489 testFloat = new LSL_Types.LSLFloat(number); 489 testFloat = new LSL_Types.LSLFloat(number);
490 490
491 testNumber = testFloat--; 491 testNumber = testFloat--;
492 Assert.That(testNumber, new DoubleToleranceConstraint(number, _lowPrecisionTolerance)); 492 Assert.That(testNumber, new DoubleToleranceConstraint(number, _lowPrecisionTolerance));
493 493
494 testNumber = testFloat; 494 testNumber = testFloat;
495 Assert.That(testNumber, new DoubleToleranceConstraint(number - 1.0, _lowPrecisionTolerance)); 495 Assert.That(testNumber, new DoubleToleranceConstraint(number - 1.0, _lowPrecisionTolerance));
496 496
497 testNumber = --testFloat; 497 testNumber = --testFloat;
498 Assert.That(testNumber, new DoubleToleranceConstraint(number - 2.0, _lowPrecisionTolerance)); 498 Assert.That(testNumber, new DoubleToleranceConstraint(number - 2.0, _lowPrecisionTolerance));
499 } 499 }
500 } 500 }
501 501
502 /// <summary> 502 /// <summary>
503 /// Tests LSLFloat is correctly cast implicitly to double. 503 /// Tests LSLFloat is correctly cast implicitly to double.
504 /// </summary> 504 /// </summary>
505 [Test] 505 [Test]
506 public void TestImplicitCastLSLFloatToDouble() 506 public void TestImplicitCastLSLFloatToDouble()
507 { 507 {
508 // A bunch of numbers to test with. 508 // A bunch of numbers to test with.
509 List<double> numberList = new List<double>(); 509 List<double> numberList = new List<double>();
510 numberList.Add(2.0); 510 numberList.Add(2.0);
511 numberList.Add(-2.0); 511 numberList.Add(-2.0);
512 numberList.Add(1.0); 512 numberList.Add(1.0);
513 numberList.Add(-1.0); 513 numberList.Add(-1.0);
514 numberList.Add(0.0); 514 numberList.Add(0.0);
515 numberList.Add(999999999.0); 515 numberList.Add(999999999.0);
516 numberList.Add(-99999999.0); 516 numberList.Add(-99999999.0);
517 numberList.Add(0.5); 517 numberList.Add(0.5);
518 numberList.Add(0.0005); 518 numberList.Add(0.0005);
519 numberList.Add(0.6805); 519 numberList.Add(0.6805);
520 numberList.Add(-0.5); 520 numberList.Add(-0.5);
521 numberList.Add(-0.0005); 521 numberList.Add(-0.0005);
522 numberList.Add(-0.6805); 522 numberList.Add(-0.6805);
523 numberList.Add(548.5); 523 numberList.Add(548.5);
524 numberList.Add(2.0005); 524 numberList.Add(2.0005);
525 numberList.Add(349485435.6805); 525 numberList.Add(349485435.6805);
526 numberList.Add(-548.5); 526 numberList.Add(-548.5);
527 numberList.Add(-2.0005); 527 numberList.Add(-2.0005);
528 numberList.Add(-349485435.6805); 528 numberList.Add(-349485435.6805);
529 529
530 double testNumber; 530 double testNumber;
531 LSL_Types.LSLFloat testFloat; 531 LSL_Types.LSLFloat testFloat;
532 532
533 foreach(double number in numberList) 533 foreach(double number in numberList)
534 { 534 {
535 testFloat = new LSL_Types.LSLFloat(number); 535 testFloat = new LSL_Types.LSLFloat(number);
536 testNumber = testFloat; 536 testNumber = testFloat;
537 537
538 Assert.That(testNumber, new DoubleToleranceConstraint(number, _lowPrecisionTolerance)); 538 Assert.That(testNumber, new DoubleToleranceConstraint(number, _lowPrecisionTolerance));
539 } 539 }
540 } 540 }
541 541
542 /// <summary> 542 /// <summary>
543 /// Tests LSLFloat.ToString(). 543 /// Tests LSLFloat.ToString().
544 /// </summary> 544 /// </summary>
545 [Test] 545 [Test]
546 public void TestToString() 546 public void TestToString()
547 { 547 {
548 // A bunch of numbers to test with. 548 // A bunch of numbers to test with.
549 Dictionary<double, string> numberSet = new Dictionary<double, string>(); 549 Dictionary<double, string> numberSet = new Dictionary<double, string>();
550 numberSet.Add(2.0, "2.000000"); 550 numberSet.Add(2.0, "2.000000");
551 numberSet.Add(-2.0, "-2.000000"); 551 numberSet.Add(-2.0, "-2.000000");
552 numberSet.Add(1.0, "1.000000"); 552 numberSet.Add(1.0, "1.000000");
553 numberSet.Add(-1.0, "-1.000000"); 553 numberSet.Add(-1.0, "-1.000000");
554 numberSet.Add(0.0, "0.000000"); 554 numberSet.Add(0.0, "0.000000");
555 numberSet.Add(999999999.0, "999999999.000000"); 555 numberSet.Add(999999999.0, "999999999.000000");
556 numberSet.Add(-99999999.0, "-99999999.000000"); 556 numberSet.Add(-99999999.0, "-99999999.000000");
557 numberSet.Add(0.5, "0.500000"); 557 numberSet.Add(0.5, "0.500000");
558 numberSet.Add(0.0005, "0.000500"); 558 numberSet.Add(0.0005, "0.000500");
559 numberSet.Add(0.6805, "0.680500"); 559 numberSet.Add(0.6805, "0.680500");
560 numberSet.Add(-0.5, "-0.500000"); 560 numberSet.Add(-0.5, "-0.500000");
561 numberSet.Add(-0.0005, "-0.000500"); 561 numberSet.Add(-0.0005, "-0.000500");
562 numberSet.Add(-0.6805, "-0.680500"); 562 numberSet.Add(-0.6805, "-0.680500");
563 numberSet.Add(548.5, "548.500000"); 563 numberSet.Add(548.5, "548.500000");
564 numberSet.Add(2.0005, "2.000500"); 564 numberSet.Add(2.0005, "2.000500");
565 numberSet.Add(349485435.6805, "349485435.680500"); 565 numberSet.Add(349485435.6805, "349485435.680500");
566 numberSet.Add(-548.5, "-548.500000"); 566 numberSet.Add(-548.5, "-548.500000");
567 numberSet.Add(-2.0005, "-2.000500"); 567 numberSet.Add(-2.0005, "-2.000500");
568 numberSet.Add(-349485435.6805, "-349485435.680500"); 568 numberSet.Add(-349485435.6805, "-349485435.680500");
569 569
570 LSL_Types.LSLFloat testFloat; 570 LSL_Types.LSLFloat testFloat;
571 571
572 foreach(KeyValuePair<double, string> number in numberSet) 572 foreach(KeyValuePair<double, string> number in numberSet)
573 { 573 {
574 testFloat = new LSL_Types.LSLFloat(number.Key); 574 testFloat = new LSL_Types.LSLFloat(number.Key);
575 Assert.AreEqual(number.Value, testFloat.ToString()); 575 Assert.AreEqual(number.Value, testFloat.ToString());
576 } 576 }
577 } 577 }
578 } 578 }
579} 579}
diff --git a/OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLString.cs b/OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLString.cs
index 615c045..83c7e77 100644
--- a/OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLString.cs
+++ b/OpenSim/Tests/OpenSim/Region/ScriptEngine/LSL_TypesTestLSLString.cs
@@ -1,112 +1,112 @@
1/* 1/*
2 * Copyright (c) Contributors, http://opensimulator.org/ 2 * Copyright (c) Contributors, http://opensimulator.org/
3 * See CONTRIBUTORS.TXT for a full list of copyright holders. 3 * See CONTRIBUTORS.TXT for a full list of copyright holders.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met: 6 * modification, are permitted provided that the following conditions are met:
7 * * Redistributions of source code must retain the above copyright 7 * * Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * * Redistributions in binary form must reproduce the above copyright 9 * * Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution. 11 * documentation and/or other materials provided with the distribution.
12 * * Neither the name of the OpenSim Project nor the 12 * * Neither the name of the OpenSim Project nor the
13 * names of its contributors may be used to endorse or promote products 13 * names of its contributors may be used to endorse or promote products
14 * derived from this software without specific prior written permission. 14 * derived from this software without specific prior written permission.
15 * 15 *
16 * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY 16 * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 17 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 18 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19 * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY 19 * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
20 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 20 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 21 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 22 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 23 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 24 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 25 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 */ 26 */
27 27
28using System.Collections.Generic; 28using System.Collections.Generic;
29using NUnit.Framework; 29using NUnit.Framework;
30using OpenSim.Tests.Common; 30using OpenSim.Tests.Common;
31using OpenSim.Region.ScriptEngine.Common; 31using OpenSim.Region.ScriptEngine.Common;
32 32
33namespace OpenSim.Region.ScriptEngine.Common.Tests 33namespace OpenSim.Region.ScriptEngine.Common.Tests
34{ 34{
35 [TestFixture] 35 [TestFixture]
36 public class LSL_TypesTestLSLString 36 public class LSL_TypesTestLSLString
37 { 37 {
38 /// <summary> 38 /// <summary>
39 /// Tests constructing a LSLString from an LSLFloat. 39 /// Tests constructing a LSLString from an LSLFloat.
40 /// </summary> 40 /// </summary>
41 [Test] 41 [Test]
42 public void TestConstructFromLSLFloat() 42 public void TestConstructFromLSLFloat()
43 { 43 {
44 // The numbers we test for. 44 // The numbers we test for.
45 Dictionary<double, string> numberSet = new Dictionary<double, string>(); 45 Dictionary<double, string> numberSet = new Dictionary<double, string>();
46 numberSet.Add(2, "2.000000"); 46 numberSet.Add(2, "2.000000");
47 numberSet.Add(-2, "-2.000000"); 47 numberSet.Add(-2, "-2.000000");
48 numberSet.Add(0, "0.000000"); 48 numberSet.Add(0, "0.000000");
49 numberSet.Add(1, "1.000000"); 49 numberSet.Add(1, "1.000000");
50 numberSet.Add(-1, "-1.000000"); 50 numberSet.Add(-1, "-1.000000");
51 numberSet.Add(999999999, "999999999.000000"); 51 numberSet.Add(999999999, "999999999.000000");
52 numberSet.Add(-99999999, "-99999999.000000"); 52 numberSet.Add(-99999999, "-99999999.000000");
53 numberSet.Add(0.5, "0.500000"); 53 numberSet.Add(0.5, "0.500000");
54 numberSet.Add(0.0005, "0.000500"); 54 numberSet.Add(0.0005, "0.000500");
55 numberSet.Add(0.6805, "0.680500"); 55 numberSet.Add(0.6805, "0.680500");
56 numberSet.Add(-0.5, "-0.500000"); 56 numberSet.Add(-0.5, "-0.500000");
57 numberSet.Add(-0.0005, "-0.000500"); 57 numberSet.Add(-0.0005, "-0.000500");
58 numberSet.Add(-0.6805, "-0.680500"); 58 numberSet.Add(-0.6805, "-0.680500");
59 numberSet.Add(548.5, "548.500000"); 59 numberSet.Add(548.5, "548.500000");
60 numberSet.Add(2.0005, "2.000500"); 60 numberSet.Add(2.0005, "2.000500");
61 numberSet.Add(349485435.6805, "349485435.680500"); 61 numberSet.Add(349485435.6805, "349485435.680500");
62 numberSet.Add(-548.5, "-548.500000"); 62 numberSet.Add(-548.5, "-548.500000");
63 numberSet.Add(-2.0005, "-2.000500"); 63 numberSet.Add(-2.0005, "-2.000500");
64 numberSet.Add(-349485435.6805, "-349485435.680500"); 64 numberSet.Add(-349485435.6805, "-349485435.680500");
65 65
66 LSL_Types.LSLString testString; 66 LSL_Types.LSLString testString;
67 67
68 foreach(KeyValuePair<double, string> number in numberSet) 68 foreach(KeyValuePair<double, string> number in numberSet)
69 { 69 {
70 testString = new LSL_Types.LSLString(new LSL_Types.LSLFloat(number.Key)); 70 testString = new LSL_Types.LSLString(new LSL_Types.LSLFloat(number.Key));
71 Assert.AreEqual(number.Value, testString.m_string); 71 Assert.AreEqual(number.Value, testString.m_string);
72 } 72 }
73 } 73 }
74 74
75 /// <summary> 75 /// <summary>
76 /// Tests constructing a LSLString from an LSLFloat. 76 /// Tests constructing a LSLString from an LSLFloat.
77 /// </summary> 77 /// </summary>
78 [Test] 78 [Test]
79 public void TestExplicitCastLSLFloatToLSLString() 79 public void TestExplicitCastLSLFloatToLSLString()
80 { 80 {
81 // The numbers we test for. 81 // The numbers we test for.
82 Dictionary<double, string> numberSet = new Dictionary<double, string>(); 82 Dictionary<double, string> numberSet = new Dictionary<double, string>();
83 numberSet.Add(2, "2.000000"); 83 numberSet.Add(2, "2.000000");
84 numberSet.Add(-2, "-2.000000"); 84 numberSet.Add(-2, "-2.000000");
85 numberSet.Add(0, "0.000000"); 85 numberSet.Add(0, "0.000000");
86 numberSet.Add(1, "1.000000"); 86 numberSet.Add(1, "1.000000");
87 numberSet.Add(-1, "-1.000000"); 87 numberSet.Add(-1, "-1.000000");
88 numberSet.Add(999999999, "999999999.000000"); 88 numberSet.Add(999999999, "999999999.000000");
89 numberSet.Add(-99999999, "-99999999.000000"); 89 numberSet.Add(-99999999, "-99999999.000000");
90 numberSet.Add(0.5, "0.500000"); 90 numberSet.Add(0.5, "0.500000");
91 numberSet.Add(0.0005, "0.000500"); 91 numberSet.Add(0.0005, "0.000500");
92 numberSet.Add(0.6805, "0.680500"); 92 numberSet.Add(0.6805, "0.680500");
93 numberSet.Add(-0.5, "-0.500000"); 93 numberSet.Add(-0.5, "-0.500000");
94 numberSet.Add(-0.0005, "-0.000500"); 94 numberSet.Add(-0.0005, "-0.000500");
95 numberSet.Add(-0.6805, "-0.680500"); 95 numberSet.Add(-0.6805, "-0.680500");
96 numberSet.Add(548.5, "548.500000"); 96 numberSet.Add(548.5, "548.500000");
97 numberSet.Add(2.0005, "2.000500"); 97 numberSet.Add(2.0005, "2.000500");
98 numberSet.Add(349485435.6805, "349485435.680500"); 98 numberSet.Add(349485435.6805, "349485435.680500");
99 numberSet.Add(-548.5, "-548.500000"); 99 numberSet.Add(-548.5, "-548.500000");
100 numberSet.Add(-2.0005, "-2.000500"); 100 numberSet.Add(-2.0005, "-2.000500");
101 numberSet.Add(-349485435.6805, "-349485435.680500"); 101 numberSet.Add(-349485435.6805, "-349485435.680500");
102 102
103 LSL_Types.LSLString testString; 103 LSL_Types.LSLString testString;
104 104
105 foreach(KeyValuePair<double, string> number in numberSet) 105 foreach(KeyValuePair<double, string> number in numberSet)
106 { 106 {
107 testString = (LSL_Types.LSLString) new LSL_Types.LSLFloat(number.Key); 107 testString = (LSL_Types.LSLString) new LSL_Types.LSLFloat(number.Key);
108 Assert.AreEqual(number.Value, testString.m_string); 108 Assert.AreEqual(number.Value, testString.m_string);
109 } 109 }
110 } 110 }
111 } 111 }
112} 112}