在NUnit测试期间无法在VS 2015中创建LocalDB

时间:2016-10-26 22:46:09

标签: c# visual-studio-2015 entity-framework-6 nunit localdb

我确定有人已经尝过这个,我不能成为第一个!?!我使用Visual Studio 2015,LocalDB(2014),EntityFramework 6.1.3,NUnit 3.5和ReSharper 2016.2建立了一个测试项目。基本上,我正在尝试使用NUnit对连接到LocalDB数据库的EntityFramework项目运行集成测试。我在我的机器上安装了ReSharper,我正在使用ReSharper的单元测试工具来运行我的NUnit单元测试(我使用NUnit 3控制台获得完全相同的结果)。 EF设置为代码优先,应用程序的上下文设置为“DropCreateDatabaseAlways”,因此应在每次测试期间删除并重新创建.mdf文件。

每次运行单元测试时,我都会遇到同样的神秘错误:“ System.OverflowException:算术运算导致溢出。”我知道这是.NET和NUnit之间的冲突,因为我设置了一个控制台应用程序与完全相同的设置(没有单元测试),它完美的工作!控制台应用程序可以创建.mdf文件,我可以使用VS的LocalDB数据库连接器连接到它并查看它的表。

配置:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  </configSections>
  <connectionStrings>
    <add name="HyperQueryEF" connectionString="Data Source=(localdb)\MSSQLLocalDB;AttachDbFilename=|DataDirectory|\HyperQueryEF.mdf;MultipleActiveResultSets=True;App=EntityFramework" providerName="System.Data.SqlClient" />
  </connectionStrings>
  <entityFramework>
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
      <parameters>
        <parameter value="mssqllocaldb" />
      </parameters>
    </defaultConnectionFactory>
    <providers>
      <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
    </providers>
  </entityFramework>
</configuration>

型号:

using System;

namespace HyperQueryEF.Model
{
    public class Dealership
    {
        public int ID { get; set; }
        public DateTime DateCreated { get; set; }
        public string Name { get; set; }
    }
}

的DbContext:

using System.Data.Entity;

namespace HyperQueryEF.Model
{
    public class HyperQueryEFContext : DbContext
    {
        public HyperQueryEFContext() : base("HyperQueryEF")
        {
        }

        public void Initialize()
        {
            Database.SetInitializer(new DropCreateDatabaseAlways<HyperQueryEFContext>());
            //Force database to initialize (Create/Migrate tables).
            Database.Initialize(true);
        }

        public virtual DbSet<Dealership> Dealerships { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            //modelBuilder.Configurations.AddFromAssembly(this.GetType().Assembly);
            modelBuilder.Entity<Dealership>().ToTable("Dealership");
            modelBuilder.Entity<Dealership>()
                .HasKey(x => x.ID)
                .Property(x => x.ID);
            modelBuilder.Entity<Dealership>()
                .Property(x => x.Name);

            base.OnModelCreating(modelBuilder);
        }
    }
}

测试

using System;
using System.IO;
using System.Reflection;
using HyperQueryEF.Model;
using NUnit.Framework;

namespace HyperQueryEF.Tests.IntegrationTests.TransactionManagerTests
{
    [TestFixture]
    public class When_the_app_initializes
    {
        private DirectoryInfo _appDataDirectory;
        private HyperQueryEFContext _context;

        [SetUp]
        public void SetUp()
        {
            _appDataDirectory = new DirectoryInfo(Assembly.GetExecutingAssembly().Location).Parent;
            AppDomain.CurrentDomain.SetData("DataDirectory", Directory.GetCurrentDirectory());
        }

        [Test]
        public void The_database_exists_as_configured()
        {
            _context = new HyperQueryEFContext();
            _context.Initialize();
        }
    }
}

(注意我将| DataDirectory | AppDomian设置设置为与Web应用程序保持一致)

功能 操作系统:Windows 10 Pro .NET:4.5.2

堆栈追踪:

  

