分享

谈一谈JUnit神奇的报错 java.lang.Exception:No tests found matching

 然并卵书屋 2017-07-10

最近在学习spring+SpringMVC+MyBatis,一个人的挖掘过程确实有点艰难,尤其是有一些神奇的报错让你会很蛋疼。特别是接触一些框架还是最新版本的时候,会因为版本问题出现很多错误,欢迎大家一起学习交流害羞

这篇就说一下困扰我昨晚2小时的一个报错,nitializationError(org.junit.runner.manipulation.Filter)或者No tests found matching异常,查阅了很多资料,总结一下这些情况和解决办法。

1.最容易发现的错误,就如报错所说,没有找到test方法就是因为忘记在方法前加 @Test 注解了。

应该是这样:

public class TestCase {
  @Test
  public void checkSomething() {
    //...
  }
}

2.使用Maven构建项目时候,pom文件中的JUnit版本和classpath中的版本不一致,删掉一个就好(这种应该没什么人吧。。。)。

3.你可以尝试重启Eclipse或者重建或者刷新项目,重新清理,关闭重新打开项目……有时候是Eclipse的问题。

4.如果是测试方法命名不规范的问题,你可以尝试把方法统一改为 testXXX(),这是JUnit3风格。

5.测试类所在文件夹必须为源文件夹source files,如果不是,选择 'Build path' -> 'Use as a source folder'。

6.看你的测试类是否继承TestCase,如果是,删除继承,并不需要继承,例如:

public class MyTestCase extends TestCase{
  @Test
  public void checkSomething() {
    //...
  }
}
//Result> AssertionFailedError: No test Found in MyTestCase

应该是下面的TestCase

public class MyTestCase {
  @Test
  public void checkSomething() {
    //...
  }
}
//Works fine
7.有些小伙伴右键选择特定的测试方法会报错,但是运行整个测试类却不会,不信可以试试大笑

8.如果你的Eclipse版本太旧,也会导致,更新版本。

9.最后一个就是我的这个问题:版本不兼容,需要更换JUnit或者spring版本

报错信息具体如下,会有两种

  1. <span style="font-size:14px;">java.lang.Exception: No tests found matching [{ExactMatcher:fDisplayName=testQueryById], {ExactMatcher:fDisplayName=testQueryById(org.seckill.dao.SeckillDaoTest)], {LeadingIdentifierMatcher:fClassName=org.seckill.dao.SeckillDaoTest,fLeadingIdentifier=testQueryById]] from org.junit.internal.requests.ClassRequest@1698c449  
  2.     at org.junit.internal.requests.FilterRequest.getRunner(FilterRequest.java:35)  
  3.     at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createFilteredTest(JUnit4TestLoader.java:77)  
  4.     at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createTest(JUnit4TestLoader.java:68)  
  5.     at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.loadTests(JUnit4TestLoader.java:43)  
  6.     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:444)  
  7.     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)  
  8.     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)  
  9.     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)  
  10.   
  11. </span>  

或者:

  1. <span style="font-size:14px;">java.lang.ExceptionInInitializerError  
  2.     at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)  
  3.     at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)  
  4.     at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)  
  5.     at java.lang.reflect.Constructor.newInstance(Constructor.java:408)  
  6.     at org.junit.internal.builders.AnnotatedBuilder.buildRunner(AnnotatedBuilder.java:29)  
  7.     at org.junit.internal.builders.AnnotatedBuilder.runnerForClass(AnnotatedBuilder.java:21)  
  8.     at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)  
  9.     at org.junit.internal.builders.AllDefaultPossibilitiesBuilder.runnerForClass(AllDefaultPossibilitiesBuilder.java:26)  
  10.     at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59)  
  11.     at org.junit.internal.requests.ClassRequest.getRunner(ClassRequest.java:26)  
  12.     at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createUnfilteredTest(JUnit4TestLoader.java:84)  
  13.     at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.createTest(JUnit4TestLoader.java:70)  
  14.     at org.eclipse.jdt.internal.junit4.runner.JUnit4TestLoader.loadTests(JUnit4TestLoader.java:43)  
  15.     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:444)  
  16.     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)  
  17.     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)  
  18.     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)  
  19. Caused by: java.lang.IllegalStateException: SpringJUnit4ClassRunner requires JUnit 4.12 or higher.  
  20.     at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.<clinit>(SpringJUnit4ClassRunner.java:102)  
  21.     ... 17 more  
  22. </span>  
No tests found matching和ExceptionInInitializerError这两个错误其实都是一个,都是初始化错误,测试用例没有成功。

  1. <span style="font-size:10px;">package org.seckill.dao;  
  2.   
  3. import javax.annotation.Resource;  
  4.   
  5. import org.junit.Test;  
  6. import org.junit.runner.RunWith;  
  7. import org.seckill.entity.Seckill;  
  8. import org.springframework.test.context.ContextConfiguration;  
  9. import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;  
  10.   
  11. /** 
  12.  * project:seckill 
  13.  * @author Daley 下午10:20:28 2016年12月20日 2016 
  14.  * 配置Spring和JUnit整合 ,JUnit启动时加载SpringIOC容器 
  15.  */  
  16. @RunWith(SpringJUnit4ClassRunner.class)  
  17. //告诉JUnitSpring配置文件  
  18. @ContextConfiguration({"classpath:spring/spring-dao.xml"})  
  19. public class SeckillDaoTest {  
  20.     //注入Dao实现类依赖  
  21.     @Resource  
  22.     private SeckillDao seckillDao;  
  23.     @Test  
  24.     public void testQueryById() {  
  25.         long id=1000;  
  26.         Seckill seckill=seckillDao.queryById(id);  
  27.         System.out.println(seckill.getName());  
  28.         System.out.println(seckill);  
  29.     }  
  30.   
  31. }</span>  

由于试过了很多方法,这时我有了一个最不愿意的怀疑,难道是版本不兼容问题?

于是我把 @RunWith注解删掉,发现这时报的是空指针错误,说明没有加载spring容器,我使用的SpringFramework版本是 4.3.4.RELEASE ,这个是最终版本应该是比较稳定和兼容性好呀,那么问题可能就是JUnit不兼容了,我使用的是JUnit4.10
当我换成4.11时候,还是报错,但是换到最新的4.12版本的时候,这个报错消失了!出现了这个可爱的颜色。


嗯……绿色一定是我的最爱

顺便贴出配置信息:

  1. <span style="font-size:14px;"><dependency>  
  2. <groupId>junit</groupId>  
  3. <artifactId>junit</artifactId>  
  4. <version>4.12</version>  
  5. </dependency>  
  6. <dependency>  
  7. <groupId>org.springframework</groupId>  
  8. <artifactId>spring-core</artifactId>  
  9. <version>4.3.4.RELEASE</version>  
  10. </dependency>  
  11. <!-- https:///artifact/org.springframework/spring-context -->  
  12. <dependency>  
  13. <groupId>org.springframework</groupId>  
  14. <artifactId>spring-context</artifactId>  
  15. <version>4.3.4.RELEASE</version>  
  16. </dependency>  
  17. <!-- https:///artifact/org.springframework/spring-beans -->  
  18. <dependency>  
  19. <groupId>org.springframework</groupId>  
  20. <artifactId>spring-beans</artifactId>  
  21. <version>4.3.4.RELEASE</version>  
  22. </dependency>  
  23. <!-- https:///artifact/org.springframework/spring-jdbc -->  
  24. <dependency>  
  25. <groupId>org.springframework</groupId>  
  26. <artifactId>spring-jdbc</artifactId>  
  27. <version>4.3.4.RELEASE</version>  
  28. </dependency>  
  29. <!-- https:///artifact/org.springframework/spring-tx -->  
  30. <dependency>  
  31. <groupId>org.springframework</groupId>  
  32. <artifactId>spring-tx</artifactId>  
  33. <version>4.3.4.RELEASE</version>  
  34. </dependency>  
  35. <!-- https:///artifact/org.springframework/spring-web -->  
  36. <dependency>  
  37. <groupId>org.springframework</groupId>  
  38. <artifactId>spring-web</artifactId>  
  39. <version>4.3.4.RELEASE</version>  
  40. </dependency>  
  41. <!-- https:///artifact/org.springframework/spring-webmvc -->  
  42. <dependency>  
  43. <groupId>org.springframework</groupId>  
  44. <artifactId>spring-webmvc</artifactId>  
  45. <version>4.3.4.RELEASE</version>  
  46. </dependency>  
  47. <!-- https:///artifact/org.springframework/spring-test -->  
  48. <dependency>  
  49. <groupId>org.springframework</groupId>  
  50. <artifactId>spring-test</artifactId>  
  51. <version>4.3.4.RELEASE</version>  
  52. </dependency></span>  


    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约