pytest框架 核心知识的系统复习
创作时间:
作者:
@小白创作中心
pytest框架 核心知识的系统复习
引用
CSDN
1.
https://blog.csdn.net/qq_33594579/article/details/146044791
1. pytest 介绍
是什么:Python 最流行的单元测试框架之一,支持复杂的功能测试和插件扩展。
优点:
语法简洁(用
assert替代self.assertEqual)。自动发现测试用例。
丰富的插件生态(如失败重试、并发执行、报告生成)。
兼容unittest框架,比自带unittest框架更加简洁高效,在unittest框架迁移到pytest框架时不需要重写代码。
适用场景:单元测试、接口测试、UI 自动化测试。
2. pytest 环境搭建
安装 pytest
pip install pytest
查看pytest是否安装成功
pip show pytest
常用扩展插件
pip install pytest-html # HTML 报告
pip install pytest-xdist # 并发执行
pip install pytest-rerunfailures # 失败重试
pip install allure-pytest # Allure 报告集成
3. pytest 用例规则
- 文件命名:以
test_开头或结尾(如test_login.py或login_test.py)。 - 函数/类命名:
- 测试函数:以
test_开头(如test_login_success)。 - 测试类:以
Test开头(如TestLogin),且类中不能有__init__方法。 - 断言:直接使用
assert(如assert response.status_code == 200)。 - setup和teardown:模块级,类级,方法级,函数级
- setup_module和teardown_module,在整个测试用例文件中所有方法运行前后,仅运行1次
- setup_class和teardown_class,在一个Class中所有用例前后运行1次
- setup_method和teardown_method,在Class下的每个方法前后运行
- setup_function和teardown_function,在非Class下的每个方法前后运行
4. pytest 用例编写
示例
# 测试函数
def test_add():
assert 1 + 1 == 2
# 测试类
class TestMath:
def test_multiply(self):
assert 2 * 3 == 6
5. pytest 用例执行顺序
- 默认顺序:按文件名和测试函数/方法的 ASCII 码顺序执行。
- 自定义顺序:
- 使用
pytest-ordering插件:@pytest.mark.run(order=1) def test_login(): pass
6. pytest 用例重跑
- 使用插件:
pytest-rerunfailures - 命令行参数:
pytest --reruns 3 --reruns-delay 2 # 失败后重试3次,间隔2秒
7. pytest 用例并发
- 使用插件:
pytest-xdist - 命令行参数:
pytest -n 4 # 启动4个进程并发执行
8. pytest 用例跳过
无条件跳过:
@pytest.mark.skip(reason="功能未实现") def test_unimplemented(): pass条件跳过:
@pytest.mark.skipif(sys.platform == "win32", reason="Windows 不支持") def test_linux_only(): pass
9. pytest 用例条件判断
- 结合
pytest.mark.skipif或自定义条件逻辑:def test_feature(): if not has_feature(): pytest.skip("环境不支持此功能") # 正常测试逻辑
10. pytest 数据初始化与清除
fixture(scope='function', params=None, autouse=False, ids=None, name=None)
- pytest提供的fixture实现unittest中setup和teardown功能,可以在每次case执行前初始化数据,不同点是,fixture可以只在执行特定case之前运行,使用更灵活
- autouse参数:默认False须手动调用,只有True时才自动执行
- scope参数: 有四个级别参数
"function": 在conftest作用域下,每一个test开头的测试方法运行前都会执行一次
"class": 在conftest作用域下,每一个Test开头的测试类运行前都会执行一次
"module": 在conftest作用域下,每一个test开头的测试模块运行前都会执行一次
"session": 在conftest作用域下,这个包运行前只会执行一次
fixture的使用方法: - 使用函数名直接调用,但没有返回值
@pytest.mark.usefixtures('function_name') - 需要使用到fixture返回值:
直接在对应的接口函数里,加入一个形参,参数名就是fixture函数名
11. pytest 用例定制化执行
添加mark标签,可筛选出对应业务模块的部分接口:
- 对于Pytest,每一个模块,类,方法和用例前都加上mark,那样在pytest运行的时候就可以只运行带有该mark标签的模块,类或用例:
- 在配置文件pytest.ini里注册标签:
- 在类名/方法名前打标签:
@pytest.mark.标签名
- 在类中/方法中打标签:
pytestmark = pytest.mark.标签名
执行时可根据标签名来执行想要的用例,例如,运行所有标记为login的测试:
pytest -m login
其他运行参数:
- '-m','user_add',
- '-m','user_add or user_list',
- '-m','not user_add',
- '-m', 'not (user_add or user_list)'
- '-k',匹配用例文件名,非接口名称,可全部匹配,可模糊匹配
- '-v',节点 --多层化
- '-s' 详细输出打印 '-q' 简化打印
12. pytest 参数化
- 核心装饰器:
@pytest.mark.parametrize - 示例:
@pytest.mark.parametrize("a, b, expected", [ (1, 2, 3), (0, 0, 0), (-1, 1, 0), ]) def test_add(a, b, expected): assert a + b == expected
13. pytest 插件介绍
- 常用插件:
pytest-html:生成 HTML 测试报告。pytest-cov:生成代码覆盖率报告。pytest-mock:集成 Mock 功能。pytest-django:Django 项目测试支持。
14. pytest 插件执行
安装与使用
# 安装插件
pip install pytest-html
# 执行并生成 HTML 报告
pytest --html=report.html
15. pytest 集成 Allure
步骤
- 安装 Allure 命令行工具(需 Java 环境):
- 下载allure.zip
- 解压allure.zip到一个文件目录中
- 把解压路径添加到环境变量Path中
pip isntall pytest-allure
验证安装完成
方法一
执行pytest单元测试,生成Allure报告需要的数据存在的目录
pytest -sq --alluredir = ../report/tmp
执行命令生成测试报告
allure generate ../report/tmp -o ../report/report --clean
方法二- 生成 Allure 结果数据:
pytest --alluredir=./allure-results- 生成可视化报告:
allure serve ./allure-results # 本地查看 allure generate ./allure-results -o ./report --clean # 生成静态报告
16. pytest 生成测试报告
多种报告形式
- Python主流自动化测试报告插件:HTMLTestRunner,BeautifulReport,Allure
- Allure是一款轻量级开源自动化测试报告生成框架,支持绝大部分测试框架,包括TestNG,Junit,pytest,unittest等
- pytest框架结合Allure可生成格式统一,美观的测试报告
简单文本报告:
pytest -v # 输出详细结果HTML 报告:
pytest --html=report.htmlAllure 报告(需集成):
pytest --alluredir=./results && allure serve ./results
总结
- 核心优势:简洁语法 + 插件生态 + 高度可定制化。
- 最佳实践:
- 使用参数化减少重复代码。
- 结合 CI/CD(如 Jenkins、GitHub Actions)自动化测试。
- 通过 Allure 或 HTML 报告直观分析结果。
热门推荐
节奏盒子:让音乐创作触手可及
车厘子VS樱桃:从营养角度看,哪种更值得你放进嘴里?
樱桃和车厘子有什么区别?车厘子凭什么那么贵,和樱桃有啥关系?
什么是发电机效率控制
冬季宅家必备:床上腿部训练指南
日本梅毒疫情持续恶化,专家:与社会“丧文化”密切相关
企业培训革新:生成式AI在人才发展中的应用
总得去趟天津吧!从五大道到海河的浪漫之旅
哈佛医学院揭秘大脑信号传递新机制!
最新研究揭示:阿尔茨海默病的大脑信号秘密
将军澳第137区:打造香港东部新枢纽
香港地铁将军澳线最新指南:8个站点全解析!
春社日是什么意思
2025年春社日是什么时候
黄连花:从形态到功效的全面解析
健康养生指南:如何通过合理饮食、运动和心态管理实现身心健康?
探秘陈武帝故宫:穿越千年的皇家建筑艺术
新疆美食“最能打”的地方,乌鲁木齐靠边站,这几样特色美食绝了
七大姑八大姨:中国家庭称谓的文化密码
乳名、昵称、大名:如何科学选择孩子的称呼?
乡村旅游发展如何实现突破?值得关注六个方面!
买鸡鸭还能领补贴!去南宁这个传统圩市赶圩好温馨
太阳黑子周期:气候变化的“幕后推手”?
洛阳高档餐厅如何破局?上海转型经验值得借鉴
如何清洁与保养大理石的台面和地板?
如何清洁和保养大理石表面?这种保养方法有哪些注意事项?
如何清洁和保养大理石表面?这种保养方法有哪些注意事项?
天津:从古渔村到现代都市的华丽转身
中国银行:出国旅游货币兑换全攻略
河北衡水柴庄村:村支书醉驾后“世袭”引争议