pytest总结
这里写目录标题
- 一、pytest的命名规则
- 二、界面化配置
- 符合命名规则的方法前面会有运行标记
- 三、pytest的用例结构
- 三部分组成
- 四、pytest的用例断言
- 断言写法:
- 五、pytest测试框架结构
- 六、pytest参数化用例
- 1、pytest参数化实现方式
- 2、单参数:每一条测试数据都会生成一条测试用例
- 3、多参数:
- ids:为测试用例起名字
- ids有中文的情况
- 4、笛卡儿积
- 七、标记测试用例
- 八、pytest设置跳过、预期失败用例
- 1、skip的使用场景:
- 2、skipif的使用场景:
- 3、xfail的使用场景:
- 九、pytest运行测试用例
- 1、运行多个测试包
- 2、运行多个测试模块
- 3、运行多个测试类
- 4、运行多个测试方法
- 5、运行单个测试方法
- 6、运行结果分析
- 十、pytest命令行常用参数
- 1、-x:
- 2、--maxfail=2:用例允许失败1条,第2条失败时,stop
- 3、-k:执行测试用例中,包含“tup”的用例(采用双引号)
- 4、-k:执行测试用例中,除了“tup”之外的用例(采用双引号)
- 5、--collect-only:只收集不运行
- 十一、python执行pytest
- 1、使用main函数
- a、pytest.main() :执行当前目录下符合规则的所有测试用例
- b、运行某一条用例
- c、运行某个标签
- 2、使用python -m pytest调用pytest
- 十二、pytest异常处理
- try...except
- pytest.raises()
- 1、捕获异常:意料之内的异常,不会报错
- 2、捕获异常:意料之外的异常,会报错
- 3、捕获多个异常
- 4、捕获异常后获取异常值和异常类型
一、pytest的命名规则
文件: test开头或者_test结尾
类名 : Test开头
方法名 :test_开头
特别注意:测试类中不能定义__init__()方法
二、界面化配置
符合命名规则的方法前面会有运行标记
三、pytest的用例结构
三部分组成
用例名称
用例步骤
用例断言
class TestXXX:def setup(self):#资源准备passdef teardown(self):#资源销毁passdef test_xxx(self):#测试步骤1#测试步骤2#断言 实际结果 对比 期望结果logging.info('这是xxx测试用例')assert 1==1
四、pytest的用例断言
断言(assert),是一种在程序中的一阶逻辑(如:一个结果为真或假的逻辑判断式),目的为了表示与验证软件开发者预期的结果。当程序执行到断言的位置时,对应的断言应该为真。若断言不为真时,程序会中止执行,并给出错误信息。
断言写法:
assert 表达式
assert 表达式,描述:当断言成功时,描述语句不会执行;当断言失败时,描述语句会执行。
class TestDemo:def test_c(self):assert 1==1def test_c1(self):assert 'abc1' in 'abcdef' , 'abc不在abcdef中'
五、pytest测试框架结构
setup_module/teardown_module:全局模块级,只运行一次
setup_class/teardown_class:类级,只在类中前后运行一次
setup_function/teardown_function:函数级别:在类外
setup_method/teardown_method:方法级别,在类中。类中每个方法执行前后
setup/teardown:在类中,在每个测试方法前后执行
六、pytest参数化用例
通过参数的方式传递数据,从而实现数据和脚本的分离
并且可以实现用例的重复生成和执行
1、pytest参数化实现方式
装饰器:pytest.mark.parametrize
2、单参数:每一条测试数据都会生成一条测试用例
#单参数
import pytest
search_list=['appium','selenium','pytest']# 两组测试数据:两条测试用例
@pytest.mark.parametrize('search_key',['java','appium'])
def test_search_params(search_key):assert search_key in search_list
3、多参数:
ids:为测试用例起名字
注意:ids 列表参数的个数要与参数值的个数一致
import pytest#测试数据有2个参数
@pytest.mark.parametrize("username,password",[["kobe",666],["kd",111],[" ",888]],ids=['success','fail','username is None'])
def test_login1(username,password):print(f'登录的用户名:{username},密码:{password}')
ids有中文的情况
import pytest@pytest.mark.parametrize("username,password",[["kobe",666],["kd",111],[" ",888]],ids=['成功','失败','用户名为空'])
def test_login(username,password):print(f'登录的用户名:{username},密码:{password}')
需要在conftest.py中定义pytest_collection_modifyitems方法
def pytest_collection_modifyitems(items):"""测试用例收集完成时,将收集到的用例名name和用例标识nodeid的中文信息显示在控制台上"""for i in items:i.name=i.name.encode('utf-8').decode('unicode-escape')i._nodeid=i.nodeid.encode('utf-8').decode('unicode-escape')
4、笛卡儿积
两组数据a=[1,2,3],b=[a,b,c]
对应的有几组组合形式?
(1,a)(1,b)(1,c)
(2,a)(2,b)(2,c)
(3,a)(3,b)(3,c)
import pytest@pytest.mark.parametrize('a',[1,2,3])
@pytest.mark.parametrize('b',['aa','bb','cc'])
def test_params1(a,b):print(f'笛卡儿积形式参数化中,a={a},b={b}')
七、标记测试用例
场景:只执行符合要求的某一部分用例可以把一个web项目划分为多个模块,然后指定模块名执行
解决:在测试用例方法上加@pytest.mark.标签名
执行:-m 执行自定义标记的相关用例
import pytest
#测试数据:整型
@pytest.mark.int
def test_int():assert isinstance(2,int)#测试数据:字符串
@pytest.mark.str
def test_str():assert isinstance('str',str)#测试数据:浮点型
@pytest.mark.float
def test_float():assert isinstance('2.7',float)
执行测试用例
D:\pytest_project\test_params>pytest test_mark.py -vs -m int
测试结果
执行用例会出现警告,解决方法:在pytest.ini中将标签注册
再次执行,没有警告了
八、pytest设置跳过、预期失败用例
这是pytest的内置标签,可以处理一些特殊的测试用例
skip:始终跳过该测试用例
skipif:遇到特定情况跳过该测试用例
xfail:遇到特定情况,产生一个”预期失败“输出
1、skip的使用场景:
1、调试时不想运行这个测试用例
2、标记无法在某些平台运行的测试用例
3、在某些版本中执行,其他版本中跳过
import pytest@pytest.mark.skip
def test_aaa():print("代码未开发完")assert True@pytest.mark.skip(reason="代码没有实现")
def test_bbb():assert False
执行测试用例:测试用例跳过图标默认置灰
案例:做判断
def check_login():return Falsedef test_function():print("start")#如果未登录,则跳过后续步骤if not check_login():pytest.skip("unsupported configuration")print("end")
2、skipif的使用场景:
import sys
print(sys.platform)@pytest.mark.skipif(sys.platform == 'darwin', reason="does not run on mac")
def test_case1():assert True
@pytest.mark.skipif(sys.platform == 'win', reason="does not run on windows")
def test_case2():assert True
@pytest.mark.skipif(sys.version_info < (3, 6), reason="requires python3.6 or higher")
def test_case3():assert True
3、xfail的使用场景:
import pytest@pytest.mark.xfail
def test_aaa():print("test_xfail1 方法执行")assert 2 == 2xfail =pytest.mark.xfail@xfail(reason="bug")
def test_hello4():assert 0
九、pytest运行测试用例
1、运行多个测试包
目录结构
运行测试用例:
D:\pytest_project>pytest demo_plugin
2、运行多个测试模块
运行测试用例:
D:\pytest_project>pytest demo_plugin/demo1
3、运行多个测试类
运行测试用例:
D:\pytest_project>pytest demo_plugin/demo2/test_demo2.py
4、运行多个测试方法
运行测试用例:
D:\pytest_project>pytest demo_plugin/demo2/test_demo2.py::TestB
5、运行单个测试方法
运行测试用例:
D:\pytest_project>pytest demo_plugin/demo2/test_demo2.py::TestB::test_d
6、运行结果分析
常用的:pass(通过)、fail(失败)、error(代码错误)
特殊的:warning(警告,例如pytest.ini中没有注册标签名)、deselect(跳过,加标签skip、skipif)
十、pytest命令行常用参数
-m:执行加标签的测试用例
-k:执行测试用例中包含某个关键字的测试用例(windows中关键字使用双引号)
-x:用例一旦运行失败,立刻停止运行(冒烟测试)
– maxfail=num:测试用例失败达到num个时,立刻停止运行
-v:打印详细信息
-s:打印输出日志
-n:并发执行测试用例
-lf:只执行上次用例失败的测试用例
-ff:先执行上次用例失败的测试用例,再执行其他的测试用例
–collect-only:测试平台,pytest自动导入功能
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2023/2/15 20:10
# @Author : 杜兰特
# @File : test_mark.py
import pytest
#测试数据:整型
@pytest.mark.int
def test_int():assert isinstance(2,int)#测试数据:字符串
@pytest.mark.str
def test_str():assert isinstance('str',str)#测试数据:浮点型
@pytest.mark.float
def test_float():assert isinstance('2.7',float)#测试数据:列表
@pytest.mark.list
def test_list():assert isinstance('[1,2,3]',list)#测试数据:元组
@pytest.mark.tuple
def test_tuple():assert isinstance('(1,)',tuple)
1、-x:
D:\pytest_project\test_params>pytest test_mark.py -x
2、–maxfail=2:用例允许失败1条,第2条失败时,stop
D:\pytest_project\test_params>pytest test_mark.py --maxfail=2
3、-k:执行测试用例中,包含“tup”的用例(采用双引号)
D:\pytest_project\test_params>pytest test_mark.py -k "tup"
4、-k:执行测试用例中,除了“tup”之外的用例(采用双引号)
D:\pytest_project\test_params>pytest test_mark.py -k "not tup"
5、–collect-only:只收集不运行
十一、python执行pytest
1、使用main函数
a、pytest.main() :执行当前目录下符合规则的所有测试用例
test_first.py文件
import pytestdef test_a():assert 1==1def test_b():assert 1==2class TestDemo:def test_c(self):assert 1==1def test_c1(self):assert 'abc1' in 'abcdef' , 'abc不在abcdef中'class TestXXX:def setup(self):#资源准备passdef teardown(self):#资源销毁passdef test_xxx(self):#测试步骤1#测试步骤2#断言 实际结果 对比 期望结果assert 1==1if __name__ == '__main__':pass#todo 1、运行当前目录下所有的用例pytest.main() #相当于pytest.main(['./'])
执行测试用例
D:\pytest_project>python test_first.py
b、运行某一条用例
import pytestif __name__ == '__main__':#todo 2、运行test_parameters.py::test_login中的某一条用例pytest.main(['test_params/test_parameters.py::test_login','-vs'])
执行测试用例
D:\pytest_project>python test_first.py
c、运行某个标签
import pytestif __name__ == '__main__':#todo 3、运行某个标签pytest.main(['test_params/test_mark.py','-vs','-m','int'])
执行测试用例
D:\pytest_project>python test_first.py
2、使用python -m pytest调用pytest
D:\pytest_project>python -m pytest test_first.py
十二、pytest异常处理
try…except
pytest.raises()
可以捕获特定的异常
获取捕获的异常的细节(异常类型、异常信息)
发生异常,后面的代码将不会被执行
1、捕获异常:意料之内的异常,不会报错
import pytest
def test_raise():with pytest.raises(expected_exception=ValueError, match='must be 0 or None'):raise ValueError("value must be 0 or None")
2、捕获异常:意料之外的异常,会报错
def test_raise1():with pytest.raises(expected_exception=ValueError, match='must be 0 or None'):raise ZeroDivisionError("除数为0的")
3、捕获多个异常
def test_raise2():with pytest.raises(expected_exception=(ValueError,ZeroDivisionError), match='must be 0 or None'):raise ZeroDivisionError("value must be 0 or None")
4、捕获异常后获取异常值和异常类型
def test_raise2():with pytest.raises(ValueError) as exc_info:raise ValueError("value must be 42")assert exc_info.type is ValueErrorassert exc_info.value.args[0] == "value must be 42"
相关文章:

