VS2017无法发现单元测试,不能运行单元测试的解决方案

问题:

      在VS2017中新建空的单元测试后,无法运行测试,即右键菜单的“运行测试”和“调试测试” 不能运行,在测试资源管理中也无法列出这个测试。

20180111004614896914.png

解决方案:

1.打开Packages.config文件,移除MSTest相关的两个nuget包引用。

image

2.在Test项目中重新增加MSTest.TestAdapter和MSTest.TestFramework的引用即可,注意要选择匹配的版本。

转载于:https://www.cnblogs.com/vveiliang/p/9660928.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 是的,通常情况下,在单元测试中使用`Scanner`可以会产生一些问题。主要原因是单元测试是自动化测试,其输入是通过程序传递的,而不是从控制台输入。因此,使用`Scanner`在单元测试中很难模拟控制台输入。另外,`Scanner`也不是线程安全的,这也可能导致一些问题。 一种解决方案是使用模拟输入,例如使用`System.setIn()`方法将输入流重定向到一个字符串流。这样,就可以将字符串作为输入传递给被测试的方法,而无需使用`Scanner`。另外,你也可以考虑使用Mockito或其他测试框架来模拟输入。 总之,在单元测试中,最好避免使用`Scanner`,而是使用其他适当的方法来模拟输入。 ### 回答2: 在单元测试不能使用Scanner的主要原因有以下几个方面。 首先,单元测试旨在验证代码的逻辑正确性,而不是与外部资源的交互。Scanner是一种用于从标准输入、文件和其他资源中读取数据的工具类,它与外部资源的交互会导致单元测试的不可控性。单元测试应该是独立、可重复的,如果代码中使用了Scanner,那么测试将受到外部输入的干扰,无法保证测试的一致性和可靠性。 其次,Scanner的使用涉及到与外部资源的交互,例如从控制台读取用户输入。在自动化测试过程中,无法依赖于人工输入,而应该使用自动化工具来模拟输入。而Scanner无法与自动化测试工具集成,无法模拟外部输入。为了确保测试的可控性和可自动化性,应该避免在单元测试中使用Scanner。 最后,Scanner的使用会引入额外的复杂性和依赖性。代码的可测试性是一个重要的软件设计原则,应该在编写代码的过程中考虑到测试的需求。引入Scanner会使代码和测试之间产生紧密的耦合,使得测试变得困难和脆弱。为了保持代码的简洁性和可维护性,应该避免在单元测试中使用Scanner。 综上所述,为了确保单元测试的可靠性和可自动化性,并保持代码的简洁性和可维护性,我们应该避免在单元测试中使用Scanner,而是通过其他方式模拟输入,如使用Mock对象、模拟框架或测试替身来代替Scanner的功能。 ### 回答3: 在单元测试中,Scanner无法使用的主要原因是它需要与用户的交互来获取输入。而在自动化的单元测试环境中,无法进行人工交互,因此无法使用Scanner进行输入操作。 此外,单元测试的目的是测试每个具体的单元(函数或方法)是否按照预期正确运行。Scanner通常用于获取用户输入,而用户的输入是无法预测的,因此无法单元测试中提供准确的输入。 为了在单元测试中模拟用户输入,我们需要使用特殊的测试框架或者工具,例如JUnit或Mockito。这些工具可以模拟用户的输入,以便测试被测单元的各种情况和边界条件。 总之,虽然Scanner是一个方便的输入工具,但在单元测试无法使用。单元测试应该是自动化的,无法进行人工交互。因此,我们需要使用其他方法或工具来模拟用户输入和测试各种输入情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值