Imported Upstream version 3.6.0

Former-commit-id: da6be194a6b1221998fc28233f2503bd61dd9d14
This commit is contained in:
Jo Shields
2014-08-13 10:39:27 +01:00
commit a575963da9
50588 changed files with 8155799 additions and 0 deletions

View File

@@ -0,0 +1,50 @@
2008-08-06 Ankit Jain <jankit@novell.com>
* CommandLineBuilderTest.cs: Add more tests.
2008-07-31 Ankit Jain <jankit@novell.com>
* CommandLineBuilderTest.cs: Add more tests.
2007-05-16 Marek Sieradzki <marek.sieradzki@gmail.com>
* CommandLineBuilderTest.cs: Added tests for filenames that contain
spaces.
2006-12-19 Marek Sieradzki <marek.sieradzki@gmail.com>
* CommandLineBuilderTest.cs, TaskItemTest.cs: More tests.
* LoggerTest.cs: Added.
2006-12-18 Marek Sieradzki <marek.sieradzki@gmail.com>
* TaskLoggingHelperTest.cs, CommandLineBuilderTest.cs: Removed Ignore.
2006-10-06 Marek Sieradzki <marek.sieradzki@gmail.com>
* TaskLoggingHelperTest.cs:
* CommandLineBuilderTest.cs: Added [Ignore].
2006-09-02 Marek Sieradzki <marek.sieradzki@gmail.com>
* TaskItemTest.cs: Fixed TestCloneCustomMetadata ().
2006-05-26 Marek Sieradzki <marek.sieradzki@gmail.com>
* CommandLineBuilderTest.cs: Added tests for
VerifyThrowNoEmbeddedQuotes () and IsQuotingRequired ().
2006-04-24 Marek Sieradzki <marek.sieradzki@gmail.com>
* TaskLoggingHelperTest.cs: Added new tests.
2006-03-29 Crestez Leonard <cdleonard@gmail.com>
* TaskItemTest.cs: Added new tests.
2006-03-11 Marek Sieradzki <marek.sieradzki@gmail.com>
* CommandLineBuilderTest.cs: Added.
* TaskItemTest.cs: Added new test.

View File

