Pytest 与allure测试报告集成

news/2024/12/19 6:41:32/

通过Feature, story, step 记录测试的功能,场景及测试步骤

# login.py
'''
login_func函数
传入参数是name 和 password
当输入的name和password与数据库db_data中数据一致时,返回“XXX成功登录系统!”
当输入的name存在于数据库db_data但密码不正确时,返回“XXX账号,密码输出错误,请重新输入!”
当输入的name不存在于数据库db_data中时,返回“XXX账号不存在,请输入正确的账号!”
'''def login_func(name,password):db_data = {"name": ['Jie', 'Jack', 'Jame'], "password": {'Jie': '123456', 'Jack': '111111', 'Jame': '222222'}}if name in db_data["name"] and str(password) == db_data["password"][name]:return(f"{name} 成功登录系统!")elif name in db_data["name"] and str(password) != db_data["password"][name]:return(f"{name} 账号,密码输出错误,请重新输入!")else:return(f"{name} 账号不存在,请输入正确的账号!")

login.py是一个登录模块,login_func函数主要实现登录功能

test_mod9.py主要实现对login.py中login_func函数功能测试

from login import login_func@allure.feature("测试登录模块")
class TestMod9:@allure.title("测试登录正例01")@allure.story("用正确的账号与密码登录")def test_login_01(self):name = "Jie"password = "123456"with allure.step(f"使用账号名称:{name},密码:{password}进行登录"):login = login_func(name,password)exc = f"{name} 成功登录系统!"pytest.assume(login == exc)@allure.title("测试登录反例02")@allure.story("用正确的账号与错误的密码登录")def test_login_02(self):name = "Jie"password = "023456"with allure.step(f"使用账号名称:{name},密码:{password}进行登录"):login = login_func(name,password)exc = f"{name} 账号,密码输出错误,请重新输入!"pytest.assume(login == exc)@allure.title("测试登录反例03")@allure.story("用不存在的账号进入登录")@allure.description("当登录账号不存在时,有正确的提示")def test_login_03(self):name = "Hele"password = "023456"with allure.step(f"使用账号名称:{name},密码:{password}进行登录"):login = login_func(name, password)exc = f"{name} 不存在账号,请输入正确的账号!"pytest.assume(login == exc)

test_mod9.py测试模块中,包含一个class TestMod9 测试类,测试类下包含了测试登录功能的三个测试用例

@allure.feature("测试登录模块"): 在报告中记录测试需求(即测试用例集的功能,要测试什么)一般修饰测试类(testsuite);

@allure.story("用正确的账号与密码登录"):在报告中记录根据测试需求细化的测试场景(即测试用例场景描述)一般修饰测试用例即方法;

(注:feature与story属于父子关系)

@allure.title("测试登录反例03"):在报告中自定义测试用例标题

@allure.description("当登录账号不存在时,有正确的提示"):报告中测试用例的详细描述

with allure.step(f"使用账号名称:{name},密码:{password}进行登录"): 在报告中记录测试用例中的测试步骤或详细信息,放在测试用例的代码逻辑中;

  • -alluredir=./result/ 为指定报告结果数据存入路径,执行上述命令后会自动在该目录下生成一个result文件夹存放报告数据

 

命令:allure serve ./result/

1、在本地启动一个server查看allure报告

 

 2、根据result文件夹中的数据在项目目录下生成allure-report存入html报告

命令:allure generate ./result/
命令:allure open ./allure-report 在本地启动查看allure报告的服务
命令:allure generate ./result/ -o ./allure-report/ --clean # 每次生成报告时先清除原报告数据

 

 

 

 


http://www.ppmy.cn/news/1344260.html

相关文章

在 Linux 中把用户添加到组的四个方法

Linux 组是用于管理 Linux 中用户帐户的组织单位。对于 Linux 系统中的每一个用户和组,它都有惟一的数字标识号。它被称为 用户 ID(UID)和组 ID(GID)。组的主要目的是为组的成员定义一组特权。它们都可以执行特定的操作…

统计数字出现次数的数位动态规划解法-数位统计DP

在处理数字问题时,我们经常遇到需要统计一定范围内各个数字出现次数的情况。这类问题虽然看起来简单,但当数字范围较大时,直接遍历统计的方法就变得不再高效。本文将介绍一种利用数位动态规划(DP)的方法来解决这一问题,具体来说,是统计两个整数a和b之间(包含a和b)所有…

liunx 备份文件脚本、还原文件脚本、替换文件脚本

最近项目中有这个业务,需要编写脚本文件以实现各种需求。由于我已经很长时间没有写过脚本了,因此我决定记录下这个过程,以便将来有类似的需求时可以参考。 在开始编写脚本之前,我首先对业务需求进行了深入的分析和理解。我了解了项…

华清作业day53

1.c代码&#xff1a; #include <stdio.h> #include <stdlib.h> #include <sys/types.h> #include <sys/ipc.h> #include <sys/msg.h> #include <string.h> #include <unistd.h> #include <sys/wait.h> struct msgbuf{long in…

使用MATLAB驱动USRP-N320实现OFDM自收自发

文章目录 前言一、收发代码二、截取一帧 OFDM三、执行主函数四、运行结果五、资源自取 前言 本文作为实验结果记录及测试&#xff0c;方便后面回顾所做的工作。本文基于一台电脑和一台 USRP 设备实现了 OFDM 自发和自收功能 一、收发代码 ofdm_tx_rx_test.m 核心代码&#x…

ArrayList和LinkedList的区别是什么

ArrayList 和 LinkedList 分别代表了两类不同的数据结构&#xff1a;动态数组和链表。它们都实现了 Java 的 List 接口&#xff0c;但是有着各自独特的特点和性能表现。 1. 数据结构 ArrayList 是基于可调整大小的数组实现的。它允许快速随机访问&#xff0c;因为内部元素可通…

体悟PyTorch的优雅

——PyTorch 是所有的框架中面向对象设计的最优雅的一个。 —— PyTorch的设计最符合人们的思维。 编程是一门艺术&#xff0c;编程可以很优雅。研究可以很优雅&#xff0c;研发也可以很优雅。我们的人生可以很优雅&#xff01; 1. PyTorch 的优雅 PyTorch 的面向对象设计确实…

Mybatis中的sql-xml延迟加载机制

Mybatis中的sql-xml延迟加载机制 hi&#xff0c;我是阿昌&#xff0c;今天记录一下关于Mybatis中的sql-xml延迟加载机制 一、前言 首先mybatis技术本身就不多介绍&#xff0c;说延迟加载机制之前&#xff0c;那要先知道2个概念&#xff1a; 主查询对象关联对象 假设咱们现…