0

我有一个 DLL,它有点复杂,我正在编写测试。大多数被测试的类都有自己的TraceSource对象,用于输出跟踪信息。

namespace MyDll
{
    public class Class1
    {
        static TraceSource tracing = new TraceSource(nameof(Class1));
        //Instance members and functions...
    }

    public class Class2
    {
        static TraceSource tracing = new TraceSource(nameof(Class2));
        //Instance members and functions...
    }

    public class Class3
    {
        static TraceSource tracing = new TraceSource(nameof(Class3));
        //Instance members and functions...
    }
}

项目内部MyDll是一个App.config文件,它ConsoleTraceListener向所有TraceSource.

<configuration>
  <system.diagnostics>
    <sources>
      <source name="Class1"
        switchName="sourceSwitch"
        switchType="System.Diagnostics.SourceSwitch">
        <listeners>
          <add name="console"/>
        </listeners>
      </source>
      <source name="Class2"
        switchName="sourceSwitch"
        switchType="System.Diagnostics.SourceSwitch">
        <listeners>
          <add name="console"/>
        </listeners>
      </source>
      <source name="Class3"
        switchName="sourceSwitch"
        switchType="System.Diagnostics.SourceSwitch">
        <listeners>
          <add name="console"/>
        </listeners>
      </source>
    </sources>
    <switches>
      <add name="sourceSwitch" value="Verbose"/>
    </switches>
    <sharedListeners>
      <add name="console"
            type="System.Diagnostics.ConsoleTraceListener">
        <filter type="System.Diagnostics.EventTypeFilter"
          initializeData="Verbose"/>
      </add>
    </sharedListeners>
  </system.diagnostics>
</configuration>

App.config配置为始终复制到输出目录。我不确定这是否相关。

这就是问题所在:如果我运行 1 个测试,我会从测试的输出中获得所有跟踪信息。但是,如果我运行所有测试,则只有第一个测试运行会跟踪被测代码。所有其他测试都没有任何输出。

如何让 MSTest 输出所有TraceSource测试的所有跟踪信息?

4

1 回答 1

0

问题在于 MSTest。测试类中的静态对象将在第一个测试中被拾取,但不会在接下来的测试中被拾取。例如,

public class SomeDependency
{
   private static TraceSource tracing = new TraceSource("SomeDependency");
   public void FunctionUsed()
   {
      tracing.TraceEvent(TraceEventType.Informational, 1, "This function is being used");
   }
}

[TestClass]
public class TestClass
{
   static SomeDependency dependency;

   [ClassInitialize]
   public static void Init(TestContext context)
   {
      dependency = new SomeDependecy();
   }

   [TestMethod]
   public void Test1()
   {
      dependency.FunctionUsed();
   }

   [TestMethod]
   public void Test2()
   {
      dependency.FunctionUsed();
   }
}

Test1将显示TraceSourcein的输出SomeDependency,但Test2不会。这是 MSTest 运行器的限制。

于 2016-02-01T15:01:33.237 回答