// NAnt - A .NET build tool
// Copyright (C) 2002 Scott Hernandez (ScottHernandez@hotmail.com)
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
//
// Scott Hernandez (ScottHernandez@hotmail.com)
// Gert Driesen (gert.driesen@ardatis.com)
using System;
using NUnit.Framework;
using NAnt.Core;
namespace Tests.NAnt.Core.Tasks {
///
/// Tests the Echo task.
///
[TestFixture]
public class EchoTest : BuildTestBase {
[SetUp]
protected override void SetUp() {
base.SetUp();
}
[Test]
public void Test_EchoDefaultProjectInfo() {
string _xml = @"
";
string result = RunBuild(_xml);
Assert.IsTrue(result.IndexOf("Go Away!") != -1, "Echo message missing:" + result);
}
[Test]
public void Test_EchoDefaultProjectInfoMacro() {
string _xml = @"
";
string result = RunBuild(_xml);
Assert.IsTrue(result.IndexOf("Go Away!") != -1, "Macro should have expanded:" + result);
}
[Test]
public void Test_EchoDebugProjectInfo() {
string _xml = @"
";
string result = RunBuild(_xml, Level.Info);
Assert.IsTrue(result.IndexOf("Go Away!") == -1, "Debug echo should not be output when Project level is Info.");
}
[Test]
public void Test_EchoWarningProjectInfo() {
string _xml = @"
Go Away!
";
string result = RunBuild(_xml, Level.Info);
Assert.IsTrue(result.IndexOf("Go Away!") != -1, "Warning echo should be output when Project level is Info.");
}
[Test]
public void Test_EchoWarningProjectInfoMacro() {
string _xml = @"
${prop} Away!
";
string result = RunBuild(_xml, Level.Info);
Assert.IsTrue(result.IndexOf("Go Away!") != -1, "Macro should have expanded:" + result);
}
[Test]
public void Test_EchoWarningProjectError() {
string _xml = @"
Go Away!
";
string result = RunBuild(_xml, Level.Error);
Assert.IsTrue(result.IndexOf("Go Away!") == -1, "Warning echo should not be output when Project level is Error.");
}
[Test]
[ExpectedException(typeof(TestBuildException))]
public void Test_EchoInvalidLevel() {
string _xml = @"
";
RunBuild(_xml, Level.Error);
}
[Test]
[ExpectedException(typeof(TestBuildException))]
public void Test_EchoMessageAndInlineContent() {
string _xml = @"
Go Away!
";
RunBuild(_xml, Level.Info);
}
}
}