Python自动化一------pytes与allure结合生成测试报告

一、 需求引入

最近在搞接口自动化,用python实现的,用例写完了,执行也没啥问题,但测试结果查看,还有测试执行信息查看不方便,所以就需要生成一下测试报告。

二、 方案选择

最初方案是有两个:

  1. unittest + htmlrunner
  2. pytest + allure

考虑到pytest的功能相比unittest更为强大,且其生态目前已经非常活跃和丰富,allure生成的测试报告也比htmlrunner更加炫丽,我最终选择方案2.

三、 实现步骤

步骤一:安装 Allure

确保您已安装 allure-pytest 插件。在命令行中运行以下命令进行安装:

复制代码
pip install allure-pytest

步骤二:编写测试代码示例

在测试代码中,可以使用 allure 提供的装饰器和上下文管理器来添加额外的测试信息,如标签、附件、步骤等。例如:

python 复制代码
import pytest

from allure_commons.types import AttachmentType



@pytest.mark.parametrize("a, b", [(1, 2), (3, 4)])

def test_addition(a, b):

assert a + b == 3 # 示例断言,实际应替换为有意义的测试逻辑


with allure.step("Performing addition"):

result = a + b


allure.attach(

f"{a} + {b} = {result}",

attachment_type=AttachmentType.TEXT,

)

步骤三:运行测试并生成临时 Allure 数据

在命令行中,运行带有 --alluredir 参数的 pytest 命令,指定 Allure 数据文件存放的目录:

复制代码
pytest --alluredir=allure_results

这将执行测试并生成 Allure 数据文件到指定的 allure_results 目录。

代码执行:

python 复制代码
pytest_args = ["--alluredir", allure_dir, test_dir]

pytest.main(pytest_args)

如果是多次执行的话,其实可以动态生成一个目录,用以区分多个测试执行结果,如以每次执行的而测试计划名称,或者时间戳。

步骤四:生成 Allure 报告

安装 allure-commandline 工具以生成报告:

复制代码
pip install allure-commandline

然后,使用 allure generate 命令生成报告:

复制代码
allure generate allure_results --clean -o allure_report

这将基于 allure_results 目录中的数据生成 HTML 报告,并存储在 allure_report 目录中。

步骤五:查看报告

打开 allure_report 目录中的 index.html 文件,即可在浏览器中查看生成的 Allure 测试报告。

如果上一步执行了allure generate指令生成了测试报告,则执行以下指令:

复制代码
allure open -h {test_report_host} -p {test_report_port} {test_report_dir}

若上一步未执行allure generate指令生成测试报告,则执行以下指令:

复制代码
allure serve -h {test_report_host} -p {test_report_port} {test_report_dir}

如果需要将报告部署到服务器或与团队共享,可以将 allure_report 目录打包或上传到合适的位置。如果您使用 CI/CD 工具(如 Jenkins、GitLab CI/CD、GitHub Actions 等),可以配置相应的 Allure 插件或步骤来自动化测试执行、报告生成和部署过程。

问题总结

1. 是否需要本地安装allure程序

在之前,我也尝试过pytest与allure结合生成测试报告,那会儿看的参考文献是说要安装,于是我也照做了,最后也确实能正常生成报告。

但是吧,这次我查了下相关文档,好像也没提到一定要本地安装allure。于是我实际测试了一下,只要安装了pytest-allure库,确实一切功能都可以正常使用。(前提是已经安装了allure-commandline

so,本地安装allure程序步骤可以直接省略了。

2. 安装allure-commandline失败

我使用3.x版本的python安装allure-commandline时报错找不到这个库。 切换pypi源,升级pip等等所有步骤都尝试过后,还是不行。 我又查了下相关资料,好像可能是因为python版本太高了,没有对应版本的allure-commandline库。 解决方案: 自己去github下载allure2,然后在本地解压缩,建议解压缩至项目路径下,这样可以根据项目中的相对路径调用allure指令,否则就需要配置环境变量allure安装目录\bin

3. 用allure.step装饰测试用例类的setup_class(self)报错

我之前在考虑怎么增加setup步骤的说明信息,搜到一篇文章说可以用allure.step装饰。我试了一下,结果报错 setup_class() missing 1 required positional argument: 'self'

问题很明显,就是setup_class()有一个self参数,而step不接受这个参数。

所以最终解决办法就是不用allure.step装饰测试用例类的setup_class(self)方法,改为使用日志记录相关信息。

最后: 下方这份完整的软件测试视频教程已经整理上传完成,需要的朋友们可以自行领取**【保证100%免费】**

​​​软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

相关推荐
lly2024067 小时前
PHP Error: 常见错误及其解决方法
开发语言
@zulnger7 小时前
selenium 自动化测试工具实战项目(窗口切换)
selenium·测试工具·自动化
毕设源码李师姐7 小时前
计算机毕设 java 基于 java 的图书馆借阅系统 智能图书馆借阅综合管理平台 基于 Java 的图书借阅与信息管理系统
java·开发语言·课程设计
忆~遂愿7 小时前
Runtime 上下文管理:计算实例的生命周期、延迟最小化与上下文切换优化
java·大数据·开发语言·人工智能·docker
沐知全栈开发7 小时前
PostgreSQL中的AND和OR操作符
开发语言
powerfulhell7 小时前
寒假python作业5
java·前端·python
1尢晞17 小时前
Java学习
java·开发语言
铉铉这波能秀7 小时前
LeetCode Hot100 中 enumerate 函数的妙用(2026.2月版)
数据结构·python·算法·leetcode·职场和发展·开发
毕设源码-赖学姐7 小时前
【开题答辩全过程】以 基于python的电影推荐系统为例,包含答辩的问题和答案
开发语言·python