TestNG-详解preserve-order的作用与测试case的执行顺序
在TestNG xml配置文件中,关于<test>
的配置里面,有一个属性叫preserve-order
,一开始以为这个属性可以用来控制测试case(那些被@Test注解标注的方法)的执行顺序,后来测试了一把,发现没有这种效果,最后上网找了一下这个属性的作用,发现它是用来控制<test>
里面所有<classes>
的执行顺序的。<test>
默认下的preserve-order
为true
,表示<test>
下所有<classes>
顺序执行,
目前使用方法;
1.毕竟UI自动化比较复杂,可能能代码正确,由于其他因素导致代码没有运行,我们不可能每次都重新运行整个Suite。所以每个@Test类,都加上字母,这样单个类运行的时候也能够按照字母A~Z顺序运行
2.没有用Priority=0.1.2.3是因为多个Class中的重复的priority,在运行Suite时,会先运行所有类中priority小的@Test,所以也会导致运行|Suite时顺序紊乱;
其实priority在单个Class中还是很好用的。
eg:
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="Preserve order test runs">
<test name="Regression 1" preserve-order="true">
<classes>
<class name="com.pack.preserve.ClassOne"/>
<class name="com.pack.preserve.ClassTwo"/>
<class name="com.pack.preserve.ClassThree"/>
</classes>
</test>
</suite>
会依次执行ClassOne
、ClassTwo
、ClassThree
的测试方法。
又如:
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="Preserve order test runs">
<test name="Regression 1" preserve-order="true">
<classes>
<class name="com.pack.preserve.ClassTwo"/>
<class name="com.pack.preserve.ClassThree"/>
<class name="com.pack.preserve.ClassOne"/>
</classes>
</test>
</suite>
会依次执行ClassTwo
、ClassThree
、ClassOne
的测试方法。
【注意】 一个<class>
类里面可能存在多个测试方法(被@Test注解的方法),这些方法的执行顺序不受preserve-order
控制。默认测试方法的执行顺序是按照方法名的字典序升序排序执行的。
那么,对于需要按照一定顺序执行测试方法的需求,我们应该如何实现?
有以下几种做法:
(1) 使用priority
指定执行顺序(默认值为0),数值越小,越靠前执行
eg:
@Test(priority = 0)
public void testMethod1() {
}
@Test(priority = 1)
public void testMethod2() {
}
@Test(priority = 2)
public void testMethod3() {
}
这样指定以后,将按照testMethod1
、testMethod2
、testMethod3
顺序执行。
我们不推荐使用这种方式来指定测试方法的执行顺序。因为当你中间需要修改执行顺序的时候,会相当麻烦。而且,多个
<class>
的测试方法,如果指定了相同的priority
,那么会产生与预期不一样的执行顺序,TestNG会先跑所有相同priority
的测试方法,而不管你的测试方法是不是在同一个<class>
里面。
(2) 从方法名称做手脚
因为默认执行顺序是按照方法名的字典序升序排序执行的。那么,有目的地去定制方法名称,就可以让方法按照我们要求的顺序执行,比如:
@Test
public void B() {
}
@Test
public void A() {
}
@Test
public void C() {
}
这样方法就会按照A
、B
、C
顺序执行。
这种方式使得我们命名测试方法名称更加费劲,也不是最优的解决方案。
(3) 在xml里面使用<include>
指定需要执行的方法和顺序
比如:
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd">
<suite name="Preserve order test runs">
<test name="Regression 1" preserve-order="true">
<classes>
<class name="com.pack.preserve.ClassOne">
<methods>
<include name="B" />
<include name="A" />
</methods>
</class>
</classes>
</test>
</suite>
如上配置,ClassOne
会执行两个测试方法,先执行B
,然后执行A
。
我们推荐使用这种方式来指定方法的执行顺序,因为这是最灵活并且最直观的。
参考:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix