【发布时间】:2015-07-03 05:03:57
【问题描述】:
这是我的代码:
public class Bar { }
public class Foo { public string Name { get; set; } public Bar TheBar { get; set; } }
public class Dependency
{
public Foo DoSomething(Expression<Func<Foo, bool>> exp1) { return new Foo(); }
}
public class Base
{
public Dependency Dependency { get; set; }
public virtual Foo MethodA(Expression<Func<Foo, bool>> exp1,
params Expression<Func<Foo, object>>[] exp2)
{
return Dependency.DoSomething(exp1);
}
}
public class Derived : Base
{
public Foo DerviedMethod(string str)
{
return base.MethodA(e1 => e1.Name.Equals(str), e2 => e2.TheBar);
}
}
还有我的单元测试代码:
var mock = new Mock<Derived> { CallBase = true }; // Same result with false
mock
.Setup(m => m.MethodA(
It.IsAny<Expression<Func<Foo, bool>>>(),
It.IsAny<Expression<Func<Foo, object>>>()
))
.Returns(new Foo());
// Act
var result = mock.Object.DerviedMethod("test");
// Assert
Assert.IsNotNull(result);
但它仍然调用原始方法而不是模拟的方法。这两个类都存在于同一个程序集中。
我搜索过它,几乎所有人都用CallBase = true 或false 找到了它。
你知道上面的代码有什么问题吗?
【问题讨论】:
-
你的Derived方法不应该标记为
virtual吗?否则我认为你不能正确地模拟具体的课程。不确定。 -
我已将其标记为
virtual但现在它返回null而不是 bar 实例 -
问题可能来自您的
Setup。您可以尝试通过去除更多绒毛来找出问题所在,例如各种Expressions 参数和泛型以深入核心。无法让您的示例在我这边编译。 -
我也没有,看起来这可能是起订量无法做到的。 this one 之类的类似答案/cmets 似乎得出了相同的结论。将您的架构从继承更改为组合(以便 Derive 有一个 Base 实例,而不是从它继承)可能会解决您的问题。这样你就可以直接模拟 Base 类并将你的模拟传递给你的 Derived 类。
-
您还没有包含
DoTest所做的事情,但是您不能像当前编写的那样模拟代码。您通过base.说明符调用您尝试模拟的方法,该说明符告诉实现运行特定版本的函数。任何虚拟声明都会被忽略,因此不能被 Moq 截获。这基本上与我在此答案中讨论的问题相同(对 Moq 和 NSubstitute 的限制对此相同)stackoverflow.com/a/31062287/592182
标签: c# unit-testing moq-3