3

我正在尝试将在 NUnit 中运行的自动化测试的结果记录在一个小型数据库中,以便出于各种原因轻松访问和更安全地记录数据。(大约有 550 个自动化测试,运行它们可能需要几天时间)

我已经可以访问测试的结束状态(通过/失败/错误/取消/跳过等),但我想记录额外的详细信息。

我希望在 TearDown() 中执行此操作。

这是我能找到的最接近的东西,但没有为我提供答案: https ://groups.google.com/forum/?fromgroups=#!msg/nunit-discuss/lXxwECvpqFc/IbKOfQlbJe8J

想法?

4

3 回答 3

4

我相信您将能够通过NUnit EventListeners获得所需的信息。我自己没有使用过这些,但我已将它们添加为书签,以执行与您要完成的任务类似的操作。

这是您将使用的界面。希望您的TearDown方法会在之前被调用TestFinished,但我无法验证这一点。

public interface EventListener
{
    void RunStarted(string name, int testCount );
    void RunFinished(TestResult result);
    void RunFinished(Exception exception);
    void TestStarted(TestName testName);
    void TestFinished(TestResult result);
    void SuiteStarted(TestName testName);
    void SuiteFinished(TestResult result);
    void UnhandledException(Exception exception);
    void TestOutput(TestOutput testOutput);
}
于 2013-01-15T19:37:12.053 回答
1

对于那些想要一些 skellie 代码的人:

[NUnitAddinAttribute(Type = ExtensionType.Core,
Name = "Database Addin",
Description = "Writes test results to the database")]
public class MyExtension :IAddin, EventListener
{
//some private attributes to hold important data

//you must provide the Install method
    public bool Install(IExtensionHost host)
    {
        //I also built my connection string in here
        IExtensionPoint listeners = host.GetExtensionPoint("EventListeners");
        if (listeners == null)
             return false;

        listeners.Install(this);
        return true;
    }

//you must also provide all the event handlers, 
//but they don't have to actually do anything if they are not used.
//e.g.

    public void TestStarted(NUnit.Core.TestName testName)
    {
        //This saved the start time of the test
        _start =  DateTime.Now;
    }

    public void TestFinished(NUnit.Core.TestResult result)
    {
        //LogTest connected to the databse and executed a proc to 
        //insert the log, was quite simple
        LogTest((result.Message == null? "" : result.Message),
            result.ResultState,
            result.Name,
            _start,
            DateTime.Now);
    }

    public void TestOutput(NUnit.Core.TestOutput testOutput)
    {
         //this is one of the unused event handlers, it remains empty.
    }
    //etc..

}
于 2013-01-17T09:41:00.567 回答
1

NUnit 3.0在 TestContext.CurrentContext 中包含了这些细节。~

注意: 如果您将 VS 测试适配器作为扩展包含在内,则使用事件处理程序将导致测试运行两次。一次用于扩展,一次用于实现事件处理程序所需的包含 dll。

于 2016-02-15T17:46:39.557 回答