@@ -0,0 +1,383 @@
//
// TaskLoggingHelperTest.cs
//
// Author:
// Marek Sieradzki (marek.sieradzki@gmail.com)
//
// (C) 2005 Marek Sieradzki
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
using System;
using System.Collections;
using Microsoft.Build.Framework;
using Microsoft.Build.Utilities;
using NUnit.Framework;
namespace MonoTests.Microsoft.Build.Utilities {
class LoggerExtension : Logger {
public LoggerExtension () : base () { }
public override void Initialize (IEventSource eventSource)
{
}
}
[TestFixture]
public class LoggerTest {
[Test]
public void TestAssignment ()
{
LoggerExtension le = new LoggerExtension ();
Assert.IsNull (le.Parameters, "A1");
Assert.AreEqual (LoggerVerbosity.Quiet, le.Verbosity, "A2");
le.Parameters = "a;b";
le.Verbosity = LoggerVerbosity.Detailed;
Assert.AreEqual ("a;b", le.Parameters, "A3");
Assert.AreEqual (LoggerVerbosity.Detailed, le.Verbosity, "A4");
}
[Test]
public void TestFormatErrorEvent1 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 1;
int columnNumber = 2;
int endLineNumber = 3;
int endColumnNumber = 4;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildErrorEventArgs beea = new BuildErrorEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file(1,2,3,4): subcategory error code: message", le.FormatErrorEvent (beea), "A1");
}
[Test]
public void TestFormatErrorEvent2 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 1;
int columnNumber = 0;
int endLineNumber = 0;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildErrorEventArgs beea = new BuildErrorEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file(1): subcategory error code: message", le.FormatErrorEvent (beea), "A1");
}
[Test]
public void TestFormatErrorEvent3 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 1;
int columnNumber = 2;
int endLineNumber = 0;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildErrorEventArgs beea = new BuildErrorEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file(1,2): subcategory error code: message", le.FormatErrorEvent (beea), "A1");
}
[Test]
public void TestFormatErrorEvent4 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 0;
int columnNumber = 0;
int endLineNumber = 0;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildErrorEventArgs beea = new BuildErrorEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file : subcategory error code: message", le.FormatErrorEvent (beea), "A1");
}
[Test]
public void TestFormatErrorEvent5 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 0;
int columnNumber = 0;
int endLineNumber = 1;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildErrorEventArgs beea = new BuildErrorEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file : subcategory error code: message", le.FormatErrorEvent (beea), "A1");
}
[Test]
public void TestFormatErrorEvent6 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 0;
int columnNumber = 0;
int endLineNumber = 0;
int endColumnNumber = 1;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildErrorEventArgs beea = new BuildErrorEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file : subcategory error code: message", le.FormatErrorEvent (beea), "A1");
}
[Test]
public void TestFormatErrorEvent7 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 0;
int columnNumber = 1;
int endLineNumber = 0;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildErrorEventArgs beea = new BuildErrorEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file : subcategory error code: message", le.FormatErrorEvent (beea), "A1");
}
[Test]
public void TestFormatWarningEvent1 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 1;
int columnNumber = 2;
int endLineNumber = 3;
int endColumnNumber = 4;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildWarningEventArgs beea = new BuildWarningEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file(1,2,3,4): subcategory warning code: message", le.FormatWarningEvent (beea), "A1");
}
[Test]
public void TestFormatWarningEvent2 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 1;
int columnNumber = 0;
int endLineNumber = 0;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildWarningEventArgs beea = new BuildWarningEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file(1): subcategory warning code: message", le.FormatWarningEvent (beea), "A1");
}
[Test]
public void TestFormatWarningEvent3 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 1;
int columnNumber = 2;
int endLineNumber = 0;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildWarningEventArgs beea = new BuildWarningEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file(1,2): subcategory warning code: message", le.FormatWarningEvent (beea), "A1");
}
[Test]
public void TestFormatWarningEvent4 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 0;
int columnNumber = 0;
int endLineNumber = 0;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildWarningEventArgs beea = new BuildWarningEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file : subcategory warning code: message", le.FormatWarningEvent (beea), "A1");
}
[Test]
public void TestFormatWarningEvent5 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 0;
int columnNumber = 0;
int endLineNumber = 1;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildWarningEventArgs beea = new BuildWarningEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file : subcategory warning code: message", le.FormatWarningEvent (beea), "A1");
}
[Test]
public void TestFormatWarningEvent6 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 0;
int columnNumber = 0;
int endLineNumber = 0;
int endColumnNumber = 1;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildWarningEventArgs beea = new BuildWarningEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file : subcategory warning code: message", le.FormatWarningEvent (beea), "A1");
}
[Test]
public void TestFormatWarningEvent7 ()
{
LoggerExtension le = new LoggerExtension ();
string subcategory = "subcategory";
string code = "code";
string file = "file";
int lineNumber = 0;
int columnNumber = 1;
int endLineNumber = 0;
int endColumnNumber = 0;
string message = "message";
string helpKeyword = "helpKeyword";
string senderName = "senderName";
BuildWarningEventArgs beea = new BuildWarningEventArgs (
subcategory, code, file, lineNumber, columnNumber,
endLineNumber, endColumnNumber, message, helpKeyword, senderName);
Assert.AreEqual ("file : subcategory warning code: message", le.FormatWarningEvent (beea), "A1");
}
[Test]
public void TestIsVerbosityAtLeast ()
{
LoggerExtension le = new LoggerExtension ();
le.Verbosity = LoggerVerbosity.Quiet;
Assert.IsTrue (le.IsVerbosityAtLeast (LoggerVerbosity.Quiet), "A1");
Assert.IsFalse (le.IsVerbosityAtLeast (LoggerVerbosity.Minimal), "A2");
le.Verbosity = LoggerVerbosity.Minimal;
Assert.IsTrue (le.IsVerbosityAtLeast (LoggerVerbosity.Minimal), "A3");
Assert.IsFalse (le.IsVerbosityAtLeast (LoggerVerbosity.Normal), "A4");
le.Verbosity = LoggerVerbosity.Normal;
Assert.IsTrue (le.IsVerbosityAtLeast (LoggerVerbosity.Normal), "A5");
Assert.IsFalse (le.IsVerbosityAtLeast (LoggerVerbosity.Detailed), "A6");
le.Verbosity = LoggerVerbosity.Detailed;
Assert.IsTrue (le.IsVerbosityAtLeast (LoggerVerbosity.Detailed), "A7");
Assert.IsFalse (le.IsVerbosityAtLeast (LoggerVerbosity.Diagnostic), "A8");
}
}
}

