я следующий класс, который является декоратором для IDisposable
объекта (я опустил материал, он добавляет), который сам по себе реализует IDisposable
с использованием общей схемы:Как я могу тестировать финализатор?
public class DisposableDecorator : IDisposable
{
private readonly IDisposable _innerDisposable;
public DisposableDecorator(IDisposable innerDisposable)
{
_innerDisposable = innerDisposable;
}
#region IDisposable Members
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
#endregion
~DisposableDecorator()
{
Dispose(false);
}
protected virtual void Dispose(bool disposing)
{
if (disposing)
_innerDisposable.Dispose();
}
}
можно легко проверить, что innerDisposable
расположено, когда Dispose()
называются:
[Test]
public void Dispose__DisposesInnerDisposable()
{
var mockInnerDisposable = new Mock<IDisposable>();
new DisposableDecorator(mockInnerDisposable.Object).Dispose();
mockInnerDisposable.Verify(x => x.Dispose());
}
Но как я пишу тест, чтобы убедиться, что innerDisposable
делает не получить утилизирована финализатором? Я хочу написать что-то вроде этого, но это не удается, по-видимому, потому что финализации не вызывается GC нить:
[Test]
public void Finalizer__DoesNotDisposeInnerDisposable()
{
var mockInnerDisposable = new Mock<IDisposable>();
new DisposableDecorator(mockInnerDisposable.Object);
GC.Collect();
mockInnerDisposable.Verify(x => x.Dispose(), Times.Never());
}
[Здесь] (http://stackoverflow.com/questions/3259456/should-dispose-methods-be-unit-tested) вы можете увидеть использование IDisposable. Это сработало для меня. –