阿里软件测试工程师手把手教学——自动化测试报告太丑,怎么办?

TestNG的报告太难看了?测试结果维度显示受限?无法确定用例的优先级?查看错误信息不方便吗?

Allure测试报告框架帮助您轻松实现“高”报告呈现。本文通过实例演示了如何将Allure测试框架从0集成到1。它侧重于如何将Allure集成到现有的自动化测试项目中,以及如何优化报告的呈现。Allure非常强大,它支持多种语言的多种测试框架,无论是Java/Python还是Junit/TestNG。其他语言和框架的流程与本文一致,具体配置参考各语言框架的规范。

此外,本文还提供了一个基于TestNG+Maven的单元测试实例来模拟实际的自动化测试项目。

01

TestNG报告vsAllure报告

下图显示了同一个自动化测试项目的TestNG报告和Allure报告。Allure报告不仅在外观上有明显优势,而且提供了多维度的测试结果展示。

  • TestNG默认报告

  • Allure报告

02

Allure集成自动化测试流程

Allure的集成分为如下步骤:

  • 编写自动化测试工程实现“单元测试/API测试/UI测试”
  • 下载配置Allure服务
  • 在自动化测试工程中引入Allure支持
  • 在自动化测试工程中引入Allure注解
  • 指定配置文件,选择运行的测试套件
  • 运行Allure服务进行报告展示

03

编写自动化测试工程

本文提供了一个基于TestNG+Maven的单元测试实例模拟实际的自动化测试工程

工程结构说明:

  • Application:基于maven管理的待测应用,模拟业务系统
  • HelloTest:基于TestNG实现的单元测试,用以测试Application代码
  • testng.xml:TestNG的配置文件,用于动态配置运行时测试套件

配置Allure服务

  • 解压Zip文件,拷贝到指定目录下,配置系统环境变量指向解压后的bin目录:

  • 进入命令行,运行allure –version,出现版本号提示说明allure服务已经安装配置完毕。

工程中引入Allure支持

本文基于Maven实现项目管理。通过在pom.xml中配置Allure的jar包和插件,实现了对TestNG默认报表的分析和优化。详细配置说明见下图:

工程中引入Allure注解

Allure提供了强大的注解支持,通过这些注解可以实现报告的定制化展示,注解文档参见docs.qameta.io/allure/

  • @Epic, @Feature, @Story提供的归类功能,类似于目录功能
  • @DisplayName 指定Allure报告上展示的名字
  • @Severity 说明测试用例重要性, 根据实际业务情况对用例进行分类
  • @Step 说明测试执行步骤, 用于标识测试用例的执行细节
  • @Attachment 添加HTML报告上展示的附件
  • @Category 实现自定义的缺陷分类
  • @TmsLink 实现和缺陷管理系统的关联

本示例中引入了@Epic, @Story, @Severity, @Step说明如何在已有的测试工程中添加Allure注解。

运行测试工程生成测试结果数据

这个例子基于Maven项目。在Eclipse中,选中工程右键 Run as –> Maven test 测试运行的项目来运行测试并生成测试数据。

运行后,默认会生成allure-results文件夹,测试数据(json格式的测试数据)会保存在其中。

运行Allure服务生成美化后的测试报告

切换到项目根目录,打开命令行,运行allure serve命令生成测试报告。

测试报告解析

总览/图表页面中查看测试概况:包含测试用例数,测试通过率,测试Defect,不同优先级测试用例的情况,测试执行耗时,测试套件数,测试的场景分类。其中测试场景由自动化代码中@Epic的标识,优先级由@Severity标识。

图表显示汇总数据

类别显示defect情况

功能显示用例分类

Allure不仅可以和TestNG/Junit集成,还可以集成到Jenkins当中发布测试报告。


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值