当前位置: 首页 > news >正文

Allure 在 Python 中的安装与使用

Allure 是一个灵活轻量级的测试报告工具,它能够生成详细且富有洞察力的测试报告。在 Python 中,Allure 通常与 Pytest 结合使用,以提供更加丰富的测试结果展示。下面我将介绍关于如何在 Python 中使用 Allure 的详细操作。

一、环境准备

在开始之前,确保你的环境中已经安装了 Python 和 Pytest。接下来,你需要安装 Allure 的命令行工具和 Python 库。

安装 Allure 命令行工具:

pip install allure-cmdline

安装 Allure Python 库:

pip install allure-pytest

二、编写测试用例

创建一个 Python 文件,比如 test_example.py,并编写以下代码:

import pytest
import allure# 定义一个测试函数,使用 allure 的 feature 来标记测试的特性
@allure.feature("加法运算测试")
class TestAddition:# 使用 allure 的 story 来标记具体的测试场景@allure.story("测试两个正数相加")def test_add_positive_numbers(self):# 一个简单的断言assert 3 + 4 == 7# 使用 pytest 的 parametrize 来实现参数化测试 @pytest.mark.parametrize("x,y,expected", [(1, 2, 3), (3, 4, 7)])@allure.story("测试加法的参数化场景")def test_add_with_parameters(self, x, y, expected):# 参数化测试的断言assert x + y == expected# 使用 allure 的 step 来记录测试步骤
@allure.step("执行加法操作")
def add_and_print_result(x, y):result = x + yprint(f"The result of {x} + {y} is {result}")return result# 测试用例中使用 allure step
def test_add_step(self):with allure.step("步骤1:输入两个参数"):x = 2y = 3result = add_and_print_result(x, y)with allure.step("步骤2:验证结果"):assert result == 5

三、运行测试用例

使用 Pytest 运行测试,并生成 Allure 报告:

pytest test_example.py --alluredir=allure-results

这条命令会执行 test_example.py 中的测试用例,并将 Allure 报告的生成结果存放在 allure-results 目录中。

四、生成 Allure 报告

在命令行中使用 Allure 命令行工具生成报告:

allure serve allure-results

执行该命令后,Allure 会启动一个本地服务器,并在默认的 Web 浏览器中打开生成的 Allure 报告。

五、Allure 报告的定制化

Allure 报告支持定制化,你可以通过添加不同的注解来丰富报告的内容。

自定义描述

使用 allure.description 来为测试用例添加描述:

@allure.description("""
这是一个复杂的测试用例,它执行多个步骤来验证登录流程。
""")
def test_complex_login(self):# ...

附件

你可以在测试用例中添加附件,比如截图或文本日志:

def test_with_attachment(self):with allure.step("生成报告并附加日志"):allure.attach("这是日志文件的内容", body="文本内容", attachment_type=allure.attachment_type.TEXT)

六、总结

Allure 是一个功能强大的测试报告工具,它能够提供清晰、易于理解的测试结果。通过上述步骤,你可以在 Python 中轻松地使用 Allure 来增强你的测试报告。

七、附录

  • Allure 官方文档:Allure GitHub
  • Pytest 插件:allure-pytest 安装和使用说明。
http://www.lryc.cn/news/346934.html

相关文章:

  • python实现动态时钟功能
  • QueryPerformanceCounter实现高精度uS(微妙)延时
  • Logstash详解
  • QT设计模式:适配器模式
  • 开发规范相关
  • C++ 容器(五)——Set操作
  • 【数字IC设计】芯片设计中的RDC
  • spark history server异常
  • 一个优秀 Maven 项目,各 Model 间最佳继承设计方案
  • MATLAB概述
  • Redis5.0的Stream数据结构
  • 避坑指南!RK3588香橙派yolov5生成RKNN模型!
  • 算法学习笔记(Nim游戏)
  • 第13节 第二种shellcode编写实战(2)
  • 【QuikGraph】C#调用第三方库实现迪杰斯特拉(Dijkstra)算法功能
  • 查看ubuntu当前路径的剩余存储空间
  • 利用预训练模型和迁移学习打造智能狗门
  • 常用Linux命令详细总结
  • 基于SpringBoot的竹宣非遗宣传网站
  • 怎么清理服务器的C盘?
  • 动态规划----股票买卖问题(详解)
  • Unity射线检测不到MeshCollider的原因
  • ssrf初步
  • linux 安装 mangodb 并设置服务开机自启
  • Virtualbox7.0.10+Ubuntu20.04网络配置
  • 设计模式之服务定位器模式
  • 冯喜运:5.12黄金回撤继续上涨,下周原油走势分析
  • JavaEE企业级开发中常用的JDK7和JDK8的时间类
  • leetcode 2316.统计无向图中无法互相到达点对数
  • WPS二次开发系列:如何使用WPS返回的FileUri