接口自动化测试失败重试机制-rerunfailures

前言

在执行接口测试用例的过程中,稳定性在整个测试运行中是非常重要,但经常会遇到服务器不稳定或者网络不稳定的情况,只执行一次用例结果可能说明不了问题,会把用例判断了“假失败”,为了避免这种假判定,这个时候可以引入重试机制,pytest框架相较于unittest的一大优势就在于拥有用例失败的重试机制,以此来应对环境不稳定问题或者是测试用例脚本的不稳定性问题。能够大幅提高用例的成功率,但是也会增加执行时间。
使用到pytest的插件,插件名称为rerunfailures,该插件有两种用法一种是装饰器的方法,另一种是命令行参数的方法。以下会介绍两个方法在项目中的使用案例。

第一种方法是通过装饰器的方法进行用例的失败重跑。装饰器的使用格式说明:

@pytest.mark.flaky(reruns=重试次数, reruns_delay=每次重试之间的间隔设置(单位:秒))

下面用test_demo的测试用例代码举例:

import pytest
#失败case重跑两次,每次间隔5s
@pytest.mark.flaky(reruns=2, reruns_delay=5)
@pytest.mark.parametrize('test_data',[1,2])
def test_demo(test_data):
    assert test_data == 1

执行结果如图所示:执行用例demo一共执行了4次,第一个用例数据=1一次通过,第二个用例断言失败后执行重试RERUN两次,最后测试结果为fail。
在这里插入图片描述

第二种方法是命令行参数的方法,命令行的参数格式为:

pytest --reruns 3 --reruns-delay 2
pytest -vs --reruns=3 --reruns-delay=2 
# 参数详解:其中reruns空格3 表示失败重新运行3次,reruns-delay空格2 表示重新执行需要等待2秒。(这里也可以使用等于来进行表示)

下面用test_demo的测试用例代码举例:

import pytest
@pytest.mark.parametrize('test_data',[1,2])
def test_demo(test_data):
    assert test_data == 1
if __name__ == '__main__':
    #失败case重跑三次,每次间隔5s
pytest.main(['-v','--reruns=3','--reruns-delay=5','test_demo.py'])

执行结果如图所示:我们执行用例demo一共执行了5次,第一个用例数据=1,一次通过,第二个用例断言失败后执行重试RERUN三次,最后测试结果为fail。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值