前言
在使用 unittest 测试框架执行测试时,测试用例执行的顺序是默认按照 ACSII 码的顺序加载测试用例并执行,顺序为:0-9、A-Z、a-z,测试目录、测试模块、测试类、测试方法/测试函数都按照这个规则来加载测试用例。在有的时候,我们并不希望测试用例按照这样的规则来执行,pytest 就可以让我们按照我们制定的规则来执行测试用例。本文就向大家介绍一下 pytest 用例执行顺序的这些事儿。
pytest 默认执行顺序
我们的测试用例如下所示,放在两个文件夹中:
我们通过命令执行这两个文件夹中的测试用例,结果如下图:
import pytest
class TestOrder:
def test_e(self):
print("test_e")
def test_4(self):
print("test_4")
def test_b(self):
print("test_b")
def test_a(self):
print("test_a")
def test_2(self):
print("test_2")
def test_1(self):
print("test_1")
if __name__ == '__main__':
pytest.main(['demo.py','-s'])
复制代码
执行结果如下:
demo.py test_e
.test_4
.test_b
.test_a
.test_2
.test_1
.
复制代码
我们可以看出默认是自上而下依次执行的,如若遇到测试用例名称过长,也会根据字母的排序顺序执行,如下的代码执行时,就不会是自上而下,而是根据user_
后边的第一个字母l
、r
的排列顺序执行的:
class Demo:
def test_user_register(self):
'''注册'''
print('=======test_user_register============')
def test_user_login(self):
'''登录'''
print('=======test_user_login========')
if __name__ == '__main__':
pytest.main(['test_user.py', '-vs'])
复制代码
运行结果如下:
test_user.py::UserApiTest::test_user_login
test_user.py::UserApiTest::test_user_register
复制代码
自定义执行顺序
在我们的工作中,有时候需要pytest
按照我们的需要的顺序来执行测试用例,pytest 提供了一个插件来帮助我们实现这个功能,就是pytest-ordering
,安装命令如下:
pip install pytest-ordering
复制代码
注:pytest-ordering
插件通常和@pytest.mark.run()
结合使用。
class Test01():
def test_02(self):
print('\n---用例02---')
@pytest.mark.run(order=2)
def test_01(self):
print('\n---用例01---')
@pytest.mark.run(order=1)
def test_03(self):
print('\n---用例03---')
def test_04(self):
print('\n---用例04---')
if __name__ == '__main__':
pytest.main(['test_demo.py', '-s'])
复制代码
运行结果如下:
test_demo.py
---用例03---
.
---用例01---
.
---用例02---
.
---用例04---
.
复制代码
通过【运行结果】可以看出来,用例已经按照我们的要求,先执行用例 3,在执行用例 1,最后执行用例 2 的方法来的,这里需要注意的是,如果你在那个用例上面没有添加执行顺序要求的话,他会先执行带有标记的用例,然后根据未标记的用例顺序进行执行。
总结
pytest 管理用例执行顺序的方式比较灵活,并且允许并行执行以提高效率。尽管它默认的执行顺序可能不符合期望,但通过一些装饰器、插件或者利用 Fixture 的 scope,我们可以在需要时控制用例的执行顺序,以满足特定的测试需求。但在实际操作中,我们不应该让用例的执行有先后顺序,即任意单独的测试用例都是独立的完整的功能点的校验,不对其他用例有依赖。希望本文能够帮到大家!
获取更多技术资料,请点击!
评论