2

当我尝试使用我的 VS2008 单元测试项目调用 TraceSource.TraceData 时,我收到了一个 Object Disposed 异常。我在下面包含了一个非常小的代码示例,它始终如一地重现了这个问题。我只是在运行第一个单元测试后才看到这一点 - 但我有一种预感,一旦我的网站启动并与大量用户一起运行,它就会影响我。

就像在第一次单元测试后关闭底层流一样。非常感谢“溢出”大师的任何帮助。

脚步:

1)创建一个VS 2008单元测试项目

2)使用此代码添加一个类:

namespace TracingError
{
    using System.Diagnostics;
    using Microsoft.VisualStudio.TestTools.UnitTesting;

    [TestClass]
    public class UnitTest1
    {
        public static TraceSource ts = new TraceSource("TraceTest");

        [TestMethod]
        public void A()
        {
            ts.TraceEvent(TraceEventType.Information, 1, "Hello from A");
        }

        [TestMethod]
        public void B()
        {
            ts.TraceEvent(TraceEventType.Information, 1, "Hello from B");
        }
    }
}

3) 使用以下代码添加 app.config:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <system.diagnostics>
    <sources>
      <source name="TraceTest" switchName="SourceSwitch" switchType="System.Diagnostics.SourceSwitch">
        <listeners>
          <add name="console" type="System.Diagnostics.ConsoleTraceListener" initializeData="false" />
          <remove name="Default" />
        </listeners>
      </source>
    </sources>
    <switches>
      <add name="SourceSwitch" value="Verbose" />
    </switches>
    <trace autoflush="true" indentsize="4"></trace>
  </system.diagnostics>
</configuration>
4

1 回答 1

3

在运行使用 Trace.WriteLine 调用执行代码的测试时,我遇到了同样的问题。运行单个测试很好,但运行多个会触发以下调用堆栈:

System.IO.__Error.WriterClosed()
System.IO.StringWriter.Write(Char[] buffer, Int32 index, Int32 count)
System.IO.TextWriter.WriteLine(String value)
System.IO.TextWriter.SyncTextWriter.WriteLine(String value)
System.Diagnostics.TextWriterTraceListener.WriteLine(String message)
System.Diagnostics.TraceInternal.WriteLine(String message)
System.Diagnostics.Trace.WriteLine(String message)

经过一番调查,我发现在您的测试设置中放置以下代码可以解决该问题:

[TestInitialize()]
public void Setup()
{
    Array.ForEach((from TraceListener tl in Trace.Listeners
                   where tl.Name != "Default"
                   select tl).ToArray(),
                   tl => Trace.Listeners.Remove(tl));

} 

显然,在 mstest 环境中运行时,多个跟踪侦听器存在问题。MSTest 正在添加一个 System.Diagnostics.TextWriterTraceListener,它正在使用在第一次测试之后释放的流。解决方法只是删除了除默认值之外的所有 Trace 侦听器,有效地删除了 mstest 添加的侦听器。该问题似乎与对 mstest 创建的跟踪流的某些不当处理有关。之前我说过 mstest 为每个测试创建了一个 AppDomain。这不是真的。

我看到您在这里向 Microsoft 提交了错误报告,但没有收到任何有用的反馈。希望这个快速修复对您有用,就像对我一样。

于 2009-09-01T22:03:36.203 回答