使用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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值