生成报告配置xml_自动化测试报告太丑?Allure拯救你!

本文介绍了如何使用Allure测试报告框架提升自动化测试报告的展示效果。通过实例演示了Allure在TestNG和Maven环境中的集成过程,包括环境配置、注解使用、报告生成等步骤,强调了Allure在外观和多维度展示上的优势。
摘要由CSDN通过智能技术生成

cf2c36ebea436e6f2bf285d4d3ab55d8.png

TestNG报告太丑? 测试结果维度展现有限? 无法区分用例优先级? 不方便查看错误信息?

Allure测试报告框架帮助你轻松实现”高大上”报告展示。本文通过示例演示如何从0到1集成Allure测试框架。重点展示了如何将Allure集成到已有的自动化测试工程中、以及如何实现报表的优化展示。Allure非常强大,支持多种语言多种测试框架,无论是Java/Python还是Junit/TestNG,其他语言或者框架实现的流程和本文一致,具体配置参照各语言框架规范。

此外,本文提供了一个基于TestNG+Maven的单元测试实例,用以模拟实际的自动化测试工程,代码位置:https://github.com/HelloKitty666/sample-unit-testngallure  。

077b9846c22ef10c7adc34fa346d18fb.pngTestNG报告vs Allure报告 077b9846c22ef10c7adc34fa346d18fb.png

下图展示了同一自动化测试工程的TestNG报告和Allure报告,Allure报告不仅在外观上有着显而易见的优势,还提供了多维度的测试结果展示。

TestNG默认报告

1d6ce90897dbc471ba7a24acfefc1f7d.png

Allure报告

e26a081575d8be9ca14691f2c84ace2a.png

3b2b49d80f79611fa58c8ea295cd22d8.png

Allure集成自动化测试流程

a57cce92bf39d055d170f45546cace58.png

Allure的集成分为如下步骤:

  • 1. 编写自动化测试工程实现“单元测试/API测试/UI测试”

  • 2. 下载配置Allure服务

  • 3. 在自动化测试工程中引入Allure支持

  • 4. 在自动化测试工程中引入Allure注解

  • 5. 指定配置文件,选择运行的测试套件

  • 6. 运行Allure服务进行报告展示

077b9846c22ef10c7adc34fa346d18fb.png编写自动化测试工程 077b9846c22ef10c7adc34fa346d18fb.png

本文提供了一个基于TestNG+Maven的单元测试实例模拟实际的自动化测试工程,代码实例请到Github上下载:https://github.com/HelloKitty666/sample-unit-testngallure 。

工程结构说明:

6c49d42e7a5a78caf4939961d16ff885.png

• Application:基于maven管理的待测应用,模拟业务系统

• HelloTest: 基于TestNG实现的单元测试,用以测试Application代码

• testng.xml:TestNG的配置文件,用于动态配置运行时测试套件

配置Allure服务

进入Allure官网http://allure.qatools.ru/ ,点击右上角DownLoad进入下载页面,下载zip文件。

16a1e26ab95ded9e1d54753d73f4c717.png

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

04e756678224f42c9be831ad49240bd0.png

c425a190571fe7c812e31437d7de2fe1.png

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

f951780eee1b4fdfa15724a320de26bd.png

工程中引入Allure支持

本文是基于Maven实现工程管理,通过在pom.xml中配置Allure的jar包和插件实现TestNG默认报告的解析和优化,详细配置说明参见下图:

cef44593fdce37f8054f5807450cea9d.png

工程中引入Allure注解

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

• @Epic, @Feature, @Story提供的归类功能,类似于目录功能

• @DisplayName 指定Allure报告上展示的名字

• @Severity 说明测试用例重要性, 根据实际业务情况对用例进行分类

• @Step 说明测试执行步骤, 用于标识测试用例的执行细节

• @Attachment 添加HTML报告上展示的附件

• @Category 实现自定义的缺陷分类

• @TmsLink 实现和缺陷管理系统的关联

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

1d364b09da5b7cf0db64e630b49603e2.png

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

本示例是基于Maven工程构建,在Eclipse中选中工程右键 Run as –> Maven test 运行测试,生成测试数据。

5023880520324064ab9ee769b01ed1b9.png

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

6e5dfeb4982723cb092539b425950de0.png

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

切换到工程根目录下,打开命令行运行allure serve 命令,生成测试报告。03073ffbc10d166097163e58c7411207.png

在浏览器中输入http://10.255.6.35:57135/index.html 即可查看测试报告。

测试报告解析

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

图表显示汇总数据

5128d5418af10c7792cde26bec84f725.png

类别显示defect情况

4edf9525e8b8e6447bca7d9fd6db9c46.png

功能显示用例分类

4b0444141f2d3751410a997de1de63fc.png

Allure不仅可以和TestNG/Junit集成,还可以集成到Jenkins当中发布测试报告。预知后事如何,请听下回分解。

4704e8c7e737dc09075c0a5f85488ed1.gif

Bye~

RECOMMEND推荐阅读

从技术走向管理的一些感悟

【自动化接口用例】从 1 到 1000 过程中的实践和思考

12条MySQL优化技巧,提速不止十倍!

55564162b0b80ec02a17210cc7bdc409.png

ceb5dfddd90756a589381e100a942e44.png

嗨,你还在看吗?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值