pytest框架的基本使用
1. 测试框架的作用
测试框架不关系用例的内容
它关心的是:用例编排和结果收集
2. pytest框架的特点
1. 适用于python语言
2. 用法符合python风格
3. 有丰富的生态
3. 安装pytest框架
1. 新建一个项目
2. 在项目终端窗口输入如下命令,用于安装pytest,其中-U是表示更新到最新的版本(如果你已经有了pytest,但是不是最新版,也会进行下载最新版)
pip install pytest -U
3. 下载完成后可以输入如下命令查看pytest是否安装成功
pip list
如果输出的列表中存在pytest,并且版本为最新,则安装成功。
4. pytest的用例发现规则
1. 从 以test_开头和以_test为结尾的文件 中收集用例
2. 从 以Test_开头的类 中收集用例(类不能包含__init__()方法)
3. 以test_开头的函数和方法 会作为测试用例
注意:作为测试用例的函数不能含有参数和返回值
5. 编写和执行测试用例
编写测试用例
编写测试用例就是通过代码实现用例的逻辑,可以通过assert来确定用例是否执行成功
class Test_A:def test_1(self):assert 1 == 1def test_2(self):assert 2 == 2
执行测试用例
方法一:通过执行pytest自带的main方法,该方法会执行项目中的所有用例

方法二:通过在终端输入命令行的方式,如下
pytest
执行不符合规则的文件中的用例
通过在终端中执行如下命令,符合的文件也可以通过此方法执行:
pytest 文件路径
6. 用例执行结果
结果缩写:
| . | 测试通过 |
| F | 测试失败 |
| E | 出现错误 |
| s | 跳过执行 |
| x | 预期内失败 |
| X | 预期外通过 |
结果的缩写是按照用例的执行顺序依次往后输出的

7. 配置
约定大于配置对于成熟的工具来说(如:pytest),默认配置是一种比较好的配置,如非必要,请勿修改
添加配置
1. 新建一个.ini结尾的文件
2. 加上如下内容
[pytest]
3. 查看所有的配置项:在终端中输入如下内容
pytest -h
4. 选择需要添加的配置项,将其按照对应的格式填写到.ini文件中
常用的命令行参数
额外的命令行选项 - addopts
![]()
| v | 增加详细程度 |
| q | 减少详细程度 |
| s | 不进行内容捕捉,让所有的输出内容可以正常展示(成功的用例不会将里面的执行过程打印出来,可以通过-s来设置) |
| x | 快速退出(只要发现失败用例就立即停止运行) |
一般情况下可以使用-vs,打印详细执行结果+用例输出内容打印
[pytest]
addopts = -vs

用户自定义标记 - mark
![]()
1. 注册标记
在.ini文件中添加mark,并添加标记
# 用户自定义标记
markers =name1name2name3
2. 打上标记
在函数上面添加标记,应该函数可以添加多个标记
class Test_A:@pytest.mark.name1def test_1(self):print('用例1')@pytest.mark.name1def test_2(self):print('用例2')@pytest.mark.name1@pytest.mark.name2def test_3(self):print('用例3')@pytest.mark.name2def test_4(self):print('用例4')
3. 筛选标记
通过筛选标记,筛选出需要执行的用例
在终端输入如下命令(可以结合前面的筛选文件):
pytest -m 标记名
也支持逻辑运算
pytest -m "标记1 and 标记2" # 执行包含标记1和标记2的用例
pytest -m "标记1 or 标记2" # 执行包含标记1或标记2的用例

框架内置标记
特点:
1. 不需要注册,可以直接使用
2. 标记不仅仅用于筛选,还有特殊的效果
常用内置标记:
| skip | 无条件跳过用例 |
| skipif | 有条件跳过用例 |
| sfail | 预期用例失败 |
| parametrize | 参数化测试 |
class Test_A:def test_1(self):print('用例1')@pytest.mark.skip()def test_2(self):print('用例2')@pytest.mark.xfail(reason='预期失败')def test_3(self):print('用例3')assert 1 == 2@pytest.mark.skipif(1 == 2, reason='当1 == 2时用例跳过')def test_4(self):print('用例4')

参数化执行带参数的用例
1. 在用例中添加参数
2. 再用力中使用参数
3. 给用例添加parametrize注解
3.1 添加第一个参数:参数名称(与用例参数名相同且对应)
3.2 添加第二个参数:用例传入参数的数据(有几组数据就意味着这个用例要执行几次,只是参数不同)
3.3 添加第三个参数(非必填):给每组参数添加用例名称
如果名称带有中文可以在.ini配置文件中添加如下内容,否则会乱码
# 用例的id可以包含各类字符,并且自负风险
disable_test_id_escaping_and_forfeit_all_rights_to_community_support = true
def add(a, b):return a + b@pytest.mark.parametrize( # 3. 添加parametreze标记'a, b', # 3.1 第一个参数为参数名称(要与用例参数对应)[(1, 1), # 3.2 第二个参数添加用例的参数数据(有几组参数就相当于是几个用例,只是参数不一样)(2, 2),(3, 3)],ids=["1 + 1", # 3.3 给每组参数添加用例名称(非必填,且使用中文需要添加相应的配置)"2 + 2","3 加 3"]
)
def test_add(a, b): # 1. 给用例添加参数print(f'执行add的结果为: {add(a, b)}') # 2. 再用例中使用参数

