Pytest 测试框架与Allure 测试报告——Allure2测试报告-L1

2024-01-21 06:44

本文主要是介绍Pytest 测试框架与Allure 测试报告——Allure2测试报告-L1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录:

  1. allure2安装
    1. Allure2介绍
    2. Allure2报告展示
    3. Allure2报告展示-首页概览
    4. Allure2报告展示-用例详情页
    5. Allure2安装
    6. Allure2下载与安装
    7. Allure环境验证
    8. 插件安装-Python
    9. 插件安装-Java
    10. 验证插件安装-Java
  2. allure2运行方式
    1. 生成测试报告流程
    2. 使用Allure2运行方式-Python
    3. 使用Allure2运行方式-Java
    4. 问题
    5. 代码示例:

1.allure2安装

Allure2 介绍
  • Allure 是由 Java 语⾔开发的⼀个轻量级,灵活的测试报告⼯具。
  • Allure 多平台的 Report 框架。
  • Allure ⽀持多语⾔,包括 python、JaveScript、PHP、Ruby 等。
  • 可以为开发/测试/管理等人员提供详尽的的测试报告,包括测试类别、测试步骤、日志、图片、视频等。
  • 可以为管理层提供高水准的统计报告。
  • 可以集成到 Jenkins 生成在线的趋势汇总报告。
Allure2 报告展示

github 地址:https://github.com/allure-framework/allure2

Allure2 报告展示 - 首页概览

Allure2 报告展示 - 用例详情页 

Allure2 安装
  1. 安装 Java,需要配置环境变量。
  2. 安装 Allure ,需要配置环境变量。
  3. 安装插件
    • Python:pip install allure-pytest
    • Java:Maven插件安装。
Allure2 下载与安装
  1. 先下载 Allure 源码包到本地。
    • 下载地址 1
    • 下载地址 2
      • mac/linux: 下载 tar
      • windows: 下载 zip
  2. 配置环境变量:解压后将 bin 目录加入 PATH 环境变量。
Allure 环境验证
  • 执行命令验证环境

# 环境验证
allure --version
插件安装-Python
  • 安装 Python 插件 allure-pytest
    • 执行命令:pip install allure
# linux/mac
> pip list |grep allure
allure-pytest         x.xx.x# windows
> pip list |findstr allure
allure-pytest         x.xx.x
 插件安装-Java
  • <groupId>指定了插件的groupId。
  • <artifactId>指定了插件的artifactId。
  • <version>指定了插件的版本号。
