自从我安装VS 2017以来,我一直在与它斗争。现在,单元测试似乎只能从命令行“dotnet test”运行。

我的项目是。net Core 1.1.1。我已经安装了SDK和1.1.1的框架更新。

我在MSDN (https://msdn.microsoft.com/en-us/library/ms182532.aspx)上尝试了样本,也失败了。

所有用于测试和主项目的NuGet包都是最新的。测试项目和主项目的构建都没有错误。测试从命令行成功运行。

有人让单元测试在VS 2017中运行吗?如果是的话,是怎么做的?

谢谢, 约翰


更新-扩展

下面是一个简单的测试项目的例子,它不能在GitHub上运行。这是一个xUnit的例子,但我已经尝试了在MS测试中内置的NUnit和visual studio。无论我做了什么测试或做了什么更改,我都无法让VS测试运行器找到任何测试。

我的努力

删除VS测试缓存文件DEL %TEMP%\VisualStudioTestExplorerExtensions 重新启动和 关闭/打开测试资源管理器 为xUnit安装Microsoft.DotNet.InternalAbstractions(见SO post) 对于NUnit,确保适配器安装和NUnit包相同的版本(3) Test -> Test Settings ->默认处理器架构设置为x86

这个问题 谁能提供一个VS2017中。net Core 1.1.0解决方案的工作示例?csproj项目文件),其中VS测试资源管理器成功找到单元测试或在给出的例子中显示问题。


当前回答

在我的案例中,是解决方案中的UWP项目导致了这个问题。

当我卸载UWP项目时,发现了测试。当我加载回来,测试再次消失。

尝试卸载所有项目,只保留测试项目。十个重建方案和测试应该出现在测试运行器。逐个加载项目,并每次重新构建解决方案,以找出导致问题的项目

样本回购

VS bug报告

其他回答

这对我来说很有效(不知道这是否是改变工作空间导致的损坏):

删除%TEMP%\VisualStudioTestExplorerExtensions中的VS测试缓存文件并重新启动VS2017。

在我的例子中,这是一个我从早期的. net版本升级测试项目的项目。在app.config中,我有到以前版本的依赖程序集的程序集绑定。

在app.config中修复程序集绑定后,我的测试被发现了。

在我的例子中,我的一个测试类不是公共的。这使得整个套件无法运行。

但这是我是如何计算出来的==>似乎“输出”控制台将向您显示测试日志。您只需要从构建切换到测试。

这简单得令人尴尬。我希望我的尴尬能帮助到其他人。

在我的例子中,我将测试项目目标为x64体系结构,而测试设置体系结构(test >默认处理器体系结构)更改为x86。它们不匹配。

在将测试设置体系结构设置回x64并重新构建之后,所有测试都再次被发现。

从Visual Studio 2017迁移到2019时,我也遇到了同样的问题。我不得不在我所有的测试项目中重新安装Microsoft.NET.Test.Sdk。