网站首页 > 技术教程 正文
简介
fixture 即测试用例执行的环境准备和消理,fixture 主要的目的是为了提供一种可靠和可重复性的手段去 运行那些最基本的测试内容。比如测试网站的功能时,每个测试用例都要登录和登出,利用 fixture 就可 以只做一次,否则每个测试用例都要做这两步。
fixture 类似于 setup/teardown 机制,但 fixture 更灵活的完成测试的初始化以及资源清理工作。可以使 用它将你需要执行 setup 的测试用例传入 fixture 函数名,不需要的测试用例可以不用传递,不传递 fixture 名的测试用例将不会执行 fixture 函数。它允许我们将复杂的测试需求归纳成更简单、更有组织的 测试函数。 @pytest.fixture 与 @pytest.mark.parametrize 结合实现参数化
如果测试数据需要在 fixture 方法中使用,同时也需要在测试用例中使用,可以在使用 parametrize 的时 候添加一个参数 indirect=True ,pytest 可以实现将参数传入到 fixture 方法中,也可以在当前的测试 用例中使用。
当 indirect 参数设置这个参数为 True 时,pytest 会把 argnames 当作函数去执行,将 argvalues 作 为参数传入到 argnames 这个函数里。创建“test_param.py”文件,代码如下:
# 方法名作为参数
test_user_data = ['Tome', 'Jerry']
@pytest.fixture(scope="module")
def login_r(request):
# 通过request.param获取参数
user = request.param
print(f"\n 登录用户:{user}")
return user
@pytest.mark.parametrize("login_r", test_user_data,indirect=True)
def test_login(login_r):
a = login_r
print(f"测试用例中login的返回值; {a}")
assert a != ""
运行结果:
test_mark_paramize.py::test_login[Tome]
test_mark_paramize.py::test_login[Jerry]
============================== 2 passed in\
0.02s ===============================
Process finished with exit code 0
登录用户:Tome PASSED [ 50%]测试用例中login的返回值; Tome
登录用户:Jerry PASSED [100%]测试用例中login的返回值; Jerry
上面的结果可以看出,当 indirect=True 时,会将 login_r 作为参数,test_user_data 被当作参数 传入到 login_r 方法中,生成多条测试用例。通过 return 将结果返回,当调用 login_r 可以获取 到 login_r 这个方法的返回数据。
fixture 间相互调用
fixture 可以作为参数传递给其它的 fixture 函数。
工作中可能不同的功能,依赖的数据,环境不一样,需要定义多个功能函数。
比如:登录 fixture 函数中需要信赖连接数据库的 fixture 函数。可以将这些功能函数都定义为 fixture, 然后通过传递 fixture 函数,实现功能之间的数据交换。
# contents of test_append.py
import pytest
@pytest.fixture
def connectDB():
return "name,school"
@pytest.fixture
def login(connectDB):
return [connectDB]
def test_string(login):
pass
测试用例/fixture 可以请求多个 fixture
下面是一个示例:
# contents of test_append.py
import pytest
# Arrange
@pytest.fixture
def first_entry():
return "a"
# Arrange
@pytest.fixture
def second_entry():
return 2
# Arrange
@pytest.fixture
def order(first_entry, second_entry):
return [first_entry, second_entry]
# Arrange
@pytest.fixture
def expected_list():
return ["a", 2, 3.0]
def test_string(order, expected_list):
# Act
order.append(3.0)
# Assert
assert order == expected_list
Fixture 终结器(Teardown/Cleanup)
添加终结器
但如果 yield 之前的内容发生异常,将不会执行 yield 后面的内容。
对于这种情况,还可以直接向测试的 request 对象添加 “finalizer” 终结器函数实现这个功能(与 yield fixtures 类似的结果,但能力更强)。
举个应用场景:
比如我们在读取文件的时候,需要打开文件,获取文件流对象,定义一个关闭文件的方法 close() , 在终结器中实现关闭操作。最后即使后面的代码有异常,也会执行终结器里面的操作。
@pytest.fixture(scope='module', autouse=True)
def operate_file(request):
print("打开文件")
fs = open('./datas/data.yaml', mode="r")
def close():
print("关闭文件")
fs.close()
request.addfinalizer(close)
datas = yaml.safe_load(fs)
raise ValueError
print(datas)
搜索微信公众号:TestingStudio霍格沃兹的干货都很硬核
猜你喜欢
- 2024-11-17 这些年,英国女王就靠这件事赚了6000多万元!
- 2024-11-17 主题分类词汇 14 (Industry 工业)
- 2024-11-17 工件的安装与夹具,建议收藏
- 2024-11-17 Pytest fixture及conftest详解
- 2024-11-17 pytest框架进阶自学系列 | 在不同的层级上重写fixture
- 2024-11-17 仕诺康丨全程导板工具盒
- 2024-11-17 Pytest的内置fixture(七)
- 2024-11-17 你会买吗?可以边走边玩的Switch专用手柄支架Fixture S1开启众筹
- 2024-11-17 思林杰获得外观设计专利授权:“充电座(BBUChargingFixture)”
- 2024-11-17 如何组织自动化测试工程的目录结构?
你 发表评论:
欢迎- 最近发表
-
- Oracle 在其新的 Linux 内核中引入了热补丁功能
- CentOS 7.6下安装Oracle 11.2.0.4
- ORACLE体系 - 2(oracle体系讲解)
- ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务
- Hadoop自学系列集(二) ---- CentOS下安装JDK
- 如何升级oracle数据库安全补丁(oraclepsu补丁升级)
- 搭建Oracle数据库服务器(oracle服务器创建用户)
- OGG同步到Kafka(oggforbigdata到kafka)
- oracle是什么软件?(oracle是干什么用的)
- 脚本化修改Oracle用户的密码以及执行sql(增删改查等)
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)