繁体   English   中英

如何在实体框架的Include()中使用Moq

[英]How to use Moq with Entity Framework Include()

我正在尝试为我的DAL层编写单元测试。

复杂之处在于DAL层具有使用Include()的查询。

我不知道如何模拟Include()方法。

楷模

    public class Apps
    {
        [Key]
        [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
        [DataMember]
        public int ID { get; set; }

        [DataMember]
        [Required(ErrorMessage = "App name required.")]
        public string Name { get; set; }

        public virtual ICollection<AppDataPermission> AppDataPermissions { get; set; }

    }

public class AppDataPermission{
        [Key]
        [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
        [DataMember]
        public int ID { get; set; }

        public DataPermissions DataPermission { get; set; }

        public virtual Apps App { get; set; }
    }

public enum DataPermissions 
{
        Admin = 1,
        Support = 2
    }

DAL

public List<Apps> GetApps()
        {
            var apps = dbContext.Apps
                .Include(x => x.AppDataPermission)
                .ToList();
            return apps;
        }

我尝试了以下[ https://msdn.microsoft.com/en-us/library/dn314429(v=vs.113).aspx][1]

但我得到以下错误

System.ArgumentNullException occurred
  HResult=0x80004003
  Message=Value cannot be null.
Parameter name: source
  Source=EntityFramework
  StackTrace:
   at System.Data.Entity.Utilities.Check.NotNull[T](T value, String parameterName)
   at System.Data.Entity.QueryableExtensions.Include[T,TProperty](IQueryable`1 source, Expression`1 path)

模拟数据库访问代码的问题在于,您正在模拟最复杂的部分(linq-to-sql,导航属性)。 一般来说,我建议不要公开DAL对象。

无论如何,您没有显示您的模拟代码,但我假设您正在public List<Apps> GetApps()

这是一种模拟它的方法:

var mockRepo = new Mock<IMyAmazingRepository>(MockBehavior.Strict);

var myMockedApps = new List<App> () {
  new Apps { ID = 1, Name ="One", new List<AppDataPermission> { (...) },
  new Apps { ID = 2, Name ="Two", new List<AppDataPermission> { (...) }
};

mockRepo.Setup(m => m.GetApps(_loggedInUserId)).Returns(myMockedApps);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM