最近看了一些TestNG的源代码,觉得这个测试框架的功能其实满强大的,里面的功能点很多,以后有机会慢慢分析一下它们的实现方法,今天主要介绍一下它如何实现方法之间的依赖关系。
背景知识:
想必大家都知道拓扑排序吧,拓扑排序最经典的应用场景就是对于Jobs/Tasks的规划,即对于存在前后依赖关系的任务如何安排一个计划来执行它们。
相关的资料,可以参考维基百科:
http://en.wikipedia.org/wiki/Topological_sorting里面介绍的比较详细。
那么反映到我们的测试场景中,有一些测试方法之间是存在依赖关系的,比如在对一个Serverside的class进行测试的时候:
@Test
public void serverStartedOk(){}
@Test(dependsOnMethods={ "serverStartedOk" })
public void method1() {}
显然,method1是依赖于serverStartedOK这个方法的,即在被依赖的方法成功执行之后,method1才会执行。
当然以上的代码存在一个小问题:
它的可维护性不太好,在method1的@Test注解的dependsOnMethods属性中,直接将依赖方法的名字以字符串的形式传入,这显然是不太合适的。所以,除了这种dependsOnMethods的依赖方式,TestNG还支持了另外一种对于依赖的声明方式,即dependsOnGroups:
@Test(groups = { "init" })
public void serverStartedOk(){}
@Test(groups = { "init" })
public void initEnvironment(){}
@Test(dependsOnGroups = { "init.*})
public void method1() {}
以上代码来自:http://testng.org/doc/documentation-main.html#dependent-methods
首先将初始化方法声明属于init