Allure精通指南(05)定制化报告内容(环境信息、图标、缺陷类别)


文章目录

      • Allure 自定义测试环境信息
      • Allure 自定义缺陷类别信息
      • Allure 自定义图标
        • 步骤一
        • 步骤二
        • 步骤三


请添加图片描述

Allure 自定义测试环境信息

步骤 1:创建 environment.properties 文件

  • 在项目根目录或任何其他不会被--clean-alluredir参数影响的目录下创建 environment.properties 文件;
  • environment.properties 文件中按需以key=value的形式填写环境信息;
  • 可以通过编写相关函数动态在执行测试用例脚本时获取每次执行时的真实值,然后写入 environment.properties 文件。
systemVersion=Mac os 14
pythonVersion=3.8.5
allureVersion=2.10.0
baseUrl=https://192.168.31.1/MyProject
projectName=MyProject
author=yangkai

请添加图片描述

步骤 2:执行 pytest 测试用例并生成 Allure 原始数据

  • 使用pytest执行测试用例,并通过 --alluredir 参数指定Allure报告原始数据的生成路径
# 这个命令会执行所有的测试用例,并将生成的 Allure 报告原始数据保存在 ./report/tmp 文件夹中。
pytest --alluredir=./report/tmp    

请添加图片描述

步骤 3:在生成报告前复制 environment.properties 文件

  • 在生成 Allure报告之前,需要将 environment.properties 文件复制到Allure报告的原始数据目录。
# Mac 系统
cp environment.properties ./report/tmp/

# Windows系统
copy environment.properties ./report/tmp/

请添加图片描述

步骤 4:生成 Allure 测试报告

  • 使用Allure的命令行工具生成测试报告。
# 这个命令会基于 report/tmp 目录中的原始数据生成 Allure 测试报告,
# 并将其输出到 report/allure-report 目录,-c 参数会清理输出目录。
# 但此时 environment.properties 文件已经存在于 report/tmp 目录中,因此不会被删除。
allure generate report/tmp -o report/allure-report -c report/allure-report

请添加图片描述

步骤5:打开 Allure 测试报告

  • 按照步骤执行命令,打开allure查看是否成功添加测试环境信息
allure open report/allure-report

请添加图片描述

Allure 自定义缺陷类别信息

注意事项:

  • 在项目根目录或任何其他不会被--clean-alluredir参数影响的目录下创建 categories.json 文件;
  • 我这里依旧是放在了根目录,在生成原始数据之后将之拷贝过去再生成报告(详细步骤请参考上述自定义测试环境信息)

以下是categories.json配置项的解释:

  • name: 这是类别的名称,它将出现在Allure报告的Categories菜单中。
  • matchedStatuses: 这是一个字符串数组,定义了哪些测试状态应该被归类到此类别下。Allure支持的状态有:passedfailedbrokenskipped
  • messageRegex: 这是一个正则表达式,用于匹配测试用例的错误或失败消息。只有当错误或失败消息与这个正则表达式匹配时,测试用例才会被归类到此类别下。
  • traceRegex: 这也是一个正则表达式,用于匹配测试用例的错误堆栈跟踪。只有当堆栈跟踪与这个正则表达式匹配时,测试用例才会被归类到此类别下。
[
  {
    "name": "跳过执行",
    "matchedStatuses": ["skipped"]
  },
  {
    "name": "环境异常",
    "matchedStatuses": ["broken", "failed"],
    "messageRegex": ".*bye-bye.*"
  },
  {
    "name": "废弃测试",
    "matchedStatuses": ["broken"],
    "traceRegex": ".*FileNotFound.*"
  },
  {
    "name": "断言失败",
    "matchedStatuses": ["failed"]
  }
]

test_case_05.py文件示例代码

import pytest


# categories.json文件已经放置在allure-results目录中

# 跳过测试
@pytest.mark.skip(reason="This test is skipped")
def test_skipped():
    assert True


# 环境异常
def test_environment_exception():
    raise Exception("Something went wrong, bye-bye!")


# 废弃测试
def test_deprecated_test():
    with open("non_existent_file.txt", "r") as f:
        content = f.read()
    assert content == "Some content"


# 断言失败
def test_assertion_failure():
    assert 1 == 2


# 断言失败
def test_test_defect():
    raise AssertionError("This is a test defect")

allure报告效果

请添加图片描述

Allure 自定义图标

在使用Allure生成测试报告时,允许自定义报告的图标,以便更好地展示你的测试结果和团队的品牌形象。

步骤一
  • 放置Logo图片:将Logo图片文件放到Allure安装路径下的plugins/custom-logo-plugin/static目录中。
  • 自定义Logo样式:如果希望进一步自定义Logo的样式(如大小、位置等),可以编辑plugins/custom-logo-plugin/styles.css文件。

请添加图片描述

style.css文件内容

.side-nav__brand {
  /* url括号内写图片的名字 */
  background: url("logo.png") no-repeat left center !important;
  margin-left: 10px;
  height: 50px;
  background-size: contain !important;
}

/* 去掉图片后边 allure 文本 */
.side-nav__brand-text {
  display: none;
}

/* 设置logo 后面的字体样式与字体大小 */
.side-nav__brand:after {
  content: "测试开发的烦恼";
  margin-left: 18px;
  height: 30px;
  font-family: Arial;
  font-size: 14px;
}

请添加图片描述

步骤二

打开allure.yml文件,并在文件末尾追加配置项

  - custom-logo-plugin

请添加图片描述

步骤三

完成上述步骤后,重新执行测试用例生成Allure报告。

新的Logo应该会在报告中显示出来,如果没有生效,请将style.css文件中的中文注释删除。

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/576358.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

OpenHarmony语言基础类库【@ohos.util.LightWeightMap (非线性容器LightWeightMap)】

LightWeightMap可用于存储具有关联关系的key-value键值对集合,存储元素中key值唯一,每个key对应一个value。 LightWeightMap依据泛型定义,采用轻量级结构,初始默认容量大小为8,每次扩容大小为原始容量的两倍。 集合中…

1、opencv介绍与开发环境搭建

1、opencv介绍 OpenCV 是 Intel 开源计算机视觉库,是一个跨平台的开源计算机视觉和机器学习软件库。它由一系列 C 函数和少量 C 类构成,可用于开发实时的图像处理、计算机视觉以及模式识别程序。 该库有 2500 多种优化算法,其中包括一套全面…

python怎么输出倒序

python怎么输出倒序?下面给大家介绍四种方法: 创建测试列表 >>> lst [1,2,3,4,5,6]方法1: >>> lst.reverse() #reverse()反转 >>> lst [6, 5, 4, 3, 2, 1] 方法2: >>> lst1 [i for i in …

2024年最好用的10款ER图神器!

分享10款ER图工具,详细分析他们的功能特点、价格和适用场景,可以根据你的需求进行选择。ER图(Entity-Relationship Diagram)是数据库设计中常用的一种模型,用于描述实体之间的关系。这种图形化的表示方法旨在帮助人们理…

数据结构——二叉树练习(深搜广搜)

数据结构——二叉树练习 路径之和深度优先算法和广度优先算法二叉搜索树判断一棵二叉树是否为搜索二叉树和完全二叉树 我们今天来看二叉树的习题: 路径之和 https://leetcode.cn/problems/path-sum-ii/ 这是一个典型的回溯,深度优先算法的题&#xff0c…

解决Win10 C盘扩展卷灰色不可用的简单方法!

当你发现电脑C盘空间不足,却又一段Win10 C盘扩展卷选项无法使用的状况时,该如何应对呢?本篇文章将向你介绍3种简单的方法,帮助你轻松解决C盘扩容的问题! C盘扩容的重要性? 当前,大部分台式机和…

普乐蛙VR航天航空体验馆VR双人旋转座椅元宇宙VR飞船

多长假来袭!!想为门店寻找更多新鲜有趣的吸粉体验?想丰富景区体验?别着急,小编为你准备了一款爆款设备——时光穿梭机,720无死角旋转!!吸睛、刺激体验,将亲子、闺蜜、情侣…

【链表】Leetcode K个一组翻转链表

题目讲解 25. K 个一组翻转链表 算法讲解 虽然这道题是一道困难题,但是从代码层面很简单,只是一道简单的模拟:我们要先求出总共需要翻转的链表有多少组(链表的长度 / k),接下来就是翻转k的链表最链接的问…

【论文速读】|理解基于大语言模型的模糊测试驱动程序生成

本次分享论文:Understanding Large Language Model Based Fuzz Driver Generation 基本信息 原文作者:Cen Zhang, Mingqiang Bai, Yaowen Zheng, Yeting Li, Xiaofei Xie, Yuekang Li, Wei Ma, Limin Sun, Yang Liu 作者单位:南洋理工大学…

Zephyr sensor子系统学习

一、背景 2023年7月份nRF Connect SDK 2.4.0最新版本,使用的Zephyr V3.3版本。从Zephyr 3.5版本在子系统中加入了sensing子系统。 现在最新的nRF Connect SDK 2.6.0 release支持v3.5.99-ncs1,已经支持sensing子系统 nRF52840现在官方支持两个传感器de…

2023最新!nginx安装配置保姆级教程

2023最新!nginx安装配置保姆级教程 这篇文章了参考了这位的教程:https://blog.csdn.net/qq_36838700/article/details/129971765 导航 文章目录 2023最新!nginx安装配置保姆级教程一、nginx下载二、编译安装nginx安装pcre安装openssl、zlib、gcc依赖安装nginx 二、拓展 一、n…

01.Scala概述及环境配置

文章目录 [toc] 1.**Scala概述**2.**Scala环境搭建**2.1下载2.2环境变量配置 1.Scala概述 特点: 同样运行在JVM上,可以与现存程序同时运行。可直接使用Java类库。同Java一样静态类型。语法和Java类似,比Java更加简洁(简洁而并不…

Python-100-Days: Day01

Day01 Python简介 1.1989年Guido von Rossum在圣诞节之夜开始着手python语言编译器的编写。 2.1991年2月 Python v1 编译器诞生,使用C实现的,此时可以调用C的库函数。 3.1994年1月,Python v1.0 正式版发布。 4.2000年10月16日&#xff0…

2024软件测试面试题总结

🍅 视频学习:文末有免费的配套视频可观看 🍅 关注公众号【互联网杂货铺】,回复 1 ,免费获取软件测试全套资料,资料在手,涨薪更快 测试技术面试题 1、什么是兼容性测试?兼容性测试侧…

农业-大量数据在数据库中做AVG如何优化

如果是直接查询呢? 设备每个分区3s回传一次数据 一个设备有三个分区 一分钟需要回传 3 * 20 60次 一个小时 回传 60*60 3600次 一天回传 3600 * 24 86400次 我如果想计算以天为单位的气温数据,需要聚合8w条数据 进行优化 一分钟60次&#xff0c…

To String的几个作用

To String的几个作用 一、Object类中toString的作用 1、在主方法中我们可以直接用toString输出对象其中的内容 2、我们需要直接输出对象中所属内容时,直接使用toString方法输出语句,输出内容不友好,不便于阅读 子类: public c…

【快速上手ESP32(基于ESP-IDFVSCode)】11-MQTT

MQTT MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议)是一种基于发布/订阅模式的轻量级通讯协议,构建于TCP/IP协议之上。它最初由IBM在1999年发布,主要用于在硬件性能受限和网络状况不佳的情况下&…

如何使用 Fly.io 和 Tigris 部署 Next.js 应用

在本教程中,您将学习到应用部署平台 Fly.io 和全球分布式的 S3 兼容对象存储服务 Tigris。 这两个平台密切相关,使它们成为您项目的绝佳选择。您可以从 Fly.io 获得应用部署体验,并从 Tigris 获得对象存储功能。 应用部署相当简单易懂&…

短视频素材去哪里找,而且不带水印的那种?

为了确保视频创作者能够接触到全球范围内的优质资源,下面列出的视频素材网站各具特色,提供从标准视频到高动态范围(HDR)的素材,满足你在不同项目中的需求。 1. 蛙学府 (中国) 提供专业级的视频素材,特别适…

【C++】STL-vector的使用

目录 1、什么是vector? 2、vector的使用 2.1 vector的定义 ​编辑 2.2 遍历修改数据 2.3 迭代器 2.4 vector空间增长问题 2.5 vector的增删查改 3、迭代器失效 3.1 会引起其底层空间改变的操作,都有可能是迭代器失效 3.2 指定位置元素的删除操…