软件测试/测试开发|pytest用例执行顺序,这篇文章就够了

简介: 软件测试/测试开发|pytest用例执行顺序,这篇文章就够了

image.png

前言

在使用unittest测试框架执行测试时,测试用例执行的顺序是默认按照ACSII码的顺序加载测试用例并执行,顺序为:0-9、A-Z、a-z,测试目录、测试模块、测试类、测试方法/测试函数都按照这个规则来加载测试用例。在有的时候,我们并不希望测试用例按照这样的规则来执行,pytest就可以让我们按照我们制定的规则来执行测试用例。本文就向大家介绍一下pytest用例执行顺序的这些事儿。

pytest默认执行顺序

  • 测试目录--->测试模块,按照排序执行:

我们的测试用例如下所示,放在两个文件夹中:

image.png

我们通过命令执行这两个文件夹中的测试用例,结果如下图:

image.png

  • 同一测试模块下的执行顺序
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_后边的第一个字母lr的排列顺序执行的:

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,我们可以在需要时控制用例的执行顺序,以满足特定的测试需求。但在实际操作中,我们不应该让用例的执行有先后顺序,即任意单独的测试用例都是独立的完整的功能点的校验,不对其他用例有依赖。希望本文能够帮到大家!

相关文章
|
14天前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
64 8
|
22天前
|
测试技术 持续交付
探索软件测试中的自动化测试策略
随着软件开发周期的加速和市场需求的不断增长,传统的手动软件测试方法已难以满足现代软件开发的高效性和准确性要求。本文旨在探讨自动化测试在软件测试中的重要性、实施策略及其对提高软件质量的影响。通过分析自动化测试的优势与挑战,以及提供实用的自动化测试工具和框架选择指南,旨在帮助读者理解并应用自动化测试以提升软件开发效率和产品质量。
|
21天前
|
机器学习/深度学习 人工智能 监控
软件测试中的自动化测试策略与最佳实践##
在当今快速发展的软件行业中,自动化测试已成为确保软件质量和加速产品上市的关键工具。本文将探讨自动化测试的重要性,分析不同类型的自动化测试工具和框架,并深入讨论实施自动化测试的最佳实践。通过案例研究和数据分析,我们将揭示如何有效整合自动化测试到软件开发生命周期中,以及它如何帮助团队提高测试效率和覆盖率。 ##
32 1
|
19天前
|
Java 测试技术 API
探索软件测试中的自动化测试框架
本文深入探讨了自动化测试在软件开发中的重要性,并详细介绍了几种流行的自动化测试框架。通过比较它们的优缺点和适用场景,旨在为读者提供选择合适自动化测试工具的参考依据。
|
20天前
|
数据管理 测试技术 持续交付
软件测试中的自动化测试策略与最佳实践
在当今快速迭代的软件开发环境中,自动化测试已成为确保软件质量和加速产品上市的关键手段。本文旨在探讨软件测试中的自动化测试策略,包括选择合适的自动化测试工具、构建有效的自动化测试框架以及实施持续集成和持续部署(CI/CD)。通过分析自动化测试的最佳实践,本文为软件开发团队提供了一系列实用的指南,以优化测试流程、提高测试效率并减少人为错误。
50 4
|
20天前
|
监控 测试技术 定位技术
探索软件测试中的自动化测试框架选择与实施###
本文不概述传统意义上的摘要内容,而是直接以一段对话形式引入,旨在激发读者兴趣。想象一下,你是一名勇敢的探险家,面前摆满了各式各样的自动化测试工具地图,每张地图都指向未知的宝藏——高效、精准的软件测试领域。我们将一起踏上这段旅程,探讨如何根据项目特性选择合适的自动化测试框架,并分享实施过程中的关键步骤与避坑指南。 ###
30 4
|
21天前
|
测试技术 持续交付 数据安全/隐私保护
软件测试的艺术与科学:探索自动化测试框架
在软件开发的世界中,测试是确保产品质量的关键环节。本文将深入探讨自动化测试框架的重要性和实现方法,旨在为读者揭示如何通过自动化测试提升软件测试效率和准确性。我们将从测试的基本概念出发,逐步引导读者了解自动化测试框架的设计和实施过程,以及如何选择合适的工具来支持测试活动。文章不仅提供理论知识,还将分享实用的代码示例,帮助读者将理论应用于实践。无论你是测试新手还是经验丰富的开发者,这篇文章都将为你打开一扇通往更高效、更可靠软件测试的大门。
20 1
|
25天前
|
数据可视化 测试技术 API
软件测试中的自动化测试框架选择与实践
在当今快节奏的软件开发环境中,自动化测试成为了确保软件质量和加速交付的关键。本文将探讨自动化测试的重要性,并比较几种流行的自动化测试框架,包括Selenium、Appium和TestComplete。文章还将提供一些最佳实践和案例研究,以帮助读者更好地理解和实施自动化测试策略。
|
25天前
|
敏捷开发 前端开发 Java
软件测试中的自动化测试框架选择与实践
在当今软件开发生命周期中,自动化测试已成为提升软件质量和开发效率的关键手段。本文旨在探讨自动化测试框架的选择标准及其在实际项目中的应用实践。通过对主流自动化测试框架的分析比较,结合具体案例,本文将阐述如何根据项目需求和团队特点选择合适的自动化测试工具,并分享实施过程中的经验教训。
32 1
|
24天前
|
Java 测试技术 API
软件测试中的自动化测试框架选择与应用##
在快速迭代的软件开发周期中,选择合适的自动化测试框架对于提高软件质量和开发效率至关重要。本文探讨了当前流行的几种自动化测试框架的特点和适用场景,旨在为软件开发团队提供决策依据。 ##