8. 夹具fixture
创建和使用夹具
夹具就是一个带有fixture标记的函数,然后将夹具作为参数传入用例的形参中即可。
如果夹具中正常去写,其所有内容会在用例执行之前执行
@pytest.fixture()
def fixture1(): # 夹具print('执行前置代码,用例执行前使用') # 夹具的内容def test_1(fixture1): # 在用例中使用夹具print('执行用例内容')

如果想在前后都执行部分夹具的代码,也需要加上yield关键字
@pytest.fixture()
def fixture1():print('执行前置代码,用例执行前使用')# yield之前的代码会在用例执行前执行yield # yield之后的代码会在用例执行后执行print('执行后置代码,用例执行后使用')def test_1(fixture1):print('执行用例内容')

夹具的返回值
夹具可以带有返回值,并且其返回值可以在用例中使用
@pytest.fixture()
def fixture1():print('执行前置代码,用例执行前使用')# yield之前的代码会在用例执行前执行yield 5# yield之后的代码会在用例执行后执行print('执行后置代码,用例执行后使用')def test_1(fixture1):print(f'输出夹具返回值:{fixture1}')

夹具的作用域
| function | 每个用例直接不共享fixture的返回值(默认) |
| class | 每个类中的用例共享fixture的返回值 |
| module | 每个文件中的用例共享fixture的返回值 |
| package | 每个目录中的用例共享fixture的返回值 |
| session | 全部用例共享fixture的返回值 |
下面以class和function作用域举例
注意:一个用例可以添加多个夹具,使用逗号分隔
@pytest.fixture(scope='class')
def fixture2():print('class作用域下,执行夹具前置代码')yield [] # 返回一个空列表,让用例之间传递数据print('class作用域下,执行夹具后置代码')@pytest.fixture()
def fixture3():print('function作用域下,执行夹具前置代码')yieldprint('function作用域下,执行夹具后置代码')# Test_A中的用例共享同一个 fixture2 夹具的返回值
class Test_A:def test_1(self, fixture2, fixture3):fixture2.append('A-test_1')print(fixture2)def test_2(self, fixture2, fixture3):fixture2.append('A-test_2')print(fixture2)def test_3(self, fixture2, fixture3):fixture2.append('A-test_3')print(fixture2)# Test_B中的用例共享同一个 fixture2 夹具的返回值
class Test_B:def test_1(self, fixture2, fixture3): # 一个用例可以添加多个夹具,用 逗号 分隔fixture2.append('B-test_1')print(fixture2)def test_2(self, fixture2, fixture3):fixture2.append('B-test_2')print(fixture2)def test_3(self, fixture2, fixture3):fixture2.append('B-test_3')print(fixture2)

