从单元测试中抓取发送到Console.Out的输出?

时间:2010-01-26 12:19:09

标签: c# unit-testing console nunit

我正在使用NUnit在C#中构建单元测试,我想测试主程序实际输出正确的输出,具体取决于命令行参数。

是否有一种来自NUnit测试方法的方法,它调用Program.Main(...)来获取写入Console.Out和Console.Error的所有内容,以便我可以对其进行验证?

2 个答案:

答案 0 :(得分:65)

您可以将Console In,Out和Error重定向到自定义StringWriters,如此

[TestMethod]
public void ValidateConsoleOutput()
{
    using (StringWriter sw = new StringWriter())
    {
        Console.SetOut(sw);

        ConsoleUser cu = new ConsoleUser();
        cu.DoWork();

        string expected = string.Format("Ploeh{0}", Environment.NewLine);
        Assert.AreEqual<string>(expected, sw.ToString());
    }
}

有关详细信息,请参阅this blog post

答案 1 :(得分:12)

您可以使用此简单类通过using语句获取输出:

public class ConsoleOutput : IDisposable
{
    private StringWriter stringWriter;
    private TextWriter originalOutput;

    public ConsoleOutput()
    {
        stringWriter = new StringWriter();
        originalOutput = Console.Out;
        Console.SetOut(stringWriter);
    }

    public string GetOuput()
    {
        return stringWriter.ToString();
    }

    public void Dispose()
    {
        Console.SetOut(originalOutput);
        stringWriter.Dispose();
    }
}

以下是如何使用它的示例:

using (var consoleOutput = new ConsoleOutput())
{
    target.WriteToConsole(text);

    Assert.AreEqual(text, consoleOutput.GetOuput());
}

您可以在我的博客文章中找到更多详细信息和工作代码示例 - Getting console output within a unit test