news 2026/6/10 17:17:04

一篇文章入门Pytest

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
一篇文章入门Pytest

一、安装

需要安装的库

pytest pytest-html 生成HTML格式的测试报告 pytest-xdist 用例分布式执行,多CPU分发 pytest-ordering 改变用例执行顺序 pytest-rerunfailures 用例失败重跑 allure-pytest 生成allure测试报告 pyYAML yaml文件库

安装命令

# 将要安装的库放到 requirements.txt 文件中,然后执行 pip install -r requirements.txt

二、语法

1、模块名(用例文件名)必须以test_开头或者_test结尾

2、测试类必须以Test开头,且不能有init方法

3、测试方法必须以test开头

三、执行

执行命令

主函数

# test_login.py import pytest class TestLogin: def test_01(self): print("用例1") if __name__ == '__main__': pytest.main() # 执行所有

命令行

# 在命令行中切换到对应目录下后,直接命令行输入 pytest

读取pytest.ini配置文件

pytest.ini是pytest单元测试框架的核心配置文件,用来改变pytest默认的行为

1、一般放在项目的根目录;

2、编码必须是ANSI

[pytest] addopts = -vs testpaths = ./project python_files = test*.py python_classes = Test* python_functions = test

addopts 命令行参数

testpaths 测试用例文件夹

python_files 搜索文件名

python_classes 搜索的测试类名

python_functions 搜索的测试方法名的开头

执行命令参数

-s 输入调试信息,如用例中的print -v 打印信息更详细 文件名(或文件夹) 指定运行文件(或文件夹里文件)用例 -n 分布式运行 --reruns 2 失败重跑(失败重跑2次,加上第一次一共跑了3次) -x 只要有一个用例报错,测试停止 --maxfail=2 最多出现两个用例报错,测试停止 -k "方法名包含的字符" 根据用例部分字符串执行指定用例

例如

# 主函数 pytest.main(['-vs', 'test_login.py', '-n=2', '--reruns=2']) # 使用nodeid 执行指定方法 pytest.main(['-vs', './文件名/类名::方法名']) # 命令行 pytest -vs -n 2 --reruns 2 -k "login "

执行顺序

unittest根据ASCII码;pytest:从上到下

改变执行顺序:

# 使这个用例第一个执行 @pytest.mark.run(order=1) def test_login(): print("Done")

分组执行

pytest.ini文件添加:

markers = smoke: 冒烟用例 login: 登录用例

用例文件:

@pytest.mark.smoke def test_login2(): print("Done")

命令行执行命令:

pytest -vs -m "smoke" # 执行多个分组 pytest -vs -m "smoke or login"

跳过测试用例

# 无条件跳过 @pytest.mark.skip(reason="跳过原因") # 符合条件跳过 @pytest.mark.skipif(num>3, reason="数量超过3个")

四、前后置

每个用例都有的功能,可以集体提取出来,比如UI自动化的执行前打开浏览器、执行结束后关闭浏览器的操作

# test_login.py import pytest class TestLogin: # 在所有用例之前,只执行一次 def setup_class(self): print("在类执行前执行,比如创建日志对象、创建数据库连接") # 在每个用例之前都会执行一次 def setup(self): print("每个用例执行前先执行setup:打开浏览器,加载网页") def test_01(self): print("用例1") def teardown(self): print("每个用例执行结束后执行teardown:关闭浏览器") def teardown_class(self): print("类执行结束后,执行一次,比如:销毁日志对象、关闭数据库连接") if __name__ == '__main__': pytest.main() # 执行所有

五、fixture

用fixture实现部分用例的前后置

@pytest.fixture()参数

scope:被标记方法的作用域,function(默认)、class、module、package/session

params:参数化

autouse:自动执行,默认False

ids:使用params参数化时,给每个值设置一个变量名

name:给被标记的方法起一个别名【当取了别名以后,原名就不能用了】

import pytest @pytest.fixture() def my_fixture(): print("这是前置方法") yield print("这是后置方法") class TestLogin: def test01(self): print("用例1") # 这个用例执行前会先执行my_fixture方法 # 用例执行完后会执行my_fixture的yield def test_02(self, my_fixture): print("用例2")

如果所有方法有前后置需要,则在fixture里加参数autouse=True,用例里也不需要写fixture名调用