pytest总结
这里写目录标题一、pytest的命名规则二、界面化配置符合命名规则的方法前面会有运行标记三、pytest的用例结构三部分组成四、pytest的用例断言断言写法:五、pytest测试框架结构六、pytest参数化用例1、pytest参数化实现方式2、单参数:每一条测试数据都会…...

CNI 网络分析(九)Calico IPIP
文章目录环境流量分析Pod 间Node 到 PodPod 到 serviceNode 到 serviceNetworkPolicy理清和观测网络流量环境 可以看到,在宿主机上有到每个 pod IP 的路由指向 veth 设备 到对端节点网段的路由 指向 tunl0 下一跳 ens10 的 ip 有到本节点网段 第一个 ip 即 tunl0 的…...

分布式任务调度(XXL-JOB)
什么是分布式任务调度? 任务调度顾名思义,就是对任务的调度,它是指系统为了完成特定业务,基于给定时间点,给定时间间隔或者给定执行次数自动执行任务。通常任务调度的程序是集成在应用中的,比如:…...

Django框架之模型视图--Session
Session 1 启用Session Django项目默认启用Session。 可以在settings.py文件中查看,如图所示 如需禁用session,将上图中的session中间件注释掉即可。 2 存储方式 在settings.py文件中,可以设置session数据的存储方式,可以保存…...