在   System.Data.ProviderBase.DbConnectionPool.TryGetConnection(的DbConnection   owningObject,UInt32 waitForMultipleObjectsTimeout,Boolean   allowCreate,Boolean onlyOneCheckConnection,DbConnectionOptions   userOptions,DbConnectionInternal&amp;连接)   System.Data.ProviderBase.DbConnectionPool.TryGetConnection(的DbConnection   owningObject,TaskCompletionSource 1 retry, DbConnectionOptions userOptions, DbConnectionInternal& connection) at System.Data.ProviderBase.DbConnectionFactory.TryGetConnection(DbConnection owningConnection, TaskCompletionSource 1重试,DbConnectionOptions   userOptions,DbConnectionInternal oldConnection,DbConnectionInternal&amp;   连接)   System.Data.ProviderBase.DbConnectionInternal.TryOpenConnectionInternal(的DbConnection   outerConnection,DbConnectionFactory connectionFactory,   TaskCompletionSource 1 retry, DbConnectionOptions userOptions) at System.Data.SqlClient.SqlConnection.TryOpenInner(TaskCompletionSource 1   重试)   System.Data.SqlClient.SqlConnection.TryOpen(TaskCompletionSource 1 retry) at System.Data.SqlClient.SqlConnection.Open() at System.Data.Entity.Infrastructure.Interception.InternalDispatcher 1.Dispatch [t目标,TInterceptionContext](t目标   目标,行动2 operation, TInterceptionContext interceptionContext, Action 3执行,行动3 executed) at System.Data.Entity.Infrastructure.Interception.DbConnectionDispatcher.Open(DbConnection connection, DbInterceptionContext interceptionContext) at System.Data.Entity.SqlServer.SqlProviderServices.<>c__DisplayClass33.<UsingConnection>b__32() at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.<>c__DisplayClass1.<Execute>b__0() at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute[TResult](Func 1   操作)   System.Data.Entity.SqlServer.SqlProviderServices.UsingMasterConnection(的DbConnection   sqlConnection,Action 1 act) at System.Data.Entity.SqlServer.SqlProviderServices.CreateDatabaseFromScript(Nullable 1   commandTimeout,DbConnection sqlConnection,String   createDatabaseScript)at   System.Data.Entity.SqlServer.SqlProviderServices.DbCreateDatabase(的DbConnection   connection,Nullable 1 commandTimeout, StoreItemCollection storeItemCollection) at System.Data.Entity.Migrations.Utilities.DatabaseCreator.Create(DbConnection connection) at System.Data.Entity.Migrations.DbMigrator.EnsureDatabaseExists(Action mustSucceedToKeepDatabase) at System.Data.Entity.Migrations.DbMigrator.Update(String targetMigration) at System.Data.Entity.Internal.DatabaseCreator.CreateDatabase(InternalContext internalContext, Func 3 createMigrator,ObjectContext objectContext)
  在System.Data.Entity.Database.Create(DatabaseExistenceState   presenceState)at   System.Data.Entity.DropCreateDatabaseAlways`1.InitializeDatabase(TContext   上下文)   System.Data.Entity.Internal.InternalContext.PerformInitializationAction(动作   行动)   System.Data.Entity.Internal.InternalContext.PerformDatabaseInitialization()   在HyperQueryEF.Model.HyperQueryEFContext.Initialize()中   C:\ Users \用户agilliam \收存箱\ HyperQueryEF \项目\ HyperQueryEF.Model \ HyperQueryEFContext.cs:线   15点到   HyperQueryEF.Tests.IntegrationTests.TransactionManagerTests.When_the_app_initializes.The_database_exists_as_configured()   在   C:\ Users \用户agilliam \收存箱\ HyperQueryEF \项目\ HyperQueryEF.Tests \ IntegrationTests \ TransactionManagerTests.cs:线   26

1 个答案:

答案 0 :(得分:1)

更新:它似乎并不像构建实体框架来支持NUnit。我使用MSTest平台构建并运行完全相同的测试,它可以工作。我更喜欢NUnit到MSTest,但是MSTest似乎完成了工作。