pytest接口测试(四)fixture传参数request

fixture传参数request

前言

有的测试用例,需要依赖于某些特定的case才可以执行,比如登录获取到token,后面的请求都需要带着,为了确保在同一用户,必须带着和登录时获取的cookies。

大部分的用例都会先登录,就需要把登录单独抽出来写个函数,其他用例全部调用这个登录函数就行,但是登录的账号不能写死。

一、函数传参

单独写个登录函数,传2个参数user和password,写用例的时候调用登录函数,输入几组user、password参数化。需要用到装饰器$pytest.mark.parametrize,里面写两个参数

  • 第1个参数是字符串,多个参数中间用逗号隔开
  • 第2个参数是list,多组数组用元组类型
import pytest

def login(user, password):
    '''登录函数'''
    print('用户名:%s' % user)
    print('密码:%s' % password)
    return 'hello'

login_data = [('admin', '123456'), ('admin','')]

# 装饰器
@pytest.mark.parametrize('user, password', login_data)
def test_login(user, password):
    '''登录测试用例'''
    result = login(user, password)
    assert result == 'hello'

if __name__ == '__main__':
    pytest.main('-s', 'day0110_fixture.py')
'''
运行结果
============================= test session starts =============================
platform win32 -- Python 3.6.6, pytest-4.5.0, py-1.8.0, pluggy-0.13.1
rootdir: F:\python work\youyou_class\study_pytestcollected 2 items

day0110_fixture.py .用户名:admin
密码:123456
.用户名:admin
密码:
                                                    [100%]

========================== 2 passed in 0.02 seconds ===========================
'''

request参数

request就是我需要什么东西,用来接受参数,用到@pytest.fixture装饰器,传参就用默认的request参数,user = request.param 这一步是接收传入的参数。

import pytest


# 测试账号数据
test_data = ["admin1", "admin2"]

@pytest.fixture(scope="function")
def login(request):
    user = request.param
    print("登录账户:%s"%user)
    return user

@pytest.mark.parametrize("login", test_data, indirect=True)
def test_login(login):
    """登录用例"""
    a = login
    print("测试用例中login的返回值:%s" % a)
    assert a != ""

indirect=True 参数是为了把login当作一个函数去执行,而不是一个参数

request传两个参数

如果用到@pytest.fixture,里面用2个参数情况,可以把多个参数用一个字典去存储,这样最终还是只传一个参数。
不同的参数再从字典里面取对应key值就行,如: user = request.param[“user”]

#_*_coding:utf-8_*_
# 作者     :Administrator
# 创建时间 :2020/1/1018:18
# 文件     :day0110_fixture.py

import pytest

@pytest.fixture(scope='function')
def login(request):
    '''登录函数'''
    user = request.param['user']
    password = request.param['password']
    print('用户名:%s' % user)
    print('密码:%s' % password)
    return 'hello'

login_data = [{'user': 'admin', 'password': '123456'}, {'user': 'admin', 'password': '1'}]

# 装饰器
@pytest.mark.parametrize('login',  login_data, indirect=True)
def test_login(login):
    '''登录测试用例'''
    result = login
    assert result == 'hello'

if __name__ == '__main__':
    pytest.main('-s', 'day0110_fixture.py')
'''
运行结果:
============================= test session starts =============================
platform win32 -- Python 3.6.6, pytest-4.5.0, py-1.8.0, pluggy-0.13.1
rootdir: F:\python work\youyou_class\study_pytestcollected 2 items

day0110_fixture.py 用户名:admin
密码:123456
.用户名:admin
密码:1
.                                                    [100%]

========================== 2 passed in 0.02 seconds ===========================

'''
  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于pytest接口自动化测试,你可以使用pytest框架来编写和执行测试用例。下面是一些常见的步骤和技巧: 1. 安装pytest:使用pip命令安装pytest库:`pip install pytest` 2. 创建测试文件:在项目中创建一个以`test_`开头的文件,例如`test_api.py`,这个文件将包含你的测试用例。 3. 编写测试用例:使用pytest提供的装饰器(如`@pytest.mark.parametrize`)来定义测试用例。你可以使用Python的断言语句(如`assert`)来验证接口的响应结果是否符合预期。 4. 运行测试用例:在命令行中进入项目根目录,运行`pytest`命令来执行所有的测试用例。pytest将自动搜索并执行所有以`test_`开头的函。 5. 使用fixture:pytest提供了fixture机制来管理测试环境的初始化和清理。你可以使用`@pytest.fixture`装饰器定义一个fixture函,并在测试用例中使用`request`参数来调用fixture函。 6. 参数化测试:使用`@pytest.mark.parametrize`装饰器来实现参数化测试。你可以通过传入不同的参数组合来执行多次相同的测试用例,从而覆盖更多的场景。 7. 断言优化:使用pytest提供的断言方法(如`assert xxx == expected`)来做断言判断,并且可以获取更详细的断言信息。你还可以使用pytest的插件来扩展断言功能。 8. 报告生成:pytest可以生成详细的测试报告,你可以使用命令行参数`--html=report.html`来生成HTML格式的报告,或者使用其他第三方插件来生成更丰富的报告。 希望以上内容对你有帮助!如果还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值