<properties><maven.compiler.encoding>UTF-8</maven.compiler.encoding><maven.compiler.version>3.10.1</maven.compiler.version><maven-surefire-plugin.version>3.0.0-M9</maven-surefire-plugin.version><!-- 使用 Java 17 语言特性 ( -source 11 )  --><java.version>17</java.version><!-- 对应junit Jupiter的版本号;放在这里就不需要在每个依赖里面写版本号,导致对应版本号会冲突 --><junit.jupiter.version>5.9.2</junit.jupiter.version><!-- log日志 --><slf4j.version>2.0.6</slf4j.version><logback.version>1.4.5</logback.version><!-- yaml对应解析 --><jackson.version>2.14.2</jackson.version><!-- hamcrest断言 --><hamcrest.version>2.2</hamcrest.version><!-- allure报告 --><allure.version>2.21.0</allure.version><allure.maven.version>2.12.0</allure.maven.version><aspectj.version>1.9.19</aspectj.version><allure.cmd.download.url>https://repo.maven.apache.org/maven2/io/qameta/allure/allure-commandline</allure.cmd.download.url></properties><!--    物料清单 (BOM)--><dependencyManagement><dependencies><!--当使用 Gradle 或 Maven 引用多个 JUnit 工件时,此物料清单 POM 可用于简化依赖项管理。不再需要在添加依赖时设置版本--><dependency><groupId>org.junit</groupId><artifactId>junit-bom</artifactId><version>${junit.jupiter.version}</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><dependencies><!-- junit5 --><!-- 创建 Junit5 测试用例的 API--><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter</artifactId><!--对应添加的依赖的作用范围--><scope>test</scope></dependency><!-- 兼容 JUnit4 版本的测试用例--><dependency><groupId>org.junit.vintage</groupId><artifactId>junit-vintage-engine</artifactId><scope>test</scope></dependency><!--suite套件依赖 --><dependency><groupId>org.junit.platform</groupId><artifactId>junit-platform-suite</artifactId><scope>test</scope></dependency><!-- log日志 --><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>${slf4j.version}</version><scope>compile</scope></dependency><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>${logback.version}</version><scope>compile</scope></dependency><!--        allure报告--><dependency><groupId>io.qameta.allure</groupId><artifactId>allure-junit5</artifactId><version>${allure.version}</version></dependency><!-- https://mvnrepository.com/artifact/org.aspectj/aspectjweaver --><dependency><groupId>org.aspectj</groupId><artifactId>aspectjweaver</artifactId><version>${aspectj.version}</version></dependency><!--        yaml文件解析--><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>${jackson.version}</version></dependency><dependency><groupId>com.fasterxml.jackson.dataformat</groupId><artifactId>jackson-dataformat-yaml</artifactId><version>${jackson.version}</version></dependency></dependencies><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>${maven.compiler.version}</version><configuration><source>${java.version}</source><target>${java.version}</target><!-- 设置编码为 UTF-8 --><encoding>${maven.compiler.encoding}</encoding></configuration></plugin><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-surefire-plugin</artifactId><version>${maven-surefire-plugin.version}</version><configuration><argLine>-javaagent:"${settings.localRepository}/org/aspectj/aspectjweaver/${aspectj.version}/aspectjweaver-${aspectj.version}.jar"</argLine><includes><!--  <include>**/*Test</include>--><!--  <include>**/Test*</include>--></includes><systemProperties><property><name>allure.results.directory</name><value>${project.build.directory}/allure-results</value></property></systemProperties></configuration><dependencies><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter-engine</artifactId><version>${junit.jupiter.version}</version></dependency><dependency><groupId>org.junit.vintage</groupId><artifactId>junit-vintage-engine</artifactId><version>${junit.jupiter.version}</version></dependency></dependencies></plugin><plugin><groupId>io.qameta.allure</groupId><artifactId>allure-maven</artifactId><version>${allure.maven.version}</version><configuration><reportVersion>${allure.version}</reportVersion><allureDownloadUrl>${allure.cmd.download.url}/${allure.version}/allure-commandline-${allure.version}.zip</allureDownloadUrl></configuration></plugin></plugins></build>
</project>
验证插件安装-Java
mvn clean test
mvn allure:report# allure报告打开网站
mvn allure:serve

2.allure2运行方式

生成测试报告流程

使用 Allure2 运行方式-Python 
  • 使用 --alluredir 参数生成测试报告。
# 在测试执行期间收集结果
pytest [测试用例/模块/包] --alluredir=./result/  (—alluredir这个选项 用于指定存储测试结果的路径)# 生成在线的测试报告
allure serve ./result
使用 Allure2 运行方式-Java
  • 使用 allure:report 参数生成测试报告。
# 在测试执行期间收集结果
# mvn命令行使用 maven插件安装
mvn clean test allure:report# 生成在线的测试报告
# mvn 直接找target/allure-results目录
mvn allure:serve 
问题
  • 运行mvn命令对应没有在target下面生成allure-results目录,怎么解决?

  • 解决方案:

    • 在src/test/resources路径下配置allure配置文件allure.properties,指名allure报告生成路径。
    allure.results.directory=target/allure-resultsa
  •  运行mvn命令一直卡在下载中,如下图:

 

  • 解决方案:
    • 在项目下创建.allure文件夹。
    • 下载allure解压到.allure文件夹下。

 

代码示例:

test_order.py

def test_one():assert Truedef test_two():assert Truedef test_three():assert Truedef test_one1():assert Truedef test_two2():assert Truedef test_three3():assert True

 在终端运行:

pytest .\test_order.py --alluredir=./results
allure serve .\results 

运行结果:

 

 

这篇关于Pytest 测试框架与Allure 测试报告——Allure2测试报告-L1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/628678

相关文章

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1