@pytest.fixture(autouse=True) ...省略... class TestLogin: def test01(self): print("用例1")

params参数化

params支持列表、元组、字典列表、字典元组

import pytest @pytest.fixture(scope='function', params=["亚索", "凯南", "腕豪"]) def my_fixture(request): yield request.param print("后置") class TestLogin: def test01(self, my_fixture): print("得到参数:", my_fixture)

工程应用

通过conftest.py和@pytest.fixture()结合使用,实现全局前后置

conftest.py 文件是单独存放fixture的配置文件,用处是可以在不同的py文件中使用同一个fixture函数,使用时原则上需要将conftest.py文件和用例放到同一层(放在根目录貌似也可以),并且不需要导入。且可以存在多个conftest.py文件(放在不同文件夹中)。调用也可以调用多个:

def test_01(self, my_fixture1, my_fixture2)

上面调用方式就是先调my_fixture1,再调用my_fixture2。

六、数据驱动

@pytest.mark.parametrize(args_name, args_value)

args_name:参数名

args_value:参数值;有多少参数值,用例就会执行多少次

例1:

import pytest class TestLogin: @pytest.mark.parametrize('args', ['北京', '上海', '广州']) def test_01(self, args): print(args) if __name__ == '__main__': pytest.main()

例2:

import pytest class TestLogin: @pytest.mark.parametrize('city, rank', [['北京', '1'], ['上海', '2'], ['广州', '3']]) def test_01(self, city, rank): print(city, rank) if __name__ == '__main__': pytest.main()

七、报告

1、下载allure,解压,配置环境变量

2、添加执行参数 --alluredir,可以去pytest.ini文件中修改(如下)。也可以在主函数中添加pytest.main([‘–alluredir=./temp’])这样生成的json文件会放到temp文件夹中

[pytest] addopts = -vs --alluredir ./temp testpaths = ./project python_files = test*.py python_classes = Test* python_functions = test

3、在主函数下增加代码

if __name__ == '__main__': pytest.main() os.system('allure generate ./temp -o ./report --clean')

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 10:57:42

如何为Rust OS构建硬件监控系统:从传感器到散热控制的实现指南

如何为Rust OS构建硬件监控系统:从传感器到散热控制的实现指南 【免费下载链接】blog_os Writing an OS in Rust 项目地址: https://gitcode.com/GitHub_Trending/bl/blog_os 在Rust操作系统开发中,硬件监控是确保系统稳定性的关键环节。本文将带…

作者头像 李华
网站建设 2026/6/10 14:58:18

Windows字体自定义完全指南:突破系统限制的界面美化方案

Windows字体自定义完全指南:突破系统限制的界面美化方案 【免费下载链接】noMeiryoUI No!! MeiryoUI is Windows system font setting tool on Windows 8.1/10/11. 项目地址: https://gitcode.com/gh_mirrors/no/noMeiryoUI 在Windows系统使用过程中&#xf…

作者头像 李华
网站建设 2026/6/10 10:58:44

多模态大语言模型下游微调全攻略:3大策略详解与实战指南

本文系统综述多模态大语言模型(MLLMs)的下游微调技术,分析选择性微调、附加式微调和重新参数化微调三大策略的优缺点。研究指出MLLMs面临任务专家化和开放世界稳定的双重挑战,并通过基准测试证明不同微调方法在专业化与泛化稳定性间存在显著差异。未来研…

作者头像 李华
网站建设 2026/6/10 10:53:09

从卡Logo到完美驱动:OpCore-Simplify工具的黑苹果配置逆袭指南

从卡Logo到完美驱动:OpCore-Simplify工具的黑苹果配置逆袭指南 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 在黑苹果的世界里&#xff…

作者头像 李华
网站建设 2026/6/10 1:02:13

鸣潮自动化工具深度评测:提升游戏效率的技术方案与实践指南

鸣潮自动化工具深度评测:提升游戏效率的技术方案与实践指南 【免费下载链接】ok-wuthering-waves 鸣潮 后台自动战斗 自动刷声骸上锁合成 自动肉鸽 Automation for Wuthering Waves 项目地址: https://gitcode.com/GitHub_Trending/ok/ok-wuthering-waves 解…

作者头像 李华