我目前正在使用 .NET MVC 并编写一些单元测试。我有一个如下所示的接口(interface)存储库:
public interface IRepository<TEntity> : IDisposable where TEntity : class
{
IQueryable<TEntity> GetAll();
TEntity Single(Expression<Func<TEntity, bool>> predicate);
}
我已经像这样 mock GetAll 方法:
_mockRepository.Setup(x => x.GetAll()).Returns(
new List<Post>
{
new Post { Title = "Test Post 1" },
new Post { Title = "Test Post 2" }
}.AsQueryable());
现在我不确定如何模拟 Single 方法,因为它有一个包含我要评估的表达式的参数。
谢谢,
b3n
编辑:
我将代码更改为:
_mockRepository.Setup(x => x.Single(It.IsAny<Expression<Func<Post, bool>>>()))
.Returns( (Expression<Func<Post, bool>> expr) => new List<Post> {
new Post { PostId = 1, Title = "Test Post 1", Created = DateTime.Now },
new Post { PostId = 2, Title = "Test Post 2", Created = DateTime.Now }
}.Where(expr));
但我现在收到以下错误:
'System.Collections.Generic.List' 不包含 'Where' 的定义,并且最佳扩展方法重载 'System.Linq.Queryable.Where(System.Linq.IQueryable, System.Linq.Expressions.Expression>)' 具有一些无效的论点。
这甚至是最好的方法还是应该只返回一个新的 Post 而不考虑传入的表达式?
编辑2:
这是工作结果。
_mockRepository.Setup(x => x.Single(It.IsAny<Expression<Func<Post, bool>>>())).Returns(
(Expression<Func<Post, bool>> expr) =>
new List<Post>
{
new Post { PostId = 1, Title = "Test Post 1", Created = DateTime.Now },
new Post { PostId = 2, Title = "Test Post 2", Created = DateTime.Now }
}.Single(expr.Compile()));
最佳答案
如果您需要使用参数,我相信您可以在 Returns 方法中使用参数匹配器和 lambda:
_mockRepository.Setup(x => x.Single(It.IsAny<Expression<Func<TEntity, bool>>>())
.Returns((Expression<Func<TEntity, bool>> expr) => ... );
编辑:
您现在遇到的错误是因为您试图将表达式树传递给 LINQ-To-Objects 的 Where 方法。要解决此问题,请使用以下命令:
_mockRepository.Setup(x => x.Single(It.IsAny<Expression<Func<Post, bool>>>()))
.Returns( (Expression<Func<Post, bool>> expr) => new List<Post> {
new Post { PostId = 1, Title = "Test Post 1", Created = DateTime.Now },
new Post { PostId = 2, Title = "Test Post 2", Created = DateTime.Now }
}.Where(expr.Compile()));
Compile() 将表达式树转换为简单的 Func 委托(delegate)。此外,由于模拟方法返回单个对象,因此 Where() 也不起作用。
关于asp.net-mvc - 如何使用 Moq 模拟存储库 Single(Expression<Func<TEntity, bool>> predicate) 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4976651/