我目前正在开发一个有32个单元测试的解决方案。我一直在使用resharper测试运行器-它工作得很好。所有测试都在运行,所有测试都显示正确的测试结果。

但是,在使用Visual Studio测试资源管理器时,测试未运行。

测试资源管理器正在显示所有单元测试,但一旦单击“全部运行”,所有测试都将变成灰色,并且不显示测试运行的结果:

所有测试类都是公共的 所有测试类都声明了[TestClass]属性 所有测试方法都使用[TestMethod]属性 生产力代码和测试项目都是针对。net 3.5的。 我已经尝试清洁构建我的解决方案,和/或删除所有obj, bin,调试和发布文件夹

我很感激任何能解释这种行为的提示。


当前回答

I found that in the project it was not referencing the Microsoft.VisualStudio.QualityTools.UnitTestFramework assembly. Instead, it was referencing Microsoft.VisualStudio.TestPlatform.TestFramework and Microsoft.VisualStudio.TestPlatform.TestFramework.Extensions. When I removed those two references and added the reference to the Microsoft.VisualStudio.QualityTools.UnitTestFramework assembly the tests that were previously marked with the blue exclamation point suddenly became active and started working.

其他回答

对于Visual Studio 2019和针对. net 5.0的测试项目,您还需要安装xunit.runner.visualstudio。所以,你的包应该像这个例子:

2.4.1 xunit () 2.4.3 xunit.runner.visualstudio ()

在解决方案资源管理器中右键单击文件,确保它的构建操作设置为“c# Compiler”

解决方案资源管理器—>右键单击文件—>“属性”—>构建动作=“c#编译器”

我在Visual Studio 2022 for Mac(预览)中创建一个单独的测试项目时遇到了这个问题。

重现步骤: VS 2022开放项目 右键单击解决方案,添加新项目 继续测试> nunit > 目标框架:NET 6.0 名称:random-tests > create mac的VS 2022包含一个覆盖的依赖项。收集器-删除此nuget引用修复了我的问题。

还有另一个荒谬的例子:同一解决方案中的两个项目有相同的projd——其中一个是测试项目,这让测试运行者感到困惑。

删除并读取测试项目到解决方案更改了projectd并修复了问题。

好吧,我知道我迟到了,但在这里记录我的答案,以防有人面临类似的问题。这个问题我已经遇到过很多次了。90%的问题通过这两步解决

project > properties > Build > Platform target > x64 (x32)

Test -> Test Settings > Default Processor Architecture > X64 (x32)

然而,我发现了一个更常见的原因。解决方案文件经常改变开发人员系统,并且它们开始指向错误的mste . testadapter。特别是如果您正在使用nuget包的自定义路径。 我解决了这个问题

在记事本中打开.csproj文件。 手动更正对MSTest的引用。导入TestAdapter 像这样的指令。