View File

@@ -0,0 +1,303 @@
//
// TaskItemTest.cs:
//
// Author:
// Marek Sieradzki (marek.sieradzki@gmail.com)
//
// (C) 2005 Marek Sieradzki
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
using System;
using System.Collections;
using System.Collections.Specialized;
using System.IO;
using Microsoft.Build.Framework;
using Microsoft.Build.Utilities;
using NUnit.Framework;
namespace MonoTests.Microsoft.Build.Utilities {
[TestFixture]
public class TaskItemTest {
ITaskItem item,item1,item2;
ICollection metadataNames;
[SetUp]
public void SetUp ()
{
string[] temp = new string[] {"FullPath", "RootDir", "Filename", "Extension", "RelativeDir", "Directory",
"RecursiveDir", "Identity", "ModifiedTime", "CreatedTime", "AccessedTime"};
ArrayList al = new ArrayList ();
foreach (string s in temp)
al.Add (s);
metadataNames = al;
}
private bool CompareStringCollections (ICollection compared, ICollection reference)
{
Hashtable comparedHash;
comparedHash = CollectionsUtil.CreateCaseInsensitiveHashtable ();
foreach (string s in compared)
comparedHash.Add (s, null);
foreach (string s in reference) {
if (comparedHash.ContainsKey (s) == false) {
return false;
}
}
return true;
}
public void TestCloneCustomMetadata ()
{
item = new TaskItem ();
item.SetMetadata ("AAA", "111");
item.SetMetadata ("aaa", "222");
item.SetMetadata ("BBB", "111");
string [] metakeys = new string [] { "aaa", "BBB" };
IDictionary meta = item.CloneCustomMetadata ();
Assert.IsTrue (CompareStringCollections (meta.Keys, metakeys), "A1");
metakeys [0] = "aAa";
Assert.IsTrue (CompareStringCollections (meta.Keys, metakeys), "A2");
Assert.AreEqual ("222", meta ["aaa"], "A3");
Assert.AreEqual ("222", meta ["AAA"], "A4");
Assert.AreEqual ("222", meta ["aAa"], "A5");
Assert.AreEqual ("111", meta ["BbB"], "A5");
}
[Test]
[Ignore ("NRE on .NET 2.0")]
public void TestCtor1 ()
{
new TaskItem ((ITaskItem) null);
}
[Test]
[ExpectedException (typeof (ArgumentNullException))]
public void TestCtor2 ()
{
new TaskItem ((string) null);
}
[Test]
[ExpectedException (typeof (ArgumentNullException))]
public void TestCtor3 ()
{
new TaskItem ((string) null, new Hashtable ());
}
[Test]
[ExpectedException (typeof (ArgumentNullException))]
public void TestCtor4 ()
{
new TaskItem ("itemspec", null);
}
[Test]
public void TestCtor_EscapedSpecialChar ()
{
// If we instantiate with the *escaped* metadata, it's unescaped automatically
var metadata = "foo@2x.png";
var escapedMetadata = global::Microsoft.Build.BuildEngine.Utilities.Escape ("foo@2x.png");
var item = new TaskItem (escapedMetadata);
item.SetMetadata ("mine", escapedMetadata);
Assert.AreEqual (metadata, item.ItemSpec, "#1");
Assert.AreEqual (metadata, item.GetMetadata ("Identity"), "#2");
Assert.AreEqual (Path.GetFileNameWithoutExtension (metadata), item.GetMetadata ("FileName"), "#3");
Assert.IsTrue (item.GetMetadata ("FullPath").EndsWith (metadata), "#4");
Assert.AreEqual (metadata, item.GetMetadata ("mine"), "#5");
}
[Test]
public void TestCtor_EscapedSpecialChar_BrokenEscaping ()
{
// This is badly escaped, but MSBuild does not care.
var metadata = "foo%4@2x.png";
var item = new TaskItem (metadata);
Assert.AreEqual (metadata, item.ItemSpec, "#1");
Assert.AreEqual (metadata, item.GetMetadata ("Identity"), "#2");
Assert.AreEqual (Path.GetFileNameWithoutExtension (metadata), item.GetMetadata ("FileName"), "#3");
Assert.IsTrue (item.GetMetadata ("FullPath").EndsWith (metadata), "#4");
}
[Test]
public void TestCtor_UnescapedSpecialChar ()
{
// If we instantiate with unescaped metadata, we get the same value back
var metadata = "foo@2x.png";
var item = new TaskItem (metadata);
item.SetMetadata ("mine", metadata);
Assert.AreEqual (metadata, item.ItemSpec, "#1");
Assert.AreEqual (metadata, item.GetMetadata ("Identity"), "#2");
Assert.AreEqual (Path.GetFileNameWithoutExtension (metadata), item.GetMetadata ("FileName"), "#3");
Assert.IsTrue (item.GetMetadata ("FullPath").EndsWith (metadata), "#4");
Assert.AreEqual (metadata, item.GetMetadata ("mine"), "#5");
}
[Test]
public void TestCopyConstructor ()
{
item1 = new TaskItem ("itemSpec");
item1.SetMetadata ("meta1", "val1");
item2 = new TaskItem (item1);
Assert.AreEqual (item1.GetMetadata ("meta1"), item2.GetMetadata ("meta1"), "A1");
item1.SetMetadata ("meta1", "val2");
Assert.AreEqual ("val2", item1.GetMetadata ("meta1"), "A2");
Assert.AreEqual ("val1", item2.GetMetadata ("meta1"), "A3");
item2.SetMetadata ("meta1", "val3");
Assert.AreEqual ("val2", item1.GetMetadata ("meta1"), "A4");
Assert.AreEqual ("val3", item2.GetMetadata ("meta1"), "A5");
}
[Test]
public void TestCopyMetadataTo ()
{
item1 = new TaskItem ("itemSpec");
item2 = new TaskItem ("itemSpec");
item1.SetMetadata ("A", "1");
item1.SetMetadata ("B", "1");
item1.SetMetadata ("C", "1");
item2.SetMetadata ("B", "2");
item1.CopyMetadataTo (item2);
Assert.AreEqual ("1", item2.GetMetadata ("A"), "1");
Assert.AreEqual ("2", item2.GetMetadata ("B"), "2");
Assert.AreEqual ("1", item2.GetMetadata ("C"), "3");
}
[Test]
public void TestGetMetadata ()
{
item = new TaskItem ("itemSpec");
item.SetMetadata ("Metadata", "Value");
Assert.AreEqual ("Value", item.GetMetadata ("Metadata"), "A1");
Assert.AreEqual (String.Empty, item.GetMetadata ("lala"), "A2");
Assert.AreEqual ("itemSpec", item.GetMetadata ("iDentity"), "A3");
Assert.AreEqual ("", item.GetMetadata ("extension"), "A4");
Assert.AreEqual ("", item.GetMetadata ("ModifiedTime"), "A5");
Assert.AreEqual ("", item.GetMetadata ("CreatedTime"), "A6");
Assert.AreEqual ("", item.GetMetadata ("ModifiedTime"), "A7");
Assert.AreEqual ("", item.GetMetadata ("AccessedTime"), "A8");
}
[Test]
public void TestMetadataNames ()
{
item = new TaskItem ("itemSpec");
Assert.IsTrue (CompareStringCollections (item.MetadataNames, metadataNames), "A1");
item.SetMetadata ("a", "b");
Assert.AreEqual (12, item.MetadataNames.Count, "A2");
}
[Test]
public void TestOpExplicit ()
{
TaskItem item = new TaskItem ("itemSpec");
item.SetMetadata ("a", "b");
Assert.AreEqual ("itemSpec", (string) item, "A1");
}
[Test]
[ExpectedException (typeof (ArgumentException))]
public void TestRemoveMetadata1 ()
{
item = new TaskItem ("lalala");
item.RemoveMetadata ("EXTension");
}
[Test]
[ExpectedException (typeof (ArgumentNullException))]
public void TestRemoveMetadata2 ()
{
item = new TaskItem ("lalala");
item.RemoveMetadata (null);
}
[Test]
public void TestRemoveMetadata3 ()
{
item = new TaskItem ("lalala");
item.SetMetadata ("a", "b");
item.RemoveMetadata ("a");
Assert.AreEqual (11, item.MetadataCount, "A1");
}
[Test]
public void TestSetMetadata1 ()
{
item = new TaskItem ("itemSpec");
item.SetMetadata ("Metadata", "Value1");
item.SetMetadata ("Metadata", "Value2");
Assert.AreEqual (item.MetadataCount, 12, "MetadataCount");
Assert.AreEqual ("Value2", item.GetMetadata ("Metadata"));
}
[Test]
[ExpectedException (typeof (ArgumentNullException))]
public void TestSetMetadata2 ()
{
item = new TaskItem ("itemSpec");
item.SetMetadata (null, "value");
}
[Test]
[ExpectedException (typeof (ArgumentNullException))]
public void TestSetMetadata3 ()
{
item = new TaskItem ("itemSpec");
item.SetMetadata ("name", null);
}
[Test]
[ExpectedException (typeof (ArgumentException))]
public void TestSetReservedMetadata ()
{
item = new TaskItem ("lalala");
item.SetMetadata ("Identity", "some value");
}
[Test]
public void TestSetItemSpec ()
{
var itemSpec = "foo@2x.png";
var escapedItemSpec = global::Microsoft.Build.BuildEngine.Utilities.Escape (itemSpec);
var item = new TaskItem ("foo");
item.ItemSpec = itemSpec;
Assert.AreEqual (itemSpec, item.ItemSpec, "#1");
item.ItemSpec = escapedItemSpec;
Assert.AreEqual (itemSpec, item.ItemSpec, "#2");
}
}
}

