0

我一直在寻找在 NUnit 中获取错误消息的方法。到目前为止,我发现了一些使用 IAddin 和 EventListener 来获取消息的类,但是没有用。我将此代码基于此链接:

关于扩展

源代码

可扩展性

我将代码添加到项目中,但没有记录任何内容,或者在测试失败时没有做任何事情。我读到我必须将 dll 添加到一些“NUnit\addins\”文件夹中,但我找不到任何带有这个“插件”的插件文件夹。

我不知道我错过了什么,有人可以帮助我吗?

下面是我使用的代码:

using System;
using System.IO;
using NUnit.Core;
using NUnit.Core.Extensibility;

namespace Test
{
    [NUnitAddinAttribute(Type = ExtensionType.Core,
                         Name = "Database Addin",
                         Description = "Writes test results to the database.")]
    public class MyNunitExtension : IAddin, EventListener
    {
        public bool Install(IExtensionHost host)
        {
            IExtensionPoint listeners = host.GetExtensionPoint("EventListeners");
            if (listeners == null)
                return false;

        listeners.Install(this);
        return true;
    }

    public void RunStarted(string name, int testCount) { }
    public void RunFinished(TestResult result) { }
    public void RunFinished(Exception exception) { }
    public void TestStarted(TestName testName) { }

    public void TestFinished(TestResult result)
    {
        using (var arq = File.Open(@"C:\Temp\Log.txt", FileMode.Append))
        using (var writer = new StreamWriter(arq))
        {
            var message = string.Format("[{0:s}] [{1}] {2}", DateTime.Now,
                result.ResultState, result.Name);
            writer.WriteLine(message);
            var isFailure =
                result.ResultState == ResultState.Error ||
                result.ResultState == ResultState.Failure;
            if (isFailure)
            {
                writer.WriteLine(result.Message);
            }
        }
    }

    public void SuiteStarted(TestName testName) { }
    public void SuiteFinished(TestResult result) { }
    public void UnhandledException(Exception exception) { }
    public void TestOutput(TestOutput testOutput) { }
}
}
4

1 回答 1

1

希望这会对您有所帮助。

我目前也在查看 Nunit 的插件,建议您检查以下内容:您在上面获得插件文件的解决方案需要使用 .net 3.5 的目标框架进行设置(请参阅此处的讨论:https:// groups.google.com/d/msg/nunit-discuss/je0VXIsVQNQ/UpvDmYEkVhAJ)。当您构建此解决方案时,将它从 bin 文件夹中创建的 .dll 放入 nunit 的插件目录中,在我的情况下,该目录可以在安装目录中找到( C:\Program Files (x86)\NUnit 2.6.4 \bin\addins )。

然后,当您打开 Nunit 时,转到工具 > 插件,您应该在那里看到您的插件。

于 2015-09-02T10:59:00.610 回答