首页 » Maven实战 » Maven实战全文在线阅读

《Maven实战》14.6 在profile中激活集成测试

关灯直达底部

很多项目都有大量的单元测试和集成测试,单元测试的粒度较细,运行较快,集成测试粒度较粗,运行比较耗时。在构建项目或者做持续集成的时候,我们都应当尽量运行所有的测试用例,但是当集成测试比较多的时候,高频率地运行它们就会变得不现实。因此有一种更为合理的做法。例如,每次构建时只运行所有的单元测试,因为这不会消耗太多的时间(可能小于5分钟),然后以一个相对低一点的频率执行所有集成测试(例如每天2次)。

TestNG中组的概念能够很好地支持单元测试和集成测试的分类标记。例如,可以使用如下的标注表示一个测试方法属于单元测试:

然后使用类似的标注表示某个测试方法为集成测试:

使用上述方法可以很方便清晰地声明每个测试方法所属的类别。下面的工作就是告诉Maven默认只执行所有的单元测试,只在特定的时候才执行集成测试,见代码清单14-20所示。

代码清单14-20 在profile中配置执行TestNG测试组

如果读者对Maven集成TestNG不熟悉,请先回顾10.7节。代码清单14-20中首先配置了maven-surefire-plugin执行unit测试组,也就是说默认Maven只会执行单元测试。如果想要执行集成测试,就需要激活full profile,在这个profile中配置了maven-surefire-plugin执行unit和integration两个测试组。

有了上述配置,用户就可以根据实际情况配置持续集成服务器。例如,每隔15分钟检查源码更新,如有更新则进行一次默认构建,即只包含单元测试。此外,还可以配置一个定时的任务。例如,每天执行两次,执行一个激活full profile的构建,以包含所有的集成测试。

从该例中可以看到,profile不仅可以用来应对不同的构建环境以保持构建的可移植性,还可以用来分离构建的一些较耗时或者耗资源的行为,并给予更合适的构建频率。