我正在使用 AutoFixtureAutoMoqCustomization
并尝试创建一个包含只读属性的类的实例,因此:
public override ILog Logger { get; } = LogManager.GetLogger(typeof(MyService));
这个想法是我应该能够ILog
使用以下方法冻结我的测试测试:
var log = fixture.Freeze<Mock<ILog>>;
并验证它是在 main 方法调用之后通过以下方式调用的:
log.Verify(l => l.Warn, Times.Once);
但是,当我调用fixture.Create<MyService>
AutoFixture 时,不会Logger
用模拟的ILog
. 我还尝试删除默认值LogManager.GetLogger<etc>
,在这种情况下,ILog
值为null
。
其他属性正确填充了测试替身,但不是这个。
作为参考,该ILog
接口来自 ServiceStack 的日志框架,如下所示:
public interface ILog
{
bool IsDebugEnabled { get; }
void Debug(object message);
void Debug(object message, Exception exception);
void DebugFormat(string format, params object[] args);
void Error(object message);
void Error(object message, Exception exception);
void ErrorFormat(string format, params object[] args);
void Fatal(object message);
void Fatal(object message, Exception exception);
void FatalFormat(string format, params object[] args);
void Info(object message);
void Info(object message, Exception exception);
void InfoFormat(string format, params object[] args);
void Warn(object message);
void Warn(object message, Exception exception);
void WarnFormat(string format, params object[] args);
}
我还验证了手动创建 Mocks 并使用 Moq 进行设置 - 该ILog
属性已正确替换为我的 Mock 使用:
myServiceMock.Setup(s => s.Logger).Returns(myLoggerMock)
任何人都可以对此有所了解吗?
重现步骤
测试
using ServiceStack;
using ServiceStack.Logging;
using ServiceStack.Web;
using MyApp;
[Test]
public void LogTest()
{
var fixture = new Fixture().Customize(new AutoMoqCustomization());
var log = fixture.Freeze<Mock<ILog>>();
var request = fixture.Freeze<Mock<IRequest>>();
var response = new Mock<IResponse>();
var service = fixture.Create<MyService>();
request.Setup(r => r.Response).Returns(response.Object);
service.Post(null);
log.Verify(l => l.Warn(It.IsAny<string>()), Times.Once());
}
服务类- 注意:通常该Logger
属性将带有后缀= LogManager.GetLogger(typeof(MyService))
,但我在这一点上省略了它以查看问题。
using ServiceStack;
using ServiceStack.Logging;
namespace MyApp
{
public class MyService : BaseService
{
public override ILog Logger { get; }
public MyResponse Post(MyRequest request)
{
if (request != null) return new MyResponse() {Message = request.Message};
Logger.Warn("Null request object");
return null;
}
}
public abstract class BaseService : Service
{
public abstract ILog Logger { get; }
}
public class MyRequest
{
public string Message { get; set; }
}
public class MyResponse
{
public string Message { get; set; }
}
}
如果您在该service.Post(null)
行上设置断点,您将看到该ILog
属性仍然为空,但其他属性有模拟。