Visual Studio Ordered测试运行两次

时间:2013-03-08 00:40:56

标签: c# visual-studio unit-testing visual-studio-2012 mstest

所以我有一个非常简单的设置来初始化一个LocalDB数据库来运行一些集成测试。

在我的设置中,我正在按如下方式初始化我的测试:

[AssemblyInitialize]
public static void AssemblyInitialize(TestContext context)
{
    AppDomain.CurrentDomain.SetData(
    "DataDirectory", Path.Combine(AppDomain.CurrentDomain.BaseDirectory, ""));

    System.Data.Entity.Database.SetInitializer(new MyDatabaseInitializer());
}

public class MyDatabaseInitializer : System.Data.Entity.DropCreateDatabaseAlways<Context>
{
    protected override void Seed(Context context)
    {
        // Add entities to database.
        context.Blogs.AddOrUpdate(x => x.Title, new Blog
        {
            BlogId = Guid.NewGuid(),
            Title = "some Title"
        });

        context.SaveChanges();
    }
}

我有三个这样的测试:

[TestMethod]
[DeploymentItem("Database1.mdf")]
[DeploymentItem("UnitTestProject1.dll.config")]
public void initialize()
{

}

[TestMethod]
public void TestMethod1()
{
    var ctx = new Context();

    var res = ctx.Blogs.ToList();

    res.Should().NotBeNull().And.HaveCount(1);
}

[TestMethod]
public void it_should_be_able_to_add_a_new_blog()
{
    var ctx = new Context();

    ctx.Blogs.Add(new Blog {BlogId = Guid.NewGuid(), Title = "OMFG " + DateTime.Now.ToShortDateString()});

    ctx.SaveChanges();

    ctx.Blogs.Should().HaveCount(2);
}

我有一个OrderedTest文件,如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<OrderedTest name="orderedtest1" storage="c:\users\jolmos\documents\visual studio 2012\projects\consoleapplication9\unittestproject1\orderedtest1.orderedtest" id="cc545e78-c463-4f38-88fc-ac8b49b420be" xmlns="http://microsoft.com/schemas/VisualStudio/TeamTest/2010">
  <TestLinks>
    <TestLink id="d0380f08-e99f-ebae-e5cd-9ae8196521cb" name="initialize" storage="bin\debug\unittestproject1.dll" type="Microsoft.VisualStudio.TestTools.TestTypes.Unit.UnitTestElement, Microsoft.VisualStudio.QualityTools.Tips.UnitTest.ObjectModel, Version=11.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
    <TestLink id="5b688acc-bf10-4c7e-4b60-69d8596bdd90" name="TestMethod1" storage="bin\debug\unittestproject1.dll" type="Microsoft.VisualStudio.TestTools.TestTypes.Unit.UnitTestElement, Microsoft.VisualStudio.QualityTools.Tips.UnitTest.ObjectModel, Version=11.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
    <TestLink id="0c248cf5-fa4f-6c24-b151-3ffdbae30f10" name="it_should_be_able_to_add_a_new_blog" storage="bin\debug\unittestproject1.dll" type="Microsoft.VisualStudio.TestTools.TestTypes.Unit.UnitTestElement, Microsoft.VisualStudio.QualityTools.Tips.UnitTest.ObjectModel, Version=11.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
  </TestLinks>
</OrderedTest>

enter image description here

测试工作很棒......但是......

由于某种原因,我的测试运行了两次

所以我在每次测试时都有一个断点,当我点击 Test |时调试|所有测试测试执行两次,即使AssemblyInitialize方法执行两次=(

更新1

我刚发现测试是在TestResults文件夹下的两个不同文件夹中创建的,差异为1秒

下图中的名称只是我的网络用户名

enter image description here

我的配置中缺少什么?

2 个答案:

答案 0 :(得分:4)

  

出于某种原因,我的测试运行了两次

您的测试运行两次,因为它们作为简单的单元测试和有序测试的一部分运行。

  

甚至AssemblyInitialize方法都执行了两次

如果您打开bin\debug文件夹,您会看到您的orderedtest包含在orderedtest1.orderedtest中。您已经打开它,因此您看到它是一个简单的xml文件。此文件未编译到程序集中。

当visual studio开始执行测试时,它首先选择单元测试。因此,它初始化它们包含的程序集。完成后,它不知道有序测试包含来自同一程序集的测试,因此执行AssemblyCleanup。当它开始执行orderedtest时,它必须重新初始化Assembly以测试包含它的单元测试。

答案 1 :(得分:3)

这是因为您的Ordered Test本身就是一个测试,因此运行所有测试意味着所有单个测试都会运行以及Ordered测试,因此其中包含的测试将运行两次。

您可以使用“测试列表编辑器”有选择地运行测试( Test \ Windows \ Test List Editor )。