使用pytest框架编写测试用例的过程中,封装测试用例是一个非常重要的技术,本文将介绍如何封装pytest测试用例。
1. 为什么要封装pytest测试用例
进行自动化测试,需要编写大量自动化测试用例,若每个测试用例都写成独立的函数,在编写和维护测试用例时会遇到以下问题:
1)代码冗余
不同的测试用例需要复用相同的代码,就需要在每个测试用例中都编写相同的代码,会导致代码冗余。
2)可读性差
每个测试用例都是一个独立的函数,测试用例就会分散在多个文件中,代码阅读比较困难。
3)维护成本高
若测试用例需要修改,就需要在多个文件中进行修改,这会增加修改的难度和成本。
为了解决上面的问题,可以采用封装测试用例的方式。
2. 如何封装pytest测试用例
1)使用pytest.fixture装饰器
pytest.fixture装饰器可以定义测试用例所需要的前置条件和后置条件,从而实现测试用例之间的复用。
代码实例:
import pytest
@pytest.fixture
def login():
# 登录逻辑
return user_id
def test_case1(login):
# 测试用例1
pass
def test_case2(login):
# 测试用例2
pass
上述代码定义一个登录的前置条件,然后在所有需要登录的测试用例中都调用这个前置条件,就不用在每个测试用例中都编写登录的代码。
2) 使用pytest.mark.parametrize装饰器
pytest.mark.parametrize装饰器可以定义多组输入参数和预期结果,从而实现测试用例的参数化。
代码实例:
import pytest
def add(x, y):
return x + y
@pytest.mark.parametrize("x,y,result", [(1,2,3), (2,3,5), (3,4,7)])
def test_add(x, y, result):
assert add(x, y) == result
3) 使用pytest.mark组织测试用例
pytest.mark可以定义多个标签,用以标识测试用例所属的测试类别。
代码实例:
import pytest
@pytest.mark.webtest
def test_case1():
# Web UI自动化测试用例1
pass
@pytest.mark.webtest
def test_case2():
# Web UI自动化测试用例2
pass
@pytest.mark.apitest
def test_case3():
# API自动化测试用例1
pass
@pytest.mark.apitest
def test_case4():
# API自动化测试用例2
pass
上述代码,将所有Web UI自动化测试用例标记为webtest,然后使用pytest -m选项运行这些测试用例,这样可以避免出现测试用例重复执行或漏测的情况。
总之,封装pytest测试用例可以提高测试代码的质量,降低测试过程的复杂度,使自动化测试用例易于维护,从而提高测试效率。
下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!
软件测试面试小程序
被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!
涵盖以下这些面试题板块:
1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux
6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础
获取方式 :