From 2b83169c4b0972752c22c1e69462a01225f1745e Mon Sep 17 00:00:00 2001 From: Mike Mazur Date: Wed, 20 Aug 2008 06:09:11 +0000 Subject: [PATCH] Adding unit test for issue 2006, though it's commented out as those compiler tests tend to tank on our continuous build server. --- .../Shared/CodeTools/CompilerTest.cs | 35 ++++++++++++++++++- 1 file changed, 34 insertions(+), 1 deletion(-) diff --git a/OpenSim/Tests/OpenSim/Region/ScriptEngine/Shared/CodeTools/CompilerTest.cs b/OpenSim/Tests/OpenSim/Region/ScriptEngine/Shared/CodeTools/CompilerTest.cs index 43e314374a..7725d8dbe7 100644 --- a/OpenSim/Tests/OpenSim/Region/ScriptEngine/Shared/CodeTools/CompilerTest.cs +++ b/OpenSim/Tests/OpenSim/Region/ScriptEngine/Shared/CodeTools/CompilerTest.cs @@ -85,11 +85,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools.Tests } } - //[Test] /// /// Test the C# compiler error message can be mapped to the correct /// line/column in the LSL source when an undeclared variable is used. /// + //[Test] public void TestUseUndeclaredVariable() { m_compilerParameters.OutputAssembly = Path.Combine(m_testDir, Path.GetRandomFileName() + ".dll"); @@ -116,5 +116,38 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools.Tests Assert.AreEqual(new KeyValuePair(5, 21), positionMap[new KeyValuePair(m_compilerResults.Errors[0].Line, m_compilerResults.Errors[0].Column)]); } + + /// + /// Test that a string can be cast to string and another string + /// concatenated. + /// + //[Test] + public void TestCastAndConcatString() + { + m_compilerParameters.OutputAssembly = Path.Combine(m_testDir, Path.GetRandomFileName() + ".dll"); + + string input = @"string s = "" a string""; + +default +{ + state_entry() + { + key gAvatarKey = llDetectedKey(0); + string tmp = (string) gAvatarKey + s; + llSay(0, tmp); + } +}"; + + CSCodeGenerator cg = new CSCodeGenerator(); + string output = "using OpenSim.Region.ScriptEngine.Shared; using System.Collections.Generic;\n" + + "namespace SecondLife { " + + "public class Script : OpenSim.Region.ScriptEngine.Shared.ScriptBase.ScriptBaseClass {\n" + + "public Script() { } " + + cg.Convert(input) + + "} }\n"; + m_compilerResults = m_CSCodeProvider.CompileAssemblyFromSource(m_compilerParameters, output); + + Assert.AreEqual(0, m_compilerResults.Errors.Count); + } } }