Python测试框架: ​封装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测试用例可以提高测试代码的质量,降低测试过程的复杂度,使自动化测试用例易于维护,从而提高测试效率。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的接口自动化框架: 1. 安装依赖库 ``` pip install pytest pip install requests ``` 2. 创建项目目录结构 ``` project ├── api │ ├── __init__.py │ └── user_api.py ├── config │ └── config.ini ├── testcases │ ├── __init__.py │ └── test_user_api.py ├── conftest.py └── pytest.ini ``` 3. 编写配置文件 config/config.ini ``` [host] url = http://localhost:8080/api/ ``` 4. 编写 API 接口封装 api/user_api.py ```python import requests import json from configparser import ConfigParser class UserApi: def __init__(self): self.config = ConfigParser() self.config.read('config/config.ini') self.url = self.config.get('host', 'url') def get_user(self, user_id): url = self.url + f'user/{user_id}' response = requests.get(url) return json.loads(response.text) def add_user(self, data): url = self.url + 'user' headers = {'Content-Type': 'application/json'} response = requests.post(url, data=json.dumps(data), headers=headers) return json.loads(response.text) def update_user(self, user_id, data): url = self.url + f'user/{user_id}' headers = {'Content-Type': 'application/json'} response = requests.put(url, data=json.dumps(data), headers=headers) return json.loads(response.text) def delete_user(self, user_id): url = self.url + f'user/{user_id}' response = requests.delete(url) return json.loads(response.text) ``` 5. 编写测试用例 testcases/test_user_api.py ```python from api.user_api import UserApi class TestUserApi: def setup_class(self): self.api = UserApi() def test_get_user(self): user_id = 1 user = self.api.get_user(user_id) assert user['id'] == user_id def test_add_user(self): data = {'name': 'test', 'age': 20} user = self.api.add_user(data) assert user['name'] == data['name'] def test_update_user(self): user_id = 1 data = {'name': 'test1'} user = self.api.update_user(user_id, data) assert user['name'] == data['name'] def test_delete_user(self): user_id = 1 user = self.api.delete_user(user_id) assert user['id'] == user_id ``` 6. 运行测试 在项目根目录下运行以下命令: ``` pytest ``` 运行结果如下: ``` ============================= test session starts ============================== platform win32 -- Python 3.9.5, pytest-6.2.4, py-1.10.0, pluggy-0.13.1 rootdir: D:\project plugins: Faker-8.13.0 collected 4 items testcases\test_user_api.py .... [100%] ============================== 4 passed in 0.48s ============================== ``` 以上就是一个简单的接口自动化框架,你可以根据实际情况进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值