Pytest学习笔记8-参数化
前言
我们在实际自动化测试中,某些测试用例是无法通过一组测试数据来达到验证效果的,所以需要通过参数化来传递多组数据
在unittest中,我们可以使用第三方库parameterized来对数据进行参数化,从而实现数据驱动测试
而在pytest中,也提供了功能强大的@pytest.mark.parametrize装饰器来实现数据参数化
Pytest参数化的方式
pytest有三种传参方式
@pytest.mark.parametrize()
通过装饰器方式进行参数化(最常使用)pytest.fixture()
方式进行参数化,fixture
装饰的函数可以作为参数传入其他函数conftest.py
文件中存放参数化函数,可作用于模块内的所有测试用例
@pytest.mark.parametrize实现参数化
装饰测试类
当装饰器 @pytest.mark.parametrize 装饰测试类时,会将数据集合传递给类的所有测试用例方法
举个
import pytest
# 定义测试数据
data1 = [
(1, 2, 3),
(4, 5, 9)
]
# 定义add方法
def add(a, b):
return a + b
# 添加parametrize装饰器
@pytest.mark.parametrize('a, b, expect', data1)
class TestParametrize(object):
def test_parametrize_1(self, a, b, expect):
print(f'\n测试用例1数据为{a}-{b},结果为{expect}')
assert add(a, b) == expect
def test_parametrize_2(self, a, b, expect):
print(f'\n测试用例2数据为{a}-{b},结果为{expect}')
assert add(a, b) == expect
执行结果如下
装饰测试函数
单个数据
当测试用例只需要一个参数时,我们使用列表存放测试数据,例如定义一个列表
data = [1,2]
使用@pytest.mark.parametrize装饰器时,第一个参数使用变量a接收列表中的每个元素,第二个参数传递存储数据的列表
在测试用例中使用同名的变量a接收测试数据,列表有多少个元素就会生成并执行多少个测试用例
上代码
import pytest
data = [1, 2 , 3]
@pytest.mark.parametrize('a', data)
def test_parametrize(a):
print(f'\n被加载测试数据为{a}')
执行结果如下
一组数据
当测试用例需要多个数据时,我们可以使用嵌套序列(嵌套元组&嵌套列表)的列表来存放测试数据
装饰器@pytest.mark.parametrize()可以使用单个变量接收数据,也可以使用多个变量接收,同样,测试用例函数也需要与其保持一致
当使用单个变量接收时,测试数据传递到测试函数内部时为列表中的每一个元素或者小列表,需要使用索引的方式取得每个数据
当使用多个变量接收数据时,那么每个变量分别接收小列表或元组中的每个元素
列表嵌套多少个列表或元组,测生成多少条测试用例
上代码
import pytest
data = [
[1, 2, 3],
[4, 5, 9]
]
@pytest.mark.parametrize('a, b, expect', data)
def test_parametrize_1(a, b, expect):
# 当使用多个变量接收数据时,那么每个变量分别接收小列表或元组中的每个元素
print(f'\n测试数据为{a},{b},{expect}')
actual = a + b
assert actual == expect
@pytest.mark.parametrize('value', data)
def test_parametrize_2(value):
当使用单个变量接收时,测试数据传递到测试函数内部时为列表中的每一个元素或者小列表,需要使用索引的方式取得每个数据
print(f'\n测试数据为{value}')
actual = value[0] + value[1]
assert actual == value[2]
执行结果如下
组合数据
一个测试函数还可以同时被多个参数化装饰器装饰,多个装饰器中的数据会进行交叉组合的方式传递给测试函数,进而生成n*n个测试用例,这也为我们的测试设计时提供了方便
上代码
import pytest
data_1 = [1, 2]
data_2 = [3, 4, 5]
@pytest.mark.parametrize('a', data_1)
@pytest.mark.parametrize('b', data_2)
def test_parametrize_1(a, b):
print(f'\n测试数据为{a},{b}')
执行结果如下
标记用例
当我们不想执行某组测试数据时,我们可以标记skip或skipif
当我们预期某组数据会执行失败时,我们可以标记为xfail
上代码
import pytest
data1 = [
[1, 2, 3],
pytest.param(3, 4, 8, marks=pytest.mark.xfail),
pytest.param(3, 4, 7, marks=pytest.mark.skip)
]
def add(a, b):
return a + b
@pytest.mark.parametrize("a,b,expected", data1)
def test_mark(a, b, expected):
print(f'测试数据为{a},{b},结果为{expected}')
assert add(a, b) == expected
执行结果如下
嵌套字典
数据列表中也可以使用字典类型的数据
上代码
import pytest
data_1 = (
{
'user': 1,
'pwd': 2
},
{
'user': 3,
'pwd': 4
}
)
@pytest.mark.parametrize('dic', data_1)
def test_parametrize_1(dic):
print(f'测试数据为{dic}')
执行结果如下
增加可读性
使用ids参数
参数化装饰器有一个额外的参数ids,可以标识每一个测试用例,自定义测试数据结果的显示,用来增加测试用例的可读性
上代码
import pytest
data = [1, 2, 3]
ids = [f'TestData-{a}' for a in data]
@pytest.mark.parametrize('a', data ,ids= ids)
def test_parametrize(a):
print(f'\n被加载测试数据为 {a}')
执行结果为
自定义id做标识
除了使用ids参数增加输出可读性外,我们还可以在参数列表的参数旁边定义一个id值来做标识
上代码
import pytest
data = [
pytest.param(1, id="this is test1"),
pytest.param(2, id="this is test2")
]
@pytest.mark.parametrize('a', data)
def test_parametrize(a):
print(f'\n被加载测试数据为 {a}')
执行结果如下
pytest.fixture()方式进行参数化
待更新
整理参考
Pytest学习笔记8-参数化的更多相关文章
- [转载]pytest学习笔记
pytest学习笔记(三) 接着上一篇的内容,这里主要讲下参数化,pytest很好的支持了测试函数中变量的参数化 一.pytest的参数化 1.通过命令行来实现参数化 文档中给了一个简单的例子, ...
- pytest 学习笔记一:参数化与组织分层
组织分层: 1.普通方式,和unittest分层类似: setup_module() # 通常放在类外 setup_class(cls) setup(self) teardown(self) tea ...
- pytest学习笔记
From: https://blog.csdn.net/gaowg11/article/details/54910974 由于对测试框架了解比较少,所以最近看了下pytest测试框架,对学习心得做个记 ...
- pytest学习笔记(一)
这两天在学习pytest,之前有小用到pytest,觉得这个测试框架很灵巧,用在实现接口自动化(pytest+requests)非常的轻便,然后很有兴致的决定学习下,然后又发现了pytest-sele ...
- pytest学习笔记(三)
接着上一篇的内容,这里主要讲下参数化,pytest很好的支持了测试函数中变量的参数化 一.pytest的参数化 1.通过命令行来实现参数化 文档中给了一个简单的例子, test_compute.py ...
- pytest学习笔记(二)
继续文档的第二章 (一)pytest中可以在命令行中静态/动态添加option,这里没什么好讲的,略过... 这里面主要讲下如何试用skip/xfail,还有incremental(包含一些列的测试步 ...
- pytest 学习笔记一 入门篇
前言 之前做自动化测试的时候,用的测试框架为Python自带的unittest框架,随着工作的深入,发现了另外一个框架就是pytest (官方地址文档http://www.pytest.org/en/ ...
- Pytest学习笔记3-fixture
前言 个人认为,fixture是pytest最精髓的地方,也是学习pytest必会的知识点. fixture用途 用于执行测试前后的初始化操作,比如打开浏览器.准备测试数据.清除之前的测试数据等等 用 ...
- Pytest学习笔记5-conftest.py的用法
前言 在之前介绍fixture的文章中,我们使用到了conftest.py文件,那么conftest.py文件到底该如何使用呢,下面我们就来详细了解一下conftest.py文件的特点和使用方法吧 什 ...
随机推荐
- Java_集合之一
1.Collection集合 1.1数组和集合的区别[理解] 相同点 都是容器,可以存储多个数据 不同点 数组的长度是不可变的,集合的长度是可变的 数组可以存基本数据类型和引用数据类型 集合只能存引用 ...
- Java中volatile关键字你真的理解了吗?
面:你怎样理解volatile关键字时? 我:不加思索的说出,volatile修饰的成员变量,可保证线程可见性.不保证原子性和禁止指令重排. 面:你能谈谈什么是线程可见性吗? 我:各个线程对主内存中共 ...
- Zoho Projects助力企业项目高效管理
挑选项目管理工具,就和人买衣服.买鞋子是一样的,除了看外观,最重要的是合适.随着项目管理工具的不断发展,市面上有很多工具都非常优秀,也能解决企业.团队的实际需求. 对于项目管理来说,最重要的在于人员协 ...
- BogoMips 和cpu主频无关 不等于cpu频率
http://tinylab.org/explore-linux-bogomips/ 内核探索:Linux BogoMips 探秘 Tao HongLiang 创作于 2015/05/12 打赏 By ...
- CentOS7 删除virbr0虚拟网卡
在CentOS 7的安装过程中如果有选择相关虚拟化的的服务安装系统后,启动网卡时会发现有一个以网桥连接的私网地址的virbr0网卡,这个是因为在虚拟化中有使用到libvirtd服务生成的,如果不需要可 ...
- 信息学C++教程<-3->输入输出格式控制
二进制输出整数 在计算机系统内的数据本身就是二进制 思考:在C++中,如何通过cout函数来输出二进制的数字呢? 所需库文件:1.iomanip //管理C++格式控制 2.bitset //二进 ...
- 查看mysql的数据库物理存放位置
1.查看mysql的数据库物理存放位置: show global variables like "%datadir%";
- 再见Xshell、Xftp!Python执行Linux命令、上传下载远程文件
相信大家应该都接触过Linux操作系统(Ubuntu.Centos等),那么在使用的Linux操作系统需要使用一些远程ssh工具,尤其是公网服务器. 常用的ssh工具主要有:Xshell.MobaXt ...
- python实现发送微信消息
import json from threading import Timer from wxpy import * import requests import urllib.parse def g ...
- V $ BACKUP_DATAFILE
V$BACKUP_DATAFILE 从控制文件显示有关备份集中的控制文件和数据文件的信息. 柱 数据类型 描述 RECID NUMBER 备份数据文件记录ID STAMP NUMBER 备份数据文件记 ...