其他分享
首页 > 其他分享> > TestNG用例执行顺序

TestNG用例执行顺序

作者:互联网

大家好,我是刚哥。

TestNG用例的执行顺序有两种方式来指定:注解和XML。

注解

使用@Test的dependsOnMethods属性:

@Test
public void serverStartedOk() {}
 
@Test(dependsOnMethods = { "serverStartedOk" })
public void method1() {}

或者dependsOnGroups属性:

@Test(groups = { "init" })
public void serverStartedOk() {}
 
@Test(groups = { "init" })
public void initEnvironment() {}
 
@Test(dependsOnGroups = { "init.*" })
public void method1() {}

@Before/After也能实现初始化,但是它们的结果不会出现在测试报告中。

默认TestNG会强制校验,依赖的用例必须成功才会执行当前用例,否则当前用例会被标记为SKIP,这叫做强依赖。通过设置alwaysRun=true可以变成弱依赖,无论依赖用例执行成功与否,都会执行当前用例。

需要特别注意的是,依赖测试方法是按照测试类来进行执行的(group by class),比如b()方法依赖的a()方法有多个实例,那么会按照以下顺序执行:

a(1)
a(2)
b(2)
b(2)

举个实际的例子,登入和登出,如果想达到以下效果:

signIn("us")
signOut("us")
signIn("uk")
signOut("uk")

那么需要在XML中进行配置:

  <suite name="Factory" group-by-instances="true">
or
  <test name="Factory" group-by-instances="true">

XML

在testng.xml中使用<dependencies>depends-on来指定用例顺序:

<test name="My suite">
  <groups>
    <dependencies>
      <group name="c" depends-on="a  b" />
      <group name="z" depends-on="c" />
    </dependencies>
  </groups>
</test>

参考资料:

https://testng.org/doc/documentation-main.html 5.7 - Dependencies

标签:顺序,void,TestNG,用例,依赖,Test,执行,public
来源: https://www.cnblogs.com/df888/p/15784012.html