首页 > 解决方案 > 断言该方法已使用 xUnit 调用

问题描述

我有一个带有要测试的日志记录方法的类。例如,我想检查该Console.WriteLine方法是否已被调用。这是我的示例类

public class MyClass
{
    public void LogSomething()
    {
        Console.WriteLine("Test");
    }
}

及其测试

public class MyClassTests
{
    [Fact]
    public void LogsSomething()
    {
        MyClass myClass = new MyClass();
            
        myClass.LogSomething(); // Assert that Console.WriteLine has been called once
    }
}

有什么我可以使用的吗?(最好没有额外的包装)

我正在寻找这样的断言(伪代码)

标签: c#unit-testingxunit

解决方案


我认为您不能开箱即用地断言。

您最好的选择是使用Moq或其他模拟框架来执行此操作。您应该始终以使用依赖注入的解耦逻辑为目标,否则您最终将拥有一个难以测试的紧密耦合代码,并且每当需求发生变化时也不容易重构

public interface ILogger
{
    public void Log();    
}
public class Logger: ILogger
{
    public void Log()
    {
        Console.WriteLine("Look mom, i'm logging");
    }
}
public class MyClass
{
    private readonly ILogger Logger
    
    public MyClass(ILogger logger)
    {
        Logger = logger;
    }

    public void MyMethod()
    {
        //other code
        Logger.Log();
    }
}
public class MyClassTests
{
    [Fact]
    public void LogsSomething()
    {
      //arrange
      var logger = new Mock<ILogger>();   
      
      //act
      var sut = new MyClass(logger.Object);
      sut.MyMethod();

      //Assert 
      logger.Verify(foo => foo.Log(), Times.Once()); //here
      //some other assertions
    }
}

推荐阅读