View File

@@ -0,0 +1,82 @@
//
// TaskLoggingHelperTest.cs
//
// Author:
// Marek Sieradzki (marek.sieradzki@gmail.com)
//
// (C) 2005 Marek Sieradzki
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
using System;
using System.Collections;
using Microsoft.Build.Framework;
using Microsoft.Build.Utilities;
using NUnit.Framework;
namespace MonoTests.Microsoft.Build.Utilities {
class TestTask : Task {
public override bool Execute ()
{
return true;
}
}
[TestFixture]
public class TaskLoggingHelperTest {
TaskLoggingHelper tlh;
TestTask task;
[Test]
public void TestAssignment ()
{
tlh = new TaskLoggingHelper (task);
}
[Test]
[Category ("NotWorking")]
public void TestExtractMessageCode1 ()
{
tlh = new TaskLoggingHelper (task);
string message = "MYTASK1001: This is an error message.";
string validCode = "MYTASK1001";
string validMessageWithoutCodePrefix = "This is an error message.";
string code, messageWithoutCodePrefix;
code = tlh.ExtractMessageCode (message, out messageWithoutCodePrefix);
Assert.AreEqual (validCode, code, "#1");
Assert.AreEqual (validMessageWithoutCodePrefix, messageWithoutCodePrefix, "#2");
}
[Test]
[ExpectedException (typeof (ArgumentNullException))]
public void TestExtractMessageCode2 ()
{
tlh = new TaskLoggingHelper (task);
string output;
tlh.ExtractMessageCode (null, out output);
}
}
}