今天遇到了很奇怪的事情,浪费了两个小时。还是因为过于自信,没有仔细看配置。
maven 配置里面怎么也不能用上自己配置的testng.xml, 用了这么久,居然遇到这种问题。为此特意写了一个测试工程。
最后才发现,居然在改用surefire的地方用到了surefire-report,
下面是正确的配置,testng.xml就在项目根目录下,
- <build>
- <plugins>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-surefire-plugin</artifactId>
- <version>2.12</version>
- <configuration>
- <suiteXmlFiles>
- <suiteXmlFile>testng.xml</suiteXmlFile>
- </suiteXmlFiles>
- </configuration>
- </plugin>
- </plugins>
- </build>
当然也可以放在src/test/resources目录下,这样的话要写成
- <suritXmlFile>src/test/resources/testng.xml</suritXmlFile>
- <!DOCTYPE suite SYSTEM “http://testng.org/testng-1.0.dtd” >
- <suite name=“ClientApi” verbose=“1” >
- <test name=“functionTest”>
- <groups>
- <run>
- <exclude name=“g1”/>
- </run>
- </groups>
- <classes>
- <class name=“com.mycompany.testngexample.AppTest”></class>
- </classes>
- </test>
- </suite>
我为什么会犯这个错误,因为我的父工程的pom.xml里面用到了site plugin,site plugin里面用到了surefire-report-plugin。
实际上surefire plugin运行测试代码,并将报告放在${basedir}/target/surefire-reports目录下
文件类型是txt和xml
而surefire report plugin负责将xml文件转换成html文件,这样就可以和site产生的报告合在一起。
所以项目中应该两个都需要,surefire-plugin单独配置,而surefire-report-plugin用在site-plugin内部
如果只用surefire-report plugin,我们就不能控制那些UT需要运行,哪些不需要运行。
这件事情其实暴露了maven的一个问题,如果surefire-plugin不支持某些设置,比如testng的配置,就应该及时报错,而不是悄无声息的做一些默认行为。
友好一点,大家生活都轻松点。
另外,如果将surefire-plugin配置在parent pom中,指定的testng.xml不用任何路径前缀的话,在child project中运行mvn test,就会找child project目录下的testng.xml,互相不干扰。非常方便。