最小起订量并设置数据库上下文

时间:2018-10-15 05:07:35

标签: c# asp.net-core nunit entity-framework-core moq

我有一个Entity Framework DB Context文件。 我正在尝试在NUnit中设置Moq框架。 Moq Nunit测试目前收到以下错误。我将如何设置DBContext,并将项目添加到产品表中?

“尚未为此DbContext配置任何数据库提供程序。可以通过重写DbContext.OnConfiguring方法或在应用程序服务提供程序上使用AddDbContext来配置提供程序。如果使用了AddDbContext,则还请确保您的DbContext类型接受DbContextOptions对象在其构造函数中,并将其传递给DbContext的基本构造函数。”

电子数据库上下文文件

public partial class ElectronicsContext : DbContext
{
    public ElectronicsContext()
    {
    }

    public ElectronicsContext(DbContextOptions<ElectronicsContext> options)
        : base(options)
    {
    }

    public virtual DbSet<Product> Product { get; set; }
    public virtual DbSet<ProductCategory> ProductCategory { get; set; }

Startup.cs

    var connection = @"Server=localhost;Database=Electronics;Trusted_Connection=True;ConnectRetryCount=0";
    services.AddDbContext<ElectronicsContext>(options => options.UseSqlServer(connection));

Moq Nunit测试

 [SetUp]
 public void Setup()
 {
    var ElectronicsContext = new Mock<ElectronicsContext>();
    var ProductRepository = new Mock<ProductRepository>();

    Product producttest = new Product();
    _dbContext.Product.Add(new Product {ProductId = 1, ProductName = "TV", ProductDescription = "TV testing",ImageLocation = "test"});
    _dbContext.SaveChanges();

1 个答案:

答案 0 :(得分:9)

您不需要在单元测试中模拟上下文。您应该使用DbContextOptions类来指定要使用内存数据库来运行测试。

[TestMethod]
public void TestProducts()
{
    var options = new DbContextOptionsBuilder<ElectronicsContext>()
        .UseInMemoryDatabase(databaseName: "Products Test")
        .Options;

    using(var context = new ElectronicsContext(options))
    {
        context.Products.Add(new Product {ProductId = 1, ProductName = "TV", ProductDescription = "TV testing",ImageLocation = "test"});
        context.SaveChanges();
    }

    using(var context = new ElectronicsContext(options))
    {
        // run your test here

    }
}

这与数据库的内存表示形式有关,而不是依赖于物理服务器。您在startup.cs中提供的连接字符串不会用作测试的一部分。

可以找到更多信息here