二极管的“几种”应用
不知大家平时有没有留意,二极管的应用范围是非常广的,下面我们来看看我想到几种应用,也可以加深对电路设计的认识: A,特性应用: 由于二极管的种类非常之多,这里这个大类简单罗列下:…...

github上传本地文件详细过程
repository 也就是俗称的仓库 声明:后续操作基于win10系统 前提:有一个github账号、电脑安装了git(官方安装地址) 目的: 把图中pdf文件上传到github上的个人仓库中 效果: 温馨提示: git中复制: ctrl insert…...

常用聚类算法分析
1. 什么是聚类 1.1. 聚类的定义 聚类(Clustering)是按照某个特定标准(如距离)把一个数据集分割成不同的类或簇,使得同一个簇内的数据对象的相似性尽可能大,同时不在同一个簇中的数据对象的差异性也尽可能地大。也即聚类后同一类的数据尽可能聚集到一起…...
OSG三维渲染引擎编程学习之五十八:“第五章:OSG场景渲染” 之 “5.16 简单光源”
目录 第五章 OSG场景渲染 5.16 简单光源 5.16.1 场景中使用光源 5.16.2 简单光源示例 第五章 OSG场景渲染 OSG存在场景树和渲染树,“场景数”的构建在第三章“OSG场景组...

80211无线网络架构
无线网络架构物理组件BSS(Basic Service Set)基本服务集BSSID(BSS Identification)ssid(Service Set Identification)ESS(Extended Service Set)扩展服务集物理组件 无线网络包含四…...

基于springboot+vue的便利店库存管理系统
基于springbootvue的便利店库存管理系统 ✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取项目下载方式🍅 一、项目背景…...

3|物联网控制|计算机控制-刘川来胡乃平版|第1章:绪论|青岛科技大学课堂笔记|U1 ppt
目录绪论(2学时)常用仪表设备(3学时)计算机总线技术(4学时)过程通道与人机接口(6学时)数据处理与控制策略(6学时)网络与通讯技术(3学时࿰…...

js打印本地pdf(使用HttpPrinter打印插件)
js打印本地pdf(使用HttpPrinter打印插件)第一步:启动HttpPrinter打印插件第二步:用浏览器打开示例文件\调用示例\websocket协议示例\html\打印pdf.html输入pdf地址 点击 “下载并打印pdf文件”按钮,就可以静默打印了。…...
华为OD机试 - 双十一(Python) | 机试题算法思路 【2023】
最近更新的博客 【新解法】华为OD机试 - 关联子串 | 备考思路,刷题要点,答疑,od Base 提供【新解法】华为OD机试 - 停车场最大距离 | 备考思路,刷题要点,答疑,od Base 提供【新解法】华为OD机试 - 任务调度 | 备考思路,刷题要点,答疑,od Base 提供【新解法】华为OD机试…...
2020年UML 秋季期末测试题
1.UML的全称是(B )。A.Unified Making LanguageB.Unified Modeling LanguageC.Unified Meodem languageD.Unify Modeling Language2.UML主要应用于( C)。A.基于螺旋模型的结构化开发方法B.基于数据的数据流开发方法C.基于对象的面…...

SpringCloud - Ribbon负载均衡
目录 负载均衡流程 负载均衡策略 Ribbon加载策略 负载均衡流程 Ribbon将http://userservice/user/1请求拦截下来,帮忙找到真实地址http://localhost:8081LoadBalancerInterceptor类对RestTemplate的请求进行拦截,然后从Eureka根据服务id获取服务列表&…...

Spring Boot + Redis 实现分布式锁
一、业务背景有些业务请求,属于耗时操作,需要加锁,防止后续的并发操作,同时对数据库的数据进行操作,需要避免对之前的业务造成影响。二、分析流程使用 Redis 作为分布式锁,将锁的状态放到 Redis 统一维护&a…...
CAD二次开发 插件初始化接口IExtensionApplication
前言:在实际项目开发中,我们总会遇到一些问题。比如说在CAD打开之前,修改注册表的内容,或者解决CAD在没有完全加载想要的dll情况下,功能运行报错的bug。因此,下面和大家介绍一下IExtensionApplication接口 …...

kafka-11-kafka的监控工具和常用配置参数
kafka官方文档 参考Kafka三款监控工具比较 1 查看kafka的版本 进入kafka所在目录,通过查看libs目录下的jar包。 2.11是scala的版本,2.0.0是kafka的版本。 测试环境 #systemctl start zookeeper #systemctl start kafkka 2 kafka的常用配置 Kafka使用…...

前端PWA渐进式加载技术
1.什么是PWA? 渐进式网络应用(PWA)是谷歌在2015年底提出的概念。基本上算是web应用程序,但在外观和感觉上与原生app类似。支持PWA的网站可以提供脱机工作、推送通知和设备硬件访问等功能。 2.PWA有那些优点? 更小更…...

【ubuntu 22.04不识别ch340串口】
这个真是挺无语的,发现国内厂商普遍对开源环境不感兴趣,ch340官方linux驱动好像被厂家忘了,现在放出来的驱动还是上古内核版本: 于是,驱动居然要用户自己编译安装。。还好网上有不少大神:链接,…...

网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
【网络】每天掌握一个Linux命令 - iftop
在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...

简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

python/java环境配置
环境变量放一起 python: 1.首先下载Python Python下载地址:Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个,然后自定义,全选 可以把前4个选上 3.环境配置 1)搜高级系统设置 2…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件
在选煤厂、化工厂、钢铁厂等过程生产型企业,其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进,需提前预防假检、错检、漏检,推动智慧生产运维系统数据的流动和现场赋能应用。同时,…...

跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...

【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...

Redis数据倾斜问题解决
Redis 数据倾斜问题解析与解决方案 什么是 Redis 数据倾斜 Redis 数据倾斜指的是在 Redis 集群中,部分节点存储的数据量或访问量远高于其他节点,导致这些节点负载过高,影响整体性能。 数据倾斜的主要表现 部分节点内存使用率远高于其他节…...

基于 TAPD 进行项目管理
起因 自己写了个小工具,仓库用的Github。之前在用markdown进行需求管理,现在随着功能的增加,感觉有点难以管理了,所以用TAPD这个工具进行需求、Bug管理。 操作流程 注册 TAPD,需要提供一个企业名新建一个项目&#…...

【笔记】WSL 中 Rust 安装与测试完整记录
#工作记录 WSL 中 Rust 安装与测试完整记录 1. 运行环境 系统:Ubuntu 24.04 LTS (WSL2)架构:x86_64 (GNU/Linux)Rust 版本:rustc 1.87.0 (2025-05-09)Cargo 版本:cargo 1.87.0 (2025-05-06) 2. 安装 Rust 2.1 使用 Rust 官方安…...