在结果中可以看到function作用域的夹具对每个用例都执行了一次
class作用域的夹具对类在执行用例的前后执行了一次,并且夹具的返回值对类中的用例共享
相关文章:
pytest框架的基本使用
1. 测试框架的作用 测试框架不关系用例的内容 它关心的是:用例编排和结果收集 2. pytest框架的特点 1. 适用于python语言 2. 用法符合python风格 3. 有丰富的生态 3. 安装pytest框架 1. 新建一个项目 2. 在项目终端窗口输入如下命令,用于安装py…...
C++STL之map、set的使用和模拟实现
绪论: “我这个人走得很慢,但是我从不后退。——亚伯拉罕林肯”,本章是接上一章搜索二叉树中红黑树的后续文章,若没有看过强烈建议观看,否则后面模拟实现部分很看懂其代码原理。本章主要讲了map、set是如何使用的&am…...
100天精通鸿蒙从入门到跳槽——第18天:ArkTS组件状态管理装饰器
博主猫头虎的技术世界 🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能! 专栏链接: 🔗 精选专栏: 《面试题大全》 — 面试准备的宝典!《IDEA开发秘籍》 — 提升你的IDEA技能!《100天精通Golang》 — Go语言学习之旅!《100天精通鸿蒙》 — 从Web/安卓到鸿蒙大师!100天…...
【前端】防抖
防抖用于限制连续触发的事件的执行频率。当一个事件被触发时,防抖会延迟一定的时间执行对应的处理函数。如果在延迟时间内再次触发了同样的事件,那么之前的延迟执行将被取消,重新开始计时 场景 :用户输入 项目中遇到的场景,需要鼠标悬浮在图表的时候,将ToolsTip里的数据…...
python对图片或文件的操作
一. base64 与图片的相互转换 1. base64 转图片 import base64 from io import BytesIO from PIL import Image# base64 编码的图像数据(示例) base64_data "iVBn9DHASKJDjDsdSADSf8lgg"# 将 base64 编码的字符串解码为二进制数据 binary_d…...
架构篇19:单服务器高性能模式-Reactor与Proactor
文章目录 ReactorProactor小结上篇介绍了单服务器高性能的 PPC 和 TPC 模式,它们的优点是实现简单,缺点是都无法支撑高并发的场景,尤其是互联网发展到现在,各种海量用户业务的出现,PPC 和 TPC 完全无能为力。今天我将介绍可以应对高并发场景的单服务器高性能架构模式:Rea…...
PyInstaller 将 Python 程序生成可直接运行的程序
图标转换地址:https://convert.app/#google_vignette 官方文档:https://readthedocs.org/projects/pyinstaller/downloads/pdf/stable/#page20 安装pyinstaller pip install pyinstaller执行打包 pyinstaller -i ./resource/w.icns -w -F whv.py --a…...
专有钉钉开发记录,及问题总结
先放几个专有钉钉开发文档 专有钉钉官网的开发指南 服务端(后端)api文档 前端api文档 前端开发工具下载地址 小程序配置文件下载地址 后端SDK包下载地址 专有钉钉域名是openplatform.dg-work.cn 开发记录 开发专有钉钉时有时会遇到要使用钉钉的api;通过 my 的方…...
Java Swing桌面项目打包成可执行jar
前言 最近有需求,将Swing项目打包为一个可执行的jar包,遇见了一些问题,参考AI助手,解决了遇到的问题,也有一些亲身实践体会,记录一下。开发环境IntelliJ IDEA,JDK8,用kotlin语言实现…...
python数组反转的几种方式
python数组的反转可以有好几种方式,基于python语言的强大表现能力和丰富的特性,总结以下几种。 首先给定一个基本数组: d [1, 2, 3, 4, 5, 6] 1. reversed函数 reversed 是python的内建函数,会将原数组进行反转(但不影响原数组本身的序列…...
算法每日一题: 最大合金数 | 二分
大家好,我是星恒,今天给大家带来的是一道比较正常的二分题目 题目:leetcode 2861假设你是一家合金制造公司的老板,你的公司使用多种金属来制造合金。现在共有 n 种不同类型的金属可以使用,并且你可以使用 k 台机器来制…...
jvm优化过程
1.top命令执行查看,当前占比比较高的进程,可以看到21660这个进程的cpu占比已经100%了 编辑 2.可以定位到那个微服务的进程,可以看到是fs服务 编辑 3.执行 top -p 21660,然后按下大写的H,可以看到21772这个线程占比最高 编辑 4.…...
《Docker极简教程》--目录
一、前言 本书的目的和目标Docker的简介 二、Docker基础 Docker的历史和发展Docker的工作原理Docker的主要组件 三、Docker环境的搭建 在Windows上搭建Docker环境在Mac上搭建Docker环境在Linux上搭建Docker环境 四、Docker镜像 Docker镜像的概念Docker镜像的创建和使用D…...
嵌入式第十二天!(指针数组、指针和二维数组的关系、二级指针)
1. 指针数组: int *a[5]; char *str[5]; 指针数组主要用来操作字符串数组,通常将指针数组的每个元素存放字符串的首地址实现对多个字符串的操作。 二维数组主要用来存储字符串数组,通过每行存储一个字符串,多行存储多个字符串所组…...
俄罗斯方块游戏设计文档(基于C语言)
1. 引言 本设计文档旨在详细规划基于C语言开发的俄罗斯方块游戏的整体架构、功能模块以及具体实现步骤。这款游戏将通过控制下落的几何形状方块,以填充和消除行的方式进行,旨在提供用户友好的界面与流畅的游戏体验。 2. 需求分析 - 核心元素 - 方块&a…...
【解决】IntelliJ IDEA 重命名 Shift + F6 失效
IntelliJ IDEA 重命名 Shift F6 失效 问题解决 问题 Idea 重命名 Shift F6 ,一直没反应 解决 调查发现原因是微软新版的输入法冲突了。需要设置【使用以前版本的微软拼音输入法】解决兼容性。 设置 -> 时间和语言 -> 区域 -> 语言选项 -> 键盘选项…...
Unknown encoder ‘libmp3lame
环境: macos m1 , python3.10.x 背景 做视频切片, 使用moviepy 中VideoFileClip进行截取视频。 报错: Unknown encoder libmp3lameThe audio export failed because FFMPEG didnt find the specified codec for audio encoding …...
Android升级版本兼容问题
1、JDK的选择 AndroidJavaAPI and language features supported14 (API 34)17Core libraries13 (API 33)11Core libraries12 (API 32)11Java API11 and lowerAndroid versions https://developer.android.com/build/jdks The following table lists which version of Gradle…...
微信生成带参数二维码(用户id), 扫码可获取用户id
生成带参数的二维码: https://developers.weixin.qq.com/doc/offiaccount/Account_Management/Generating_a_Parametric_QR_Code.html 示例代码: /*** 生成带参数的二维码** param userId 用户id* return*/GetMappingRequestMapping("/createTicket/{userId}")pu…...
微信小程序(二十一)css变量-定义页面主题色
注释很详细,直接上代码 上一篇 新增内容: 1.使用css变量 2.消除按钮白块影响 3.修改图标样式 源码: npmTest.json {"navigationStyle": "custom","usingComponents": {//引入vant组件"van-nav-bar"…...
提示工程代码审查避坑指南:10个容易犯的低级错误
提示工程代码审查避坑指南:10个容易犯的低级错误 引言:为什么提示工程需要“代码审查”? 在AI时代,提示词(Prompt)是人类与大语言模型(LLM)沟通的“桥梁”。就像程序员写代码需要评审…...
单片机入门指南:硬件工程师成长路径与实战技巧
1. 单片机入门:从零开始的硬件工程师成长之路作为一名在嵌入式领域摸爬滚打多年的工程师,我见过太多初学者在单片机学习路上走弯路。单片机确实是个神奇的东西——它体积小、价格低,却能控制各种电子设备,从智能家居到工业自动化无…...
无需模拟器!Windows运行安卓应用的革命性方案——APK-Installer轻量级安装工具全解析
无需模拟器!Windows运行安卓应用的革命性方案——APK-Installer轻量级安装工具全解析 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 在数字化办公与娱乐融…...
UI-TARS-desktop快速上手:10分钟完成Qwen3-4B多模态Agent桌面版部署与任务验证
UI-TARS-desktop快速上手:10分钟完成Qwen3-4B多模态Agent桌面版部署与任务验证 想体验一个能看懂屏幕、操作软件、帮你完成任务的AI助手吗?今天要介绍的UI-TARS-desktop,就是一个内置了强大视觉理解能力的多模态AI Agent桌面应用。它基于Qwe…...
别让大模型只陪你聊天,用 RAG + Structured Extraction 终结合同盲区
音乐圈的版权大战从未停歇,从李荣浩早年关于“版权归属”的公开发声,到近期各路艺人与经纪公司的解约拉锯战,核心往往指向同一张纸——合同。 对于大多数人,无论是艺人、创作者还是创业者,合同是典型的“黑盒”。你签…...
从噪声到艺术:深入解析扩散模型采样算法的核心步骤
1. 扩散模型:当数学遇见艺术创作 想象一下,你正在看一位画家作画。他一开始只是在画布上随意涂抹颜料,看起来毫无章法。但随着画笔的不断调整,那些混乱的色块逐渐形成了清晰的轮廓,最终变成一幅精美的画作。这正是扩散…...
Arctic与ArcticDB对比分析:为何选择下一代数据存储方案
Arctic与ArcticDB对比分析:为何选择下一代数据存储方案 【免费下载链接】arctic High performance datastore for time series and tick data 项目地址: https://gitcode.com/gh_mirrors/ar/arctic 在金融数据分析和时间序列处理领域,高性能数据…...
3步打造零杂乱桌面:NoFences开源桌面管理工具全指南
3步打造零杂乱桌面:NoFences开源桌面管理工具全指南 【免费下载链接】NoFences 🚧 Open Source Stardock Fences alternative 项目地址: https://gitcode.com/gh_mirrors/no/NoFences 你是否每天花费10分钟在混乱的桌面寻找文件?据统计…...
Phi-3-mini-4k-instruct-gguf一文详解:从网页问答到摘要改写的全流程应用
Phi-3-mini-4k-instruct-gguf一文详解:从网页问答到摘要改写的全流程应用 1. 认识Phi-3-mini-4k-instruct-gguf Phi-3-mini-4k-instruct-gguf是微软Phi-3系列中的轻量级文本生成模型GGUF版本。这个模型特别适合处理问答、文本改写、摘要整理和简短创作等任务。想象…...
临床数据建模实战:Lasso回归在蛋白质组学中的5个关键应用技巧
临床数据建模实战:Lasso回归在蛋白质组学中的5个关键应用技巧 蛋白质组学数据的高维度特性让传统统计方法束手无策——当检测指标数量达到数千甚至上万时,如何从海量蛋白质中识别出真正有临床意义的生物标志物?这正是Lasso回归大显身手的领域…...
