unit-testing – 不返回值的方法的moq callbase(void方法)
发布时间:2020-12-14 04:56:55 所属栏目:百科 来源:网络整理
导读:我正在尝试模拟我正在测试的类,以便在测试它们时可以调用各个方法的基础.这将允许我仅将方法设置测试为callbase,并且将模拟在测试方法中调用的所有其他方法(同一类). 但是,我无法为不返回值的方法执行此操作.对于不返回值的方法,intellisense不显示callbase
我正在尝试模拟我正在测试的类,以便在测试它们时可以调用各个方法的基础.这将允许我仅将方法设置测试为callbase,并且将模拟在测试方法中调用的所有其他方法(同一类).
但是,我无法为不返回值的方法执行此操作.对于不返回值的方法,intellisense不显示callbase的选项. 这可能吗? 服务类: public class Service { public Service() { } public virtual void StartProcess() { //do some work string ref = GetReference(id); //do more work SendReport(); } public virtual string GetReference(int id) { //... } public virtual void SendReport() { //... } } 测试类设置: var fakeService = new Mock<Service>(); fakeService.Setup(x => x.StartProcess()); fakeService.Setup(x => x.GetReference(It.IsAny<int>())).Returns(string.Empty); fakeService.Setup(x => SendReport()); fakeService.CallBase = true; 现在在我测试GetReference的测试方法中,我可以这样做: fakeService.Setup(x => x.GetReference(It.IsAny<int>())).CallBase(); 但是当我想为StartProcess做同样的事情时,.CallBase就不存在了: fakeService.Setup(x => x.StartProcess()).CallBase(); 一旦我使方法返回一些东西,这样一个布尔值,它就变得可用. 解决方法
首先,你的mock不起作用,因为Service类上的方法不是虚拟的.在这种情况下,Moq无法拦截调用以插入自己的模拟逻辑(详情请看
here).
设置mock.CallBase = true指示Moq将显式安装调用未匹配的任何调用委托给其基本实现.删除fakeService.Setup(x => x.StartProcess());调用以便Moq可以调用基础实现. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |