使用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测试用例可以提高测试代码的质量,降低测试过程的复杂度,使自动化测试用例易于维护,从而提高测试效率。
使用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测试用例可以提高测试代码的质量,降低测试过程的复杂度,使自动化测试用例易于维护,从而提高测试效率。
如果文章对你有帮助,记得点赞,收藏,加关注。会不定期分享一些干货哦......
行动吧,在路上总比一直观望的要好,未来的你肯定会感 谢现在拼搏的自己!如果想学习提升找不到资料,没人答疑解惑时,请及时加入扣群: 320231853,里面有各种软件测试+开发资料和技术可以一起交流学习哦。
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:
这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!