今天遇到了很奇怪的事情,浪费了两个小时。还是因为过于自信,没有仔细看配置。
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,互相不干扰。非常方便。