在之前的分享中,我们知道可以使用yield或者return关键字把fixture函数里的值传递给test函数

这种方法很实用,比如我在fixture函数里向数据库里插入必要的测试数据,那我就可以把相关数据返回给test函数用来做相关断言查询等操作。

那如果我想把test函数(也就是测试用例)中的数据传给fixture函数使用,要如何实现呢?

直接先贴上一段示例代码:

import pytest@pytest.fixture
def fixt(request):marker = request.node.get_closest_marker("fixt_data")if marker is None:# Handle missing marker in some way...data = Noneelse:data = marker.args[0]# Do something with the datareturn data@pytest.mark.fixt_data(42)
def test_fixt(fixt):assert fixt == 42

一、前置知识

代码中可能有2个知识点,可能有的小伙伴并不熟悉,分别来看下。

1. Mark 标记

什么是mark标记,干什么用?

标记可以将元数据应用于测试函数(注意,不能是fixture函数),后续可以通过fixture函数或者plugins插件进行访问。

框架有一些内置的marks,也可以支持我们自定义

内置的在之前的系列分享中有出现过几个,比如:

  • pytest.mark.parametrize:参数化
  • pytest.mark.skip:跳过测试用例
  • pytest.mark.skipif: 根据条件跳过用例

其他就不展开了,上述提到的分享文章链接会附在文末。

而在上述示例代码中,pytest.mark.fixt_data则是属于自定义的mark标记,fixt_data我也可以改成fixt_pingguo也是可以的。

2. request

request本身也是一个fixture函数,但是很特殊,用于提供当前正在执行请求的上下文信息。

在上述示例代码中,测试函数test_fixt请求了fixture函数fixt,那么在这次请求中相关联到的信息就可以在request中获得。
比如:

  • fixturename: 当前这个fixture函数的名称
  • module: 当前测试函数所在的模块
  • scope:当前fixture函数作用范围
  • node:基于当前测试范围搜集到的底层节点对象,这里又包含了很多信息。

就不一一展开了,有兴趣的童鞋可以在编辑器里打个断点,查看对应的信息详情。

二、通过自定义mark传递数据

回到示例代码,我们可以先直接执行一下代码。

测试是通过的(warning先忽略,因为没有注册自定义的mark),也就是说@pytest.mark.fixt_data(42)中的42是成功的带到了fixture函数中,经过函数中的处理后最后返回出来。

其中的get_closest_marker("fixt_data")方法,是返回与名称fixt_data匹配的第一个mark,从最近的级别到更远的级别,比如从函数到模块级别。

所以在这里,被找到的mark就是我们自定义的这个@pytest.mark.fixt_data(42)标记了。

1. 自定义mark知识点

标记是使用工厂对象pytest.mark动态创建的,用于装饰器,所以我们可以用语法糖@直接使用即可。

mark对象被创建之后,就被会收集起来,然后可以通过fixture或带有Node.iter_markers的钩子函数访问,可以访问到这个mark对象的属性。

有 2 个属性:

  • mark.args:这是个元组
  • mark.kwargs:这是个字典

所以我们可以使用上面的方式来进行传参,比如现在新建一个自定义mark:

@pytest.mark.timeout(10, "slow", method="thread")
def test_function():...

这里传参实际上就是

mark.args == (10, "slow")
mark.kwargs == {"method": "thread"}

回到最上方的示例代码,在fixture函数中就可以使用data = marker.args[0]来获取到参数42

如果在测试函数上同时使用了多个自定义mark,那么举例测试函数最近的mark就会被首先迭代。比如:

@pytest.mark.timeout(10, "slow", method="thread")
@pytest.mark.slow
def test_function():...

结果就是先@pytest.mark.slow,然后是@pytest.mark.timeout

2. 注册自定义的mark

在运行最上方的示例代码时出现了一个warning,因为我们没有注册自定义的标记导致,现在来进行注册。

新建pytest.ini配置文件,在里面添加即可:

[pytest]
markers =fixt_data: pingguo testfixt_data2

这里冒号:后面的描述是可选的,比如fixt_data2就是没有添加描述。

重新执行下最上方的代码:

platform win32 -- Python 3.9.12, pytest-7.1.3, pluggy-1.0.0
rootdir: D:\PythonCode\my_python, configfile: pytest.ini
collected 1 itemusemarks.py .============================== 1 passed in 0.00s ==============================Process finished with exit code 0

注册完成。

pytest合集见连接

【pytest官方文档】解读- 如何自定义mark标记,并将测试用例的数据传递给fixture函数相关推荐

  1. 【pytest官方文档】解读- 开发可pip安装的第三方插件

    在上一篇的 hooks 函数分享中,开发了一个本地插件示例,其实已经算是在编写插件了.今天继续跟着官方文档学习更多知识点. 一个插件包含一个或多个钩子函数,pytest 正是通过调用各种钩子组成的插件 ...

  2. pytest官方文档 6.2 中文翻译版(第十章):警告捕捉

    从3.1版本开始,pytest会在整个测试执行的过程中自动的捕捉警告: # content of test_show_warnings.py import warningsdef api_v1():w ...

  3. gateway的官方文档解读

    之前公司用了springcloud的gateway.被一个伙伴留下了一堆的坑,没办法只能从头梳理. 第一步就是确定架构, gateway+consul+springboot 第二步就是确定一个flag ...

  4. Mybatis官方文档解读

    跟着Mybatis的官方文档总结一下.~ 简介 什么是mybatis? mybatis是一款优秀的持久层框架,它支持自定义SQL,存储过程以及高级映射.Mybatis免除了所有的JDBC代码以及 设置 ...

  5. splash官方文档解读(翻译)

    安装 splash是一个类似于selenium的自动化浏览器,不过它与selenium还是有很大区别的:比如splash是异步的,splash暴露httpAPI来自动化操作. 安装很简单,需要先安装d ...

  6. torch.unsqueeze官方文档解读

    文章目录 前言 1. 功能介绍 2. 参数说明 3. 代码举例 前言 本文是对torch.unsqueeze官方文档的解读,加入部分代码示例,方便理解. 1. 功能介绍 torch.unsqueeze ...

  7. 蓝牙MESH 官方文档解读 翻译(1)

    已从事两年的物联网无线通信相关应用开发,但在接触蓝牙MESH相关技术时,一般都需要查询官方机构的文档,规范等,但发现网络上相应的中文资料较少,故对相关官方文档结合自身开发经验进行了翻译. 此部分摘自官 ...

  8. pytest官方文档 6.2 中文翻译版(第五章):pytest夹具:明确的,模块化的,可扩展的

    软件测试夹具是用于初始化的测试功能的.它们提供了一个固定的基线,以便测试能够可靠地执行并产生一致的,可重复的结果.初始化可能会设置服务.状态或其他运行环境.测试函数可以通过参数访问测试夹具,通常在测试 ...

  9. Spring官方文档解读(五)之自定义 bean 的性质

    Spring 框架提供了许多接口,可用于自定义 Bean 的性质.本节将它们分组如下: Lifecycle Callbacks ApplicationContextAware 和 BeanNameAw ...

最新文章

  1. 基于SSM+Layui实现医院预约挂号系统
  2. 怎么算 实体识别_大篷车流动摆摊卖日用品月赚万元,大商场生意冷清,实体店不好做...
  3. python高斯函数表达式_Python实现高斯函数的三维显示方法
  4. 8597 石子划分问题 dpdp,只考虑第一次即可
  5. ELK学习总结(2-2)单模式CRUD操作
  6. C++从零实现简单深度神经网络(基于OpenCV)
  7. ArcEngine二次开发_01(鼠标左击右击地图响应不同事件)
  8. 开发环境ubuntu16.04常用工具和设置(git、ssh、python、sh、java、Maven、mysql、postgresql)
  9. AI进军华尔街!《终极算法》作者Domingos加盟对冲基金巨头
  10. 《初级会计电算化应用教程(金蝶KIS专业版)》——导读
  11. 解决戴尔电脑禁用无线网络问题
  12. MAXON RE40直流有刷电机在Elmo SimplIQ cello系列驱动器的增益调节
  13. 汽车之家爬虫(autohome)
  14. 百词斩不复习_百词斩是不是真的好用?
  15. 网安面试题(common)
  16. Ubuntu 编译最新LLVM套件:LLVM 16.0
  17. Python小白的飞桨之旅
  18. 《架构设计2.0大型分布式系统架构方法论与实践》三高笔记
  19. c++primerplus6notes
  20. html导航栏动态图标,导航栏动态图.html

热门文章

  1. 安卓购物商城源码(服务端+客户端)
  2. Redis6.0以后版本安装报错问题
  3. python证书认证_使用Python进行证书认证的Selenium Webdriver
  4. TO_DATE()函数?
  5. CorelDRAW Graphics Suite2022免费图形设计软件
  6. Android下载保存gif图片
  7. Android 绘制圆形进度条
  8. # Logistics Regression
  9. 软件设计师之法律法规知识
  10. 【转】用IDCNN和CRF做端到端的中文实体识别