使用pytest.fixture解决接口自动化的token传参

本文介绍了如何使用pytest.fixture解决接口自动化中token参数传递的问题。传统的做法是在每个测试用例中设置token变量,但当遇到不同类型的token时,这种方法变得复杂。通过pytest.fixture,可以灵活命名和控制作用域,如`scope="class"`实现类级别的共享,减少重复调用gettoken方法。在conftest.py文件中定义gettoken() fixture,并在测试用例中通过参数引用,简化了token的管理和复用。
摘要由CSDN通过智能技术生成

问题描述:

大部分的接口都需要在headers中传入token参数,原来的方式是在case文件的setup中调用gettoken方法拿到token,存入一个变量,然后在每个case中使用这个token变量

        但后面发现测试用例会有如下场景:

租户的token、用户的token、项目级别的token、**权限的token

        如果都在setup中定义的话,需要定义这么多的token变量,而且不同的case类的setup都需要定义这么多token变量

问题解决:

        通过pytest.fixture解决

        pytest.fixture的优势:

  • 命名方式灵活,不局限于 setup 和teardown 这几个命名,像函数一样自定义命名,然后引用时指定要执行的fixture函数
  • conftest.py 配置里可以实现数据共享,不需要 import 就能自动找到fixture
  • scope参数可以控制fixture函数的有效性:
  1. scope="function" 有效性仅局限在函数。每一个使用到这个fixture的case调用完都会再次调用这个fixture
  2. scope="class" 实现一个case文件的共享。class中只会在第一个执行到的case之前执行这个fixture函数,其他case直接用执行返回的变量,实现了token只调用一个gettoken方法,其他case复用的目的
  3. scope="module" 可以实现多个.py 跨文件共享前置
  4. scope="session
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的接口自动化测试框架。 首先,需要安装pytest库。可以使用以下命令: ```python pip install pytest ``` 然后,可以创建一个项目文件夹,并在其中创建以下文件: 1. `conftest.py`:用于定义全局配置和夹具。 2. `test_*.py`:包含测试用例的文件(可以有多个)。 接下来,我们将逐步介绍如何编写这些文件。 ## conftest.py 在这个文件中,我们可以定义一些全局配置和夹具。这一个例子: ```python import pytest import requests @pytest.fixture(scope="session") def api(): """创建一个API客户端实例""" return requests.Session() @pytest.fixture(scope="session") def base_url(): """定义API的基本URL""" return "http://api.example.com" @pytest.fixture(scope="module") def auth(api, base_url): """执行身份验证,并返回访问令牌""" response = api.post(f"{base_url}/auth", json={"username": "user", "password": "pass"}) token = response.json()["access_token"] api.headers.update({"Authorization": f"Bearer {token}"}) return token ``` 在这个例子中,我们定义了三个夹具: 1. `api`:创建一个API客户端实例,用于发送HTTP请求。 2. `base_url`:定义API的基本URL。 3. `auth`:执行身份验证,并返回访问令牌。 其中,`api`夹具的作用域为`session`,也就是说,在整个测试过程中,只会创建一次这个夹具。而`base_url`和`auth`的作用域为`module`,也就是说,在每个测试模块(即每个`test_*.py`文件)中,都会创建一次这两个夹具。 ## test_*.py 在这些文件中,我们可以编写测试用例。以下是一个例子: ```python def test_get_users(api, base_url, auth): """测试获取所有用户""" response = api.get(f"{base_url}/users") assert response.status_code == 200 assert len(response.json()) > 0 def test_create_user(api, base_url, auth): """测试创建新用户""" data = {"username": "newuser", "password": "newpass"} response = api.post(f"{base_url}/users", json=data) assert response.status_code == 201 assert response.json()["username"] == data["username"] ``` 在这个例子中,我们定义了两个测试用例: 1. `test_get_users`:测试获取所有用户,并检查返回的状态码和用户数量。 2. `test_create_user`:测试创建新用户,并检查返回的状态码和用户名。 这些测试用例将通过以下命令运行: ```python pytest ``` 这将在当前目录中查找所有以`test_*.py`命名的文件,并运行其中的所有测试用例。 总的来说,这是一个非常简单的接口自动化测试框架。您可以根据需要添加更多的夹具和测试用例,并使用pytest的各种特性(如参数化、装饰器等)来扩展它。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值