news 2026/4/16 10:19:06

一篇文章入门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/4/14 21:33:12

7个技巧掌握鸿蒙远程调试与跨设备控制:HOScrcpy实战指南

7个技巧掌握鸿蒙远程调试与跨设备控制:HOScrcpy实战指南 【免费下载链接】鸿蒙远程真机工具 该工具主要提供鸿蒙系统下基于视频流的投屏功能,帧率基本持平真机帧率,达到远程真机的效果。 项目地址: https://gitcode.com/OpenHarmonyToolkit…

作者头像 李华
网站建设 2026/4/8 9:47:43

干掉if-else噩梦!这四种设计模式太优雅了!!

在日常开发中,我们经常会遇到需要根据不同条件执行不同逻辑的场景,导致代码中出现大量的 if/else 嵌套。这不仅降低了代码的可读性和可维护性,还会增加后续扩展的难度。 本文将介绍四种优雅的设计模式来优化这种"条件爆炸"问题&am…

作者头像 李华
网站建设 2026/4/11 2:13:13

OpCore Simplify实战指南:解决黑苹果配置难题的5个非传统方案

OpCore Simplify实战指南:解决黑苹果配置难题的5个非传统方案 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 作为一名长期探索黑苹果系统…

作者头像 李华
网站建设 2026/4/15 4:34:57

测试工程师的进化论:从质量守门人到数字业务赋能者

——基于技术演进与市场需求的深度行业分析 一、被误读的“岗位消亡论”:技术迭代下的认知迷雾 2025年末,AI辅助测试工具覆盖率已达78%(Gartner数据),自动化脚本生成技术突破60%应用场景。当部分从业者焦虑于“测试将…

作者头像 李华
网站建设 2026/4/12 17:35:24

开发转行AI教育:零经验启动的3个步骤

在当今数字化转型浪潮中,人工智能(AI)教育已成为高增长领域,预计到2030年,全球AI教育市场规模将突破2000亿美元(来源:麦肯锡报告)。对于软件测试从业者而言,这一转型并非…

作者头像 李华