Я использую EF 4.1 для построения модели домена.У меня есть класс Task с методом Validate (string userCode), и в нем я хочу убедиться, что код пользователя соответствует действительному пользователю в базе данных, поэтому:
public static bool Validate(string userCode)
{
IDbSet<User> users = db.Set<User>();
var results = from u in users
where u.UserCode.Equals(userCode)
select u;
return results.FirstOrDefault() != null;
}
Я могу использовать Moq для макета IDbSetнет проблем.Но столкнулся с проблемой вызова Where:
User user = new User { UserCode = "abc" };
IList<User> list = new List<User> { user };
var users = new Mock<IDbSet<User>>();
users.Setup(x => x.Where(It.IsAny<Expression<Func<User, bool>>>())).Returns(list.AsQueryable);
Initialization method JLTi.iRIS3.Tests.TaskTest.SetUp threw exception.
System.NotSupportedException: System.NotSupportedException: Expression
references a method that does not belong to the mocked object:
x => x.Where<User>(It.IsAny<Expression`1>()).
Кроме создания уровня косвенного обращения (например, использование ServiceLocator для получения объекта, который запускает LINQ, а затем высмеивает этот метод) Я не могу думатьо том, как еще это проверить, но я хочу убедиться, что нет никакого способа, прежде чем я представлю другой слой.И я вижу, что такого рода запросы LINQ будут нужны довольно часто, чтобы объекты службы могли быстро выйти из-под контроля.
Может ли какая-то душевная помощь помочь?Спасибо!