很多项目都有大量的单元测试和集成测试,单元测试的粒度较细,运行较快,集成测试粒度较细,运行较快,集成测试粒度较粗,运行比较耗时。在构建项目或者做持续集成的时候,我们都应当尽量运行所有的测试用例,但是当集成测试比较多的时候,高频率的运行他们就会变得不现实。因此有一种更为合理的做法。例如,每次构建时只运行所有的单元测试,因为这不会消耗太多的时间(可能小于5分钟),然后以一个相对低一点的频率执行所有集成测试(例如每天2次)。
TestNG中组的概念能够很好的支持单元测试和集成测试的分类标记。例如,可以使用如下的标注表示一个测试方法属于单元测试:
@Test(groups={"unit"})
然后使用类似的标注表示某个测试方法为集成测试:
@Test(groups={"integration"})
使用上述方法可以很方便清晰的声明每个测试方法所属的类别。下面的工作就是告诉Maven默认只执行所有的单元测试,只在特定的时候才执行集成测试,见下面所示。
<project>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.5</version>
<configuration>
<groups>unit</groups>
</configuration>
</plugin>
</plugins>
</build>
<profiles>
<profile>
<id>full</id>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.5</version>
<configuration>
<groups>unit,integration</groups>
</configuration>
</plugin>
</plugins>
</build>
</profile>
</profiles>
</project>
上面首先配置了maven-surefire-plugin执行unit测试组,也就是说默认Maven只会执行单元测试。如果想要执行集成测试,就需要激活full profile,在这个profile中配置了maven-surefire-plugin执行unit和integration两个测试组。
有了上述配置,用户就可以根据实际情况配置持续集成服务器。例如,每隔15分重检查源码更新,如有更新则进行一次默认构建,即只包含单元测试。此外,还可以配置一个定时的任务。例如,每天执行两次,执行一个激活full profile的构建,以包含所有的集成测试。
从该例中可以看到,profile不仅可以用来应对不同的构建环境以保持构建的可移植性,还可以用来分离构建的一些较耗时或者耗资源的行为,并给予更适合的构建频率。