zoukankan      html  css  js  c++  java
  • pytest框架之rerunfailures失败重运行机制

    web自动化测试中,稳定性在整个测试运行中都至关重要,但不能保证测试脚本或者测试环境一直都能够稳定,它牵扯到诸多因素,在这里就不赘述,pytest框架相较于unittest的一大优势就在于拥有用例失败的重试机制,以此来应对环境不稳定问题或者是测试用例脚本的不稳定性问题。

    一、安装

    重运行机制使用到了pytest的插件,插件名称为:rerunfailures,要使用它,需要先安装此插件

    pip install pytest-rerunfailures

    二、使用方法

    1.命令行参数形式

    • 命令:pytest --reruns 重试次数

      比如:pytest --reruns 2  表示:运行失败的用例可以重新运行2次

    • 命令:pytest --reruns 重试次数 --reruns-delay 次数之间的延时设置(单位:秒)

      比如:pytest --reruns 2 --reruns-delay 5  表示:运行失败的用例可以重新运行2次,第一次和第二次的间隔时间为5秒钟

    import pytest
    
    
    def test_demo_01():
        b = 1 + 2
        assert 3 == b
    
    
    def test_demo_02():
        b = 1 + 2
        assert 2 == b
    
    
    if __name__ == '__main__':
        pytest.main(['--reruns', '3', '--reruns-delay', '5'])

      运行结果:

      

    2.使用装饰器

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

    import pytest
    
    
    def test_demo_01():
        b = 1 + 2
        assert 3 == b
    
    
    @pytest.mark.flaky(reruns=3, reruns_delay=5)
    def test_demo_02():
        b = 1 + 2
        assert 2 == b

      运行结果:

      

  • 相关阅读:
    详解单例模式
    Spring整合Mybatis案例,献给初学的朋友
    Java反射学习总结
    IDEA JSP项目构建及学习心得
    SQL Server数据库表锁定原理以及如何解除表的锁定
    MySQL锁定机制简介
    Cassandra简介
    Linux机器上实现程序自动部署以及更新
    服务器时间同步平台化
    内存查看平台化
  • 原文地址:https://www.cnblogs.com/xiaogongjin/p/11683551.html
Copyright © 2011-2022 走看看