pytest的常用插件和Allure测试报告

pytest常用插件

pytest-html插件

安装:

pip install pytest-html -U

用途:

生成html的测试报告

用法:

​在.ini配置文件里面添加

addopts = --html=report.html --self-contained-html

效果:

执行结果中存在html测试报告路径

pytest-xdist插件

安装:

pip install pytest-xdist -U

用途:

可以使用并发的方式执行用例

用法:

在.ini配置文件中添加

addopte -n 并发数(建议不要超过系统CPU的核心数)
如果并发数为0,相当于没有使用插件

效果:

会减少用例的执行时间,但是由于调用进程也需要消耗资源,所以填写的并发数太多时间并不会得到有效的提升

无并发执行情况:

并发数为2的执行情况:

可以看到效率有所提高

pytest-rerunfailures插件

安装:

pip install pytest-rerunfailures -U

用途:

在用例失败后进行重试,可以执行重试最大次数和每次重试之前的等待时间

用法:

在.ini配置文件中添加

addopts --reruns 重新执行的数量 --reruns-delay 每次重新执行的等待时间
如: --reruns 5 --reruns-delay 1   表示如果失败最多重新执行5次,并且每次重新执行之间间隔一秒

效果:

用例内容:

生成一个随机数范围是[1, 3)

断言这个随机数是否等于1,相当于是50%的概率

def test_1():
    a = random.randint(1, 3)
    assert a == 1

使用--reruns 5 --reruns-delay 1的配置执行后

pytest-order插件

安装:

pip install pytest-order -U

用途:

给用例排序,让用例可以按照执行的顺序执行

用法:

在用例上面加上如下标识

@pytest.mark.order(1)

执行时会按照数字从小到大的顺序执行,如果没有填数字或者没有添加标识的用例,会在排序的所有用例执行之后,按照原本的用例顺序执行。

效果:

用例内容:

test_1没有添加标识

test_2添加了标识但没有加入数字

test_3、test_4、test_5添加了标识并且加入了数字

def test_1():
    print('执行用例test_1')


@pytest.mark.order()
def test_2():
    print('执行用例test_2')


@pytest.mark.order(1)
def test_3():
    print('执行用例test_3')

@pytest.mark.order(3)
def test_4():
    print('执行用例test_4')

@pytest.mark.order(2)
def test_5():
    print('执行用例test_5')

预期执行顺序:

test_3、test_5、test_4、test_1、test_2

执行结果:

符合预期

pytest-base-url插件

安装:

pip install pytest-base-url -U

用途:

在用例中可以使用名为base-url的变量,可以在用例之间传递信息

用法:

在.ini配置文件中添加:

addopts  --base-url 内容
或者
base_url = 内容

效果:

用例内容:

打印base-url的内容

def test_abc(base_url):
    print('正在使用的环境是:', base_url)

base-url的内容为:

base_url = 测试环境

效果:

pytest-result-log插件

安装:

pip install pytest-result-log -U

用途:

打印的日志更详细,并且会对不同用例的日志进行区分

用法:

安装之后即可用

配置格式:

log_file = ./pytest.log
log_file_level = info
log_file_format = %(levelname)-8s %(asctime)s [%(name)s:%(lineno)s] : %(message)s
log_file_date_format = %Y-%m-%d %H:%M:%S

# 设置打印日志的级别
result_log_level_verbose = info

效果:

用例内容:

import logging

logger = logging.getLogger()

def test_log1():
    logger.info("哈哈哈,我是日志内容")

def test_log2():
    logger.info("哈哈哈,我也是日志内容")
    assert 1 == 2

执行结果:

会生成一个.log的文件,文件名为配置中设置的名称

log_file = ./pytest.log

Allure测试报告框架

环境需要

需要安装Allure和jdk11及以上版本(建议17)

并且需要将其加入到系统的环境变量

最终结果就是:在cmd窗口或者终端中输入java和allure都可以出现对应的内容

allure-pytest插件

安装:

pip install allure-pytest -U

用途:

将pytest生成的测试报告转化为Allure可以识别的数据

用法:

在.ini配置文件中添加:

addopts  --alluredir=./temps --clean-alluredir

Allure测试报告框架的用法

当生成了pytest的测试报告之后,在终端输入:

allure generate -c -o report temps

其中generate表示生成报告

-c表示清空之前的报告

-o表示报告存放的目录名字(后面的report是我设置的目录名字)

temps表示allure-pytest插件生成的测试结果存放的位置(名字可以自己更换)

可以通过在main.py文件中添加如下代码,用来在用例执行完之后,自动执行该命令

os.system('allure generate -c -o report temps')

效果:

点击你存放allure报告的目录(我的是report),找到index.html用浏览器打开

 

其中测试套会根据用来存在的目录进行区分

Allure测试报告定制

在Allure目录下找到config/allure.yml

修改成如下内容(就是把 - custom-logo-plugin 那一行加进去):

plugins:
  - junit-xml-plugin
  - xunit-xml-plugin
  - trx-plugin
  - behaviors-plugin
  - packages-plugin
  - screen-diff-plugin
  - xctest-plugin
  - jira-plugin
  - xray-plugin
  - custom-logo-plugin

然后在来到Allure的plugins\custom-logo-plugin\static路径下

找到图片文件和css文件

设计好对应的logo图片和css样式,加进去Allure报告的logo就会修改了

Allure报告中对用例分类

我们可以在用例加上allure标记

同类型的标记中内容相同的标记会被归为一类

# 对测试用例进行划分,级别从大到小
@allure.epic()
@allure.feature()
@allure.story()
@allure.title()

举例:

@allure.epic('项目标记1')
@allure.feature('模块标记1')
class Test1:
    @allure.story('场景1')
    @allure.title('功能1')
    def test_1(self):
        print('执行了test_1')

    @allure.story('场景1')
    @allure.title('功能2')
    def test_2(self):
        print('执行了test_2')

    @allure.title('功能2')
    def test_3(self):
        print('执行了test_3')

@allure.epic('项目标记1')
@allure.feature('模块标记2')
class Test2:
    @allure.title('功能1')
    def test_1(self):
        print('执行了test_1')

    @allure.title('功能1')
    def test_2(self):
        print('执行了test_2')

    @allure.story('场景1')
    @allure.title('功能2')
    def test_3(self):
        print('执行了test_3')

Test1类和Test2类都加上了epic('项目标记1')此时他们会在报告会打包到一个名为"项目标记1"的目录下

又因为他们各自有带有不同的feature()标记,所以在"项目标记1"目录下Test1类和Test2类中的用例会再被分为两个目录:"模块标记1"和"模块标记2"

Test1类中用例又被分为"场景1"目录和直接展示的用例,以此类推

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

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

相关文章

智能汽车竞赛摄像头处理(3)——动态阈值二值化(大津法)

前言 (1)在上一节中,我们学习了对图像的固定二值化处理,可以将原始图像处理成二值化的黑白图像,这里面的本质就是将原来的二维数组进行了处理,处理后的二维数组里的元素都是0和255两个值。 (2…

RFID手持终端_智能pda手持终端设备定制方案

手持终端是一款多功能、适用范围广泛的安卓产品,具有高性能、大容量存储、高端扫描头和全网通数据连接能力。它能够快速平稳地运行,并提供稳定的连接表现和快速的响应时,适用于医院、物流运输、零售配送、资产盘点等苛刻的环境。通过快速采集…

javaScript的序列化与反序列化

render函数的基本实现 javaScript的序列化与反序列化 一,js中的序列化二,序列化三,反序列化四,总结 一,js中的序列化 js中序列化就是对象转换成json格式的字符串,使用JSON对象的stringify方法,…

18.3K Star,简洁强大下载利器

Hi,骚年,我是大 G,公众号「GitHub指北」会推荐 GitHub 上有趣有用的项目,一分钟 get 一个优秀的开源项目,挖掘开源的价值,欢迎关注。 今天推荐一个强大简洁下载利器,用于从各种网站下载图像/视…

Linux(一)

介绍 常见的操作系统(windows、IOS、Android、MacOS, Linux, Unix); 一个开源、免费的操作系统,其稳定性、安全性、处理多并发已经得到业界的认可;目前很多企业级的项目(c/c/php/python/java/go)都会部署到 Linux/unix 系统上。 吉祥物 …

leetcode刷题(剑指offer) 297.二叉树的序列化和反序列化

297.二叉树的序列化与反序列化 序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据。 请设计一个算法来实现…

使用wda框架实现IOS自动化测试详解

目录 1、weditor元素定位工具 1.1、weditor的安装和使用 2、wda iOS自动化框架 2.1、wda概述 2.2、wda安装 2.3、wda的使用 2.3.1、全局配置 2.3.2、创建客户端 2.3.3、APP相关操作 1、启动APP 2、关闭APP 3、获取APP状态信息 4、获取当前APP的运行信息 2.3.4、设…

ruoyi(若依)(el-menu也可参考)菜单栏过长显示省略号才显示气泡

一、背景 若依前后端分离的版本,新版本中优化了菜单名称过长悬停显示标题,但是是悬浮所有长度大于5的标题。可以查看提交记录:https://gitee.com/y_project/RuoYi-Cloud/commit/99932d91c0144da9f34f5bb05683cc0b86303217 但是我希望是只悬浮…

Vulnhub靶机:hacksudo2 (HackDudo)

一、介绍 运行环境:Virtualbox 攻击机:kali(10.0.2.15) 靶机:hacksudo2 (HackDudo)(10.0.2.44) 目标:获取靶机root权限和flag 靶机下载地址:https://download.vulnh…

双非本科准备秋招(15.3)—— 力扣二叉树

今天学了二叉树结点表示法,建树代码如下。 public class TreeNode {public int val;public TreeNode left;public TreeNode right;public TreeNode(int val) {this.val val;}public TreeNode(int val, TreeNode left, TreeNode right) {this.val val;this.left …

C++ | 部分和函数partial_sum的使用技巧

如果你需要处理一个数组的前缀和,或者数组中某一段元素的前缀和,你会怎么做呢? partial_sum函数是STL中的函数,用于计算范围的部分和,并从结果开始分配范围中的每个元素,range[first,last)中相应元素的部分…

MH-ET LIVE Boards(ATTiny88)实验一---点亮板载灯

MH-ET LIVE Boards(ATTiny88)实验一点亮板载灯 在Arduino IDE中添加开发板资源包加入开发板json添加开发板 安装开发板驱动方法一:github下载2.0a4.rar方法二:开发板的package包中自带的2.0a4.rar安装驱动确认安装成功 blink.ino程序测试![在…

知识图谱嵌入学习在推理方法中的应用与挑战

目录 前言1 关系推理的嵌入模型1.1 嵌入模型介绍1.2 模型的差异1.3 嵌入模型的发展趋势 2 符号推理与向量推理3 嵌入模型的多样性4 强化学习与挑战5 元关系学习结论 前言 在人工智能领域,推理一直是关键任务之一。然而,传统的符号推理受限于人工定义&am…

【Vitis】Vitis HLS学习系列笔记 :第一个例程

在学习vitis的过程中一定要跑几个例程试试看,这中间遇到了几个小问题,记录下 有干货,请注意查收:作为新手,跑例程大概率会遇到问题,这里记录几个问题,如果刚好你也遇到,一定会帮到你…

每日一题——LeetCode1389.按既定顺序创建目标数组

方法一 splice 使用splice函数就可以在数组的指定索引位置添加元素 var createTargetArray function(nums, index) {let res[]for(let i0;i<nums.length;i){res.splice(index[i],0,nums[i])}return res }; 消耗时间和内存情况&#xff1a; 方法二 模拟 如果res[index[…

计算机网络——链路层(1)

计算机网络——链路层&#xff08;1&#xff09; 小程一言专栏链接: [link](http://t.csdnimg.cn/ZUTXU)前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家&#xff0c; [跳转到网站](https://www.captainbed.…

[每日一题] 02.03 - 质因数分解

质因数分解 枚举到n的平方根&#xff08;得包括平方根&#xff09; 偶数去除 import math n int(input()) if n % 2 0:print(max(n // 2,2)) else:for i in range(3,int(math.sqrt(n)) 1,2):if n % i 0:print(max(n // i,i))

2023年度总结 | 关于意义,爱与回望——写给清醒又无知的20岁

Hi&#xff0c;大家好&#xff0c;我是半亩花海&#xff0c;一名再普通不过的大学生。2023年&#xff0c;20岁&#xff0c;充实而零乱的一年&#xff0c;清醒又无知的一年。年末&#xff0c;最近的一些事儿也让我逐渐地有感而发&#xff0c;心静&#xff0c;除杂&#xff0c;思…

redis布隆过滤器(Bloom)详细使用教程

文章目录 布隆过滤器1. 原理2. 结构和操作3. 特点和应用场景4. 缺点和注意事项 应用-redis插件布隆过滤器使用详细过程安装以及配置springboot项目使用redis布隆过滤器下面是布隆过滤器的一些基础命令 扩展 布隆过滤器 Bloom 过滤器是一种概率型数据结构&#xff0c;用于快速判…

在低代码平台上实现精益软件开发:提高效率与灵活性的关键实践

什么是精益软件开发&#xff1f; 精益软件开发是一种敏捷的软件开发框架。它基于最小化浪费和最大化价值的原则。该框架基于最小可行产品策略运行&#xff0c;该策略强调交付具有基本基本功能的产品&#xff0c;然后根据收到的反馈进行迭代以即兴发挥并提供卓越。 精益软件开发…