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

一、 需求引入

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

二、 方案选择

最初方案是有两个:

  1. unittest + htmlrunner
  2. pytest + allure

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

三、 实现步骤

步骤一:安装 Allure

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

shell 复制代码
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 数据文件存放的目录:

shell 复制代码
pytest --alluredir=allure_results

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

代码执行:

python 复制代码
pytest_args = ["--alluredir", allure_dir, test_dir]
pytest.main(pytest_args)

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

步骤四:生成 Allure 报告

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

shell 复制代码
pip install allure-commandline

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

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

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

步骤五:查看报告

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

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

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

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

shell 复制代码
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)方法,改为使用日志记录相关信息

相关推荐
滴啦嘟啦哒2 分钟前
【机械臂】【总览】基于VLA结构的指令驱动式机械臂
python·ros2·vla
写代码的【黑咖啡】13 分钟前
深入理解 Python 中的函数
开发语言·python
梦帮科技14 分钟前
量子计算+AI:下一代智能的终极形态?(第一部分)
人工智能·python·神经网络·深度优先·量子计算·模拟退火算法
小兔崽子去哪了17 分钟前
机器学习 线性回归
后端·python·机器学习
山海青风20 分钟前
藏文TTS介绍:6 MMS 项目的多语言 TTS
人工智能·python·神经网络·音视频
掘金詹姆斯21 分钟前
1、为什么说精通 Python 就等于握住了 AI 时代的全栈通行证?
python
用户83562907805121 分钟前
Python 操作 Excel:从基础公式到动态函数生成
后端·python
武当王丶也25 分钟前
从零构建基于 RAG 的 AI 对话系统:Ollama + Python + 知识库实战
人工智能·python
3824278271 小时前
python:正则表达式
前端·python·正则表达式
锐学AI1 小时前
从零开始学LangChain(二):LangChain的核心组件 - Agents
人工智能·python