pytest测试用例执行后log文件下无内容 pytest用例执行顺序

admin2024-06-11  6

前言
在unittest框架中,默认按照ACSII码的顺序加载测试用例并执行,顺序为:09、AZ、a~z,测试目录、测试模块、测试类、测试方法/测试函数都按照这个规则来加载测试用例。

pytest 中的用例执行顺序与unittest 是不一样的,pytest有默认的执行顺序,还可以自定义执行顺序。

pytest 默认执行顺序
测试目录、测试模块,按照排序顺序执行

pytest测试用例执行后log文件下无内容 pytest用例执行顺序,pytest测试用例执行后log文件下无内容 pytest用例执行顺序_自定义,第1张

执行顺序如下:

pytest测试用例执行后log文件下无内容 pytest用例执行顺序,pytest测试用例执行后log文件下无内容 pytest用例执行顺序_执行顺序_02,第2张

 同一测试模块下的执行顺序

import pytest
 
class TestOrder:
 
    def test_e(self):
        print("test_e")
 
    def test_4(self):
        print("test_4")
 
 
def test_b():
    print("test_a")
 
def test_a():
    print("test_a")
 
def test_2():
    print("test_2")
 
def test_1():
    print("test_1")
 
 
if __name__ == '__main__':
    pytest.main()

执行顺序如下:

pytest测试用例执行后log文件下无内容 pytest用例执行顺序,pytest测试用例执行后log文件下无内容 pytest用例执行顺序_执行顺序_03,第3张

自定义执行顺序

pytest 框架支持自定义测试用例的执行顺序,需要安装pytest-ordering插件。

安装
pip install pytest-ordering
使用

需要使用 @pytest.mark.run(),代码如下:

import pytest
 
class TestOrder:
 
    def test_e(self):
        print("test_e")
 
    def test_4(self):
        print("test_4")
 
 
def test_b():
    print("test_a")
 
@pytest.mark.run(order=2)
def test_a():
    print("test_a")
 
@pytest.mark.run(order=1)
def test_2():
    print("test_2")
 
def test_1():
    print("test_1")
 
 
if __name__ == '__main__':
    pytest.main()

执行顺序如下:

pytest测试用例执行后log文件下无内容 pytest用例执行顺序,pytest测试用例执行后log文件下无内容 pytest用例执行顺序_自定义_04,第4张

在测试模块中,先执行被@pytest.mark.run() 标记的测试方法/测试函数,再按默认顺序执行其他的。

总结
虽然 pytest 可以自定义测试用例执行顺序,但是实际测试用例设计的过程中,不应该让用例的执行有先后顺序,即任意单独的测试用例都是独立的完整的功能点的校验,不对其他用例有依赖。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明原文出处。如若内容造成侵权/违法违规/事实不符,请联系SD编程学习网:675289112@qq.com进行投诉反馈,一经查实,立即删除!