news 2026/4/16 19:11:22

Pytest自动化测试框架完美结合Allure

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Pytest自动化测试框架完美结合Allure

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

简介

Allure Framework是一种灵活的、轻量级、多语言测试报告工具。

不仅可以以简洁的网络报告形式非常简洁地显示已测试的内容,

而且还允许参与开发过程的每个人从日常执行中提取最大程度的有用信息和测试。

从开发/测试的角度来看:

Allure报告可以快速查看到缺陷点,可以将测试未通过划分为Bug和中断的测试。

还可以配置日志,步骤,固件,附件,时间,历史记录,以及与TMS的集成和Bug跟踪系统,以便掌握所有信息。

从管理者的角度来看:

Allure提供了一个清晰的全局,涵盖了所涵盖的功能,缺陷聚集的位置,执行时间表,以及许多其他方便的事情。

独特的模块化和可扩展性,确保你能够进行适当的微调,以使更适合你自己。

官方文档:Allure Framework

部署使用

Pytest作为一个高扩展性、功能强大的自动化测试框架,自身的测试结果是较为简单的,如果想要一份完整测试报告需要其他插件的支持。

如果你对测试报告要求没那么高,你可以使用 pytest-html插件,基本覆盖了测试报告的常规内容。

但是如果你想查看清晰的测试过程、多维度的测试报告、自定义一些输出,以及与用例和缺陷系统集成等,那allure-python将是你的"不二人选"。

注意:allure-pytest从1.7之后已弃用,从2.0版本开始迁移至allure-python项目(即使用allure2),另外要运行allure命令行也需要Java的支持。

1、安装:

1)allure-pytest插件:

pip install -U allure-pytest

这将安装allure-pytest和allure-python-commons程序包,以生成与allure2兼容的报告数据。

2)allure工具:

官方下载地址:Releases · allure-framework/allure2 · GitHub

解压软件包(建议直接放到Python文件夹下),然后添加bin目录到环境变量中,最后使用 allure --version 验证是否安装成功。

2、基本使用

>>>要使allure侦听器能够在测试执行过程中收集结果,只需添加--alluredir选项并提供路径即可存储结果。

pytest --alluredir=<directory-with-results>

如果你运行后进行了用例更改,那么下次运行可能还是会查看到之前记录,可添加--clean-alluredir选项清除之前记录。

pytest --alluredir=<directory-with-results> --clean-alluredir

>>>要在测试完成后查看实际报告,你需要使用allure命令行应用程序从结果生成报告。

1)在默认浏览器中显示生成的报告

allure serve <my-allure-results>

2)要从现有的Allure结果生成报告,可以使用以下命令:

allure generate <directory-with-results>

默认报告将生成到allure-report文件夹,你可以使用-o标志更改目标文件夹:

allure generate <directory-with-results> -o <directory-with-report>

3)生成报告后,可以在默认系统浏览器中将其打开,只需运行:

allure open <directory-with-report>

你也可以找到该目录,使用浏览器打开该目录下index.html。注意:有时打开会找不到数据或者乱码,如果你使用的是pycharm,请在pycharm中右击打开。

4)如果要删除生成的报告数据,只需运行:

allure report clean

默认情况下,报告命令将在allure-results文件夹中查找报告,如果要从其他位置使用报告,则可以使用-o选项。

5)你也可以使用allure help命令查看更多帮助。

测试报告

你可以在allure报告中看到所有默认的pytest状态:只有由于一个断言错误而未成功进行的测试将被标记为失败,其他任何异常都将导致测试的状态为坏。

示例:

# test_sample.py import pytest # 被测功能 def add(x, y): return x + y # 测试类 class TestAdd: # 跳过用例 def test_first(self): pytest.skip('跳过') assert add(3, 4) == 7 # 异常用例 def test_second(self): assert add(-3, 4) == 1 raise Exception('异常') # 成功用例 def test_three(self): assert add(3, -4) == -1 # 失败用例 def test_four(self): assert add(-3, -4) == 7

运行:

E:\workspace-py\Pytest>pytest test_sample.py --alluredir=report --clean-alluredir ========================================================================== test session starts ========================================================================== platform win32 -- Python 3.7.3, pytest-6.0.2, py-1.9.0, pluggy-0.13.0 rootdir: E:\workspace-py\Pytest plugins: allure-pytest-2.8.18, assume-2.3.3, cov-2.10.1, html-3.0.0, rerunfailures-9.1.1, xdist-2.1.0 collected 4 items test_sample.py sF.F [100%] =============================================================================== FAILURES ================================================================================ __________________________________________________________________________ TestAdd.test_second __________________________________________________________________________ self = <test_sample.TestAdd object at 0x000000000464F278> def test_second(self): assert add(-3, 4) == 1 > raise Exception('异常') E Exception: 异常 test_sample.py:21: Exception ___________________________________________________________________________ TestAdd.test_four ___________________________________________________________________________ self = <test_sample.TestAdd object at 0x000000000464FD30> def test_four(self): > assert add(-3, -4) == 7 E assert -7 == 7 E + where -7 = add(-3, -4) test_sample.py:29: AssertionError ======================================================================== short test summary info ======================================================================== FAILED test_sample.py::TestAdd::test_second - Exception: 异常 FAILED test_sample.py::TestAdd::test_four - assert -7 == 7 ================================================================ 2 failed, 1 passed, 1 skipped in 0.14s =================================================================

生成报告:

E:\workspace-py\Pytest>allure generate --clean report Report successfully generated to allure-report

查看目录:

E:\workspace-py\Pytest>tree 文件夹 PATH 列表 卷序列号为 B2C1-63D6 E:. ├─.idea ├─.pytest_cache │ └─v │ └─cache ├─allure-report │ ├─data │ │ ├─attachments │ │ └─test-cases │ ├─export │ ├─history │ ├─plugins │ │ ├─behaviors │ │ ├─jira │ │ ├─junit │ │ ├─packages │ │ ├─screen-diff │ │ ├─trx │ │ ├─xctest │ │ ├─xray │ │ └─xunit-xml │ └─widgets ├─report └─__pycache__

查看报告:

Overview:总览,显示用例执行情况、严重程度分布、环境信息等。
Categories:分类,按用例执行结果分类,异常错误和失败错误。
Suites:套件,按测试用例套件分类,目录 ->测试文件 -> 测试类 ->测试方法。
Graphs:图表,显示用例执行分布情况,状态、严重程度、持续时间、持续时间趋势、重试趋势、类别趋势、整体趋势。
Timeline:时间线,显示用例耗时情况,具体到各个时间点用例执行情况
Behaviors:行为,按用例行为举止分类(以标记文字形式显示,需要用例添加allure相关装饰器)
Package:配套,按目录形式分类,显示不同的目录用例执行情况。

用例详情:

Allure报告不仅能显示pytest不同执行结果状态,错误情况,固件等,还能捕获参数化测试所有参数名称和值。

用例:

# test_sample.py import pytest import allure # 被测功能 def add(x, y): return x + y # 测试类 @allure.feature("测试练习") class TestLearning: data = [ [3, 4, 7], [-3, 4, 1], [3, -4, -1], [-3, -4, 7], ] @allure.story("测试用例") @allure.severity(allure.severity_level.NORMAL) @pytest.mark.parametrize("data", data) def test_add(self, data): assert add(data[0], data[1]) == data[2]

报告:

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

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

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

Fragstats实战:单一地类景观格局指数计算与结果解读

1. 数据准备&#xff1a;从矢量到栅格的完整转换流程 第一次接触Fragstats时&#xff0c;我也被各种数据格式搞得晕头转向。经过多次实践&#xff0c;发现最关键的是准备好正确的输入数据。Fragstats需要的是单地类栅格数据&#xff0c;也就是只包含某一种土地利用类型&#xf…

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

智慧灌区雨水情监测及闸门远控系统方案

在传统的灌区管理中&#xff0c;十分依赖人工经验和本地化操作&#xff0c;存在用水效率低、计量不全、调度滞后、抵御灾害能力弱等问题&#xff0c;直接影响到灌区的生产效益与管理水平。借助物联网、无线通信等技术打造的智慧灌区&#xff0c;可以实现对雨水情及灌溉闸门的实…

作者头像 李华
网站建设 2026/4/16 19:10:45

揭秘AI专著生成秘诀!高效工具大揭秘,快速完成学术专著撰写

学术专著的挑战与 AI 写作工具解决方案 写学术专著的挑战不仅在于能否写出来&#xff0c;更在于能否顺利出版并获得认可。在如今的出版市场中&#xff0c;学术专著的受众相对较小&#xff0c;出版社对选题的学术价值和作者的学术影响力有着严格的要求&#xff0c;很多尽管完成…

作者头像 李华
网站建设 2026/4/16 19:08:52

EWF写保护功能详解:从安装到实战操作指南

1. EWF写保护功能入门指南 第一次听说EWF写保护功能时&#xff0c;我也是一头雾水。直到有次在实验室调试设备&#xff0c;不小心把系统盘搞崩溃了&#xff0c;才真正体会到这个功能的价值。简单来说&#xff0c;EWF&#xff08;Enhanced Write Filter&#xff09;就像给硬盘分…

作者头像 李华
网站建设 2026/4/16 19:06:41

SD-PPP:Photoshop与AI绘图无缝协作的终极解决方案

SD-PPP&#xff1a;Photoshop与AI绘图无缝协作的终极解决方案 【免费下载链接】sd-ppp A Photoshop AI plugin 项目地址: https://gitcode.com/gh_mirrors/sd/sd-ppp SD-PPP是一款革命性的Photoshop AI插件&#xff0c;它重新定义了设计师与AI绘图工具之间的工作流程。这…

作者头像 李华
网站建设 2026/4/16 19:05:57

深度解析:5个实战技巧掌握抖音无水印视频下载

深度解析&#xff1a;5个实战技巧掌握抖音无水印视频下载 【免费下载链接】douyin_downloader 抖音短视频无水印下载 win编译版本下载&#xff1a;https://www.lanzous.com/i9za5od 项目地址: https://gitcode.com/gh_mirrors/dou/douyin_downloader 抖音无水印视频下载…

作者头像 李华