为了提高代码的复用性,我们在写用例的时候,会用到函数,然后不同的用例去调用这个函数。比如登录操作,大部分的用例都会先登录,那就需要把登录单独抽出来写个函数,其它用例全部的调用这个登录函数就行。
但是登录的账号不能写死,有时候我想用账号 1 去登录,执行用例 1,用账号 2 去登录执行用例 2,所以需要对函数传参。 登录函数传参
把登录单独成立,写一个函数,传 2 个参数 user 和 psw,写用例的时候调用登录函数,输入几组 user,psw 参数化登录用例
测试用例传参需要用装饰器@pytest.mark.parametrize,里面写两个参数
第一个参数是字符串,多个参数中间用逗号隔开
第二个参数是 list,多组数据用元祖类型

从结果可以看出,有 2 个用例,一个测试通过,一个测试失败了,互不影响
import pytest

test_login_data = [('admin', '111111'), ('admin', '')] # 测试登录数据
def login(user, psw):
'''普通登录函数'''
print(f'\n登录账号:{user}')
print(f'登录密码:{psw}')
if psw:
return True
else:
return False @pytest.mark.parametrize('user, psw', test_login_data)
def test_login(user, psw):
'''登录用例'''
result = login(user, psw)
assert result == True, '失败原因,密码为空' if __name__=='__main__':
pytest.main()

request 参数
如果想把登录操作放到前置操作里,也就是用到@pytest.fixture装饰器,传参就用默认的 request 参数
user = request.param 这一步是接收传入的参数,本案例是传一个参数情况

添加 indirect=True 参数是为了把 login 当成一个函数去执行,而不是一个参数
import pytest

test_user_data = ["admin1", "admin2"]
@pytest.fixture(scope='module')
def login(request):
user = request.param
print(f'\n登录账户:{user}')
return user @pytest.mark.parametrize('login', test_user_data, indirect=True)
def test_lodin(login):
'''登录用例'''
a = login
print(f'测试用例中login的返回值:{login}')
return a !='' if __name__=='__main__':
pytest.main()

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

如果要用到login里面的返回值,def test_login(login)时,传入login参数,函数返回值就是 login 了
import pytest

test_user_data = [{'user': 'admin', 'psw': '111111'},
{'user': 'admin', 'psw': ''}]
@pytest.fixture(scope='module')
def login(request):
user = request.param['user']
psw = request.param['psw']
print(f'\n登录账户:{user}')
print(f'登录密码:{psw}')
if psw:
return True
else:
return False @pytest.mark.parametrize('login', test_user_data, indirect=True)
def test_login(login):
'''登录用例'''
a = login
print(f'测试用例中login的返回值:{a}')
assert a, f'失败原因:密码为空' if __name__=='__main__':
pytest.main()


多个 fixtrue
用例上面是可以同时放多个 fixture 的,也就是多个前置操作,可以支持装饰器叠加,使用 parametrize 装饰器叠加时,用例组合是 2个参数个数相乘

如果参数 user 有 2 个数据,参数 psw 有 2 个数据,那么组合起来的案例是两个相乘,也就是组合 2*2 = 4 个用例
import pytest

test_user = ['admin1', 'admin2']
test_psw = ['11111', '222222']
@pytest.fixture(scope='module')
def input_user(request):
user = request.param
print(f'\n登录账户:{user}')
return user @pytest.fixture(scope='module')
def input_psw(request):
psw = request.param
print(f'登录密码:{psw}')
return psw @pytest.mark.parametrize('input_user', test_user, indirect=True)
@pytest.mark.parametrize('input_psw', test_psw, indirect=True)
def test_login(input_user, input_psw):
'''登录用例'''
a = input_user
b = input_psw
print(f'测试数据a->{a}, b->{b}')
assert b if __name__=='__main__':
pytest.main()
												

pytest十一:函数传参和 firture 传参数 request的更多相关文章

  1. pytest_函数传参和firture传参数request

    前言为了提高代码的复用性,我们在写用例的时候,会用到函数,然后不同的用例去调用这个函数. 比如登录操作,大部分的用例都会先登录,那就需要把登录单独抽出来写个函数,其它用例全部的调用这个登陆函数就行. ...

  2. 函数传参和firture传参数request

    前言 为了提高代码的复用性,我们在写用例的时候,会用到函数,然后不同的用例去调用这个函数.比如登录操作,大部分的用例都会先登录,那就需要把登录单独抽出来写个函数,其它用例全部的调用这个登陆函数就行.但 ...

  3. pytest 12 函数传参和fixture传参数request

    前沿: 有的case,需要依赖于某些特定的case才可以执行,比如,登陆获取到的cookie,每次都需要带着他,为了确保是同一个用户,必须带着和登陆获取到的同一个cookies. 大部分的用例都会先登 ...

  4. pytest文档14-函数传参和firture传参数request

    前言 为了提高代码的复用性,我们在写用例的时候,会用到函数,然后不同的用例去调用这个函数. 比如登录操作,大部分的用例都会先登录,那就需要把登录单独抽出来写个函数,其它用例全部的调用这个登陆函数就行. ...

  5. python中函数的参数:必传参数(位置参数)、默认值参数、参数组传参、关键字传参

    1.必传参数也叫做位置参数,因为必填,也必须对应位置 2.默认值参数如上图的word 3.参数组参数:传进去的是0个.或多个value的形式,,,和位置参数有点像,只传value值,但是没有限制个数 ...

  6. [ 随手记6 ] C/C++ 形参、实参、按值传参、指针传参、引用传参

    个人原创: 1. 形参:形式上的参数,一般多在函数声明.函数定义的参数上: 2. 实参:实体参数,有实际的值,在运算上被循环使用的值: 3. 按值传参:按值,就是把实际的值传给函数内部: 4. 指针传 ...

  7. C/C++函数调用时传参过程与可变参数实现原理

    C/C++函数调用时传参过程与可变参数实现原理 C语言的经典swap问题 在学习C语言的时候,我们大都遇到过一些经典例题,这些经典例题背后所代表的是往往是C/C++背后的一些运行原理,比如下面这个示例 ...

  8. vue初始化、数据处理、组件传参、路由传参、全局定义CSS与JS、组件生命周期

    目录 项目初始化 组件数据局部化处理 子组件 父组件 路由逻辑跳转 案例 组件传参 父传子 子组件 父组件 子传父 子组件 父组件 组件的生命周期钩子 路由传参 第一种 配置:router/index ...

  9. Apache ab测试工具使用方法(无参、get传参、post传参)

    Ab测试工具是apache自带的测试工具,具有简单易上手的特性,下面我总结一下我的使用方法,首先去官方下载apache程序包,我下的最新版本apache2.4.23,下载地址http://httpd. ...

随机推荐

  1. saltstack安装与配置

    Saltstack是基于Python开发的一套C/S架构,具备Puppet.Ansible功能于一身的配置管理工具,功能十分强大,各模块融合度及复用性极高:使用号称世界上最快的消息队列ZeroMQ使得 ...

  2. H3C常用命令详解

    H3C常用命令详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 1.关闭后台日志输出 <yinzhengjie>sys [yinzhengjie]undo info- ...

  3. TCP粘包,拆包及解决方法

    在进行Java NIO学习时,发现,如果客户端连续不断的向服务端发送数据包时,服务端接收的数据会出现两个数据包粘在一起的情况,这就是TCP协议中经常会遇到的粘包以及拆包的问题.我们都知道TCP属于传输 ...

  4. Executor, ExecutorService 和 Executors 间的不同

    java.util.concurrent.Executor, java.util.concurrent.ExecutorService, java.util.concurrent. Executors ...

  5. location对象的一些属性和方法

    window.location 对象用于获得当前页面的地址 (URL),并把浏览器重定向到新的页面 以下是window.location的属性 window.location.host 返回主机名或者 ...

  6. Java EE之Hibernate异常总结【3】Disabling contextual LOB creation as createClob() method threw error java.lang.reflect.InvocationTargetException

    参考文献:https://stackoverflow.com/questions/4588755/disabling-contextual-lob-creation-as-createclob-met ...

  7. Linux命令行与shell脚本编程大全.第3版(文字版) 超清文字-非扫描版 [免积分、免登录]

    此处免费下载,无需账号,无需登录,无需积分.收集自互联网,侵权通知删除. 点击下载:Linux命令行与shell脚本编程大全.第3版 (大小:约22M)

  8. linux相关设置

    mysql开机自启: [root@workstudio system]# systemctl enable mysqld

  9. RAC

    RAC (Oracle网格计算技术) 编辑 Oracle RAC是Oracle Real Application Cluster的简写,官方中文文档一般翻译为“真正应用集群”,它一般有两台或者两台以上 ...

  10. Struts S2-052漏洞利用

    昨天在FreeBuf上看到[9月6日更新]漏洞预警 | 高危Struts REST插件远程代码执行漏洞(S2-052) 然而一直复现不了,今天又试了下竟然成功了. 由于水表查的较严,就不冒险搞别人的服 ...