测者的测试技术手册:Junit执行单元测试用例成功,mvn test却失败的问题和解决方法

时间:2021-11-17 20:58:23

今天遇见了一个奇怪的问题,在IDE中run unit test,全部cases都成功了,但是后来通过mvn test运行case确保错了。在寻求原因的同时也找到了对应的解决方法。

Run Unit Test和Maven test的区别

差异1:在IDE中通过选中单元测试路径,点击右键选择run test和点击maven中的test是有区别的。在Maven执行测试的过程中,是不允许测试cases访问其他项目的测试类和其他项目的resources下文件的。也就是说,在a/src/test/java下的测试用例,是不能引用b/src/test/java中的类的,同时也不允许访问b/src/test/resources下的资源的。但是在IDE中的Run Unit Test几乎是没有这样的限制的。

差异2:Maven强制要求src/test/java下不能存在resource的文件,必须放到src/test/reources文件夹下,但是IDE却很少有对应的约束。

这些约束就是导致IDE下Run Unit Test是成功的,但是在Maven中失败的原因。

因此测者提醒,提交单元测试代码之前,一定要在本地mvn test一次脚本。

解决的办法

在maven插件配置:(surefire2.14以下版本)

  1. <plugin>

  2.     <groupId>org.apache.maven.plugins</groupId>

  3.     <artifactId>maven-surefire-plugin</artifactId>

  4.     <version>2.12</version>

  5.     <configuration>

  6.         <forkMode>always</forkMode>

  7.     </configuration>

  8. </plugin>

重点加入configureation的配置部分

在maven插件配置:(surefire2.14及其以上版本)

  1. <plugin>

  2.     <groupId>org.apache.maven.plugins</groupId>

  3.     <artifactId>maven-surefire-plugin</artifactId>

  4.     <version>2.19.1</version>

  5.     <configuration>

  6.         <reuseForks>false</reuseForks>

  7.         <forkCount>1</forkCount>

  8.     </configuration>

  9. </plugin>

在2.14以上的版本中,forkMode配置项已经废弃了。

另一个可能有效的方法

有时候在webapp项目中进行测试的时候,需要WEB-INF文件夹放在Class Path中,配置如下:

  1. <plugin>

  2.     <groupId>org.apache.maven.plugins</groupId>

  3.     <artifactId>maven-surefire-plugin</artifactId>

  4.     <version>2.19.1</version>

  5.     <configuration>

  6.         <reuseForks>false</reuseForks>

  7.         <forkCount>1</forkCount>

  8.         <argLine>-Xmx1024m -XX:MaxPermSize=256m -Dfile.encoding=UTF-8 -Xverify:none</argLine>

  9.         <additionalClasspathElements>

  10.             <additionalClasspathElement>${basedir}/src/main/webapp/‌WEB-INF/</additionalClasspathElement>

  11.         </additionalClasspathElements>

  12.     </configuration>

  13. </plugin>

关注测者,关注测试