接口自动化测试,生成一份简洁漂亮的测试报告,不仅可以让阅读者心情大好,而且可以提高阅读效率。
TestNG有自带的测试报告、网上也有使用ReportNG插件生成testng报告,但是效果差强人意,这里介绍使用ExtentReport测试报告框架生成漂亮的测试报告。
extentreports官网

入门程序

引入依赖

<!-- pom.xml --><dependency><groupId>com.relevantcodes</groupId><artifactId>extentreports</artifactId><version>2.41.1</version></dependency><dependency><groupId>com.vimalselvam</groupId><artifactId>testng-extentsreport</artifactId><version>1.3.1</version></dependency><dependency><groupId>com.aventstack</groupId><artifactId>extentreports</artifactId><version>3.0.6</version></dependency>
import org.testng.Assert;
import org.testng.Reporter;
import org.testng.annotations.Test;public class TestMethodsDemo {@Testpublic void test1(){Assert.assertEquals(1, 2);}@Testpublic void test2(){Assert.assertEquals(2,2);}@Testpublic void test3(){Assert.assertEquals("bbb", "bbb");}@Testpublic void logDemo(){Reporter.log("这是我们自己写的日志");throw new RuntimeException("运行时异常");}
}

testng.xml

<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" ><suite name="我们自己的接口测试套件"><test name="这些是测试模块"><classes><class name="com.tester.extend.demo.TestMethodsDemo"><methods><include name="test1"/><include name="test2"/><include name="test3"/><include name="logDemo"/></methods></class></classes></test><listeners><listener class-name="com.vimalselvam.testng.listener.ExtentTestNgFormatter"/></listeners>
</suite>

运行testng.xml,生成测试报告

使用浏览器查看生成的test-output/emailable-report.html

使用浏览器查看生成的test-output/report.html,发现界面奇丑无比,查看html源码发现,是css样式无法加载导致的。

解决css无法加载

**方法1:**把css下载到本地,把生成报告对应的静态资源地址改成本地。
**方法2:**重写ExtentTestNgFormatter.java文件,在初始化方法中添加,修改cdn为ResourceCDN.EXTENTREPORTS

htmlReporter.config().setResourceCDN(ResourceCDN.EXTENTREPORTS);

ExtentTestNGIReporterListener.java
详细代码如下

package com.tester.extend.demo;import com.aventstack.extentreports.ExtentReports;
import com.aventstack.extentreports.ExtentTest;
import com.aventstack.extentreports.ResourceCDN;
import com.aventstack.extentreports.Status;
import com.aventstack.extentreports.model.TestAttribute;
import com.aventstack.extentreports.reporter.ExtentHtmlReporter;
import com.aventstack.extentreports.reporter.configuration.ChartLocation;
import com.aventstack.extentreports.reporter.configuration.Theme;
import org.testng.*;
import org.testng.xml.XmlSuite;import java.io.File;
import java.util.*;public class ExtentTestNGIReporterListener implements IReporter {//生成的路径以及文件名private static final String OUTPUT_FOLDER = "test-output/";private static final String FILE_NAME = "index.html";private ExtentReports extent;@Overridepublic void generateReport(List<XmlSuite> xmlSuites, List<ISuite> suites, String outputDirectory) {init();boolean createSuiteNode = false;if(suites.size()>1){createSuiteNode=true;}for (ISuite suite : suites) {Map<String, ISuiteResult> result = suite.getResults();//如果suite里面没有任何用例,直接跳过,不在报告里生成if(result.size()==0){continue;}//统计suite下的成功、失败、跳过的总用例数int suiteFailSize=0;int suitePassSize=0;int suiteSkipSize=0;ExtentTest suiteTest=null;//存在多个suite的情况下,在报告中将同一个一个suite的测试结果归为一类,创建一级节点。if(createSuiteNode){suiteTest = extent.createTest(suite.getName()).assignCategory(suite.getName());}boolean createSuiteResultNode = false;if(result.size()>1){createSuiteResultNode=true;}for (ISuiteResult r : result.values()) {ExtentTest resultNode;ITestContext context = r.getTestContext();if(createSuiteResultNode){//没有创建suite的情况下,将在SuiteResult的创建为一级节点,否则创建为suite的一个子节点。if( null == suiteTest){resultNode = extent.createTest(r.getTestContext().getName());}else{resultNode = suiteTest.createNode(r.getTestContext().getName());}}else{resultNode = suiteTest;}if(resultNode != null){resultNode.getModel().setName(suite.getName()+" : "+r.getTestContext().getName());if(resultNode.getModel().hasCategory()){resultNode.assignCategory(r.getTestContext().getName());}else{resultNode.assignCategory(suite.getName(),r.getTestContext().getName());}resultNode.getModel().setStartTime(r.getTestContext().getStartDate());resultNode.getModel().setEndTime(r.getTestContext().getEndDate());//统计SuiteResult下的数据int passSize = r.getTestContext().getPassedTests().size();int failSize = r.getTestContext().getFailedTests().size();int skipSize = r.getTestContext().getSkippedTests().size();suitePassSize += passSize;suiteFailSize += failSize;suiteSkipSize += skipSize;if(failSize>0){resultNode.getModel().setStatus(Status.FAIL);}resultNode.getModel().setDescription(String.format("Pass: %s ; Fail: %s ; Skip: %s ;",passSize,failSize,skipSize));}buildTestNodes(resultNode,context.getFailedTests(), Status.FAIL);buildTestNodes(resultNode,context.getSkippedTests(), Status.SKIP);buildTestNodes(resultNode,context.getPassedTests(), Status.PASS);}if(suiteTest!= null){suiteTest.getModel().setDescription(String.format("Pass: %s ; Fail: %s ; Skip: %s ;",suitePassSize,suiteFailSize,suiteSkipSize));if(suiteFailSize>0){suiteTest.getModel().setStatus(Status.FAIL);}}}
//        for (String s : Reporter.getOutput()) {//            extent.setTestRunnerOutput(s);
//        }extent.flush();}private void init() {//文件夹不存在的话进行创建File reportDir= new File(OUTPUT_FOLDER);if(!reportDir.exists()&& !reportDir .isDirectory()){reportDir.mkdir();}ExtentHtmlReporter htmlReporter = new ExtentHtmlReporter(OUTPUT_FOLDER + FILE_NAME);// 设置静态文件的DNS//重点:怎么样解决cdn.rawgit.com访问不了的情况htmlReporter.config().setResourceCDN(ResourceCDN.EXTENTREPORTS);htmlReporter.config().setDocumentTitle("api自动化测试报告");htmlReporter.config().setReportName("api自动化测试报告");htmlReporter.config().setChartVisibilityOnOpen(true);htmlReporter.config().setTestViewChartLocation(ChartLocation.TOP);htmlReporter.config().setTheme(Theme.STANDARD);htmlReporter.config().setCSS(".node.level-1  ul{ display:none;} .node.level-1.active ul{display:block;}");extent = new ExtentReports();extent.attachReporter(htmlReporter);extent.setReportUsesManualConfiguration(true);}private void buildTestNodes(ExtentTest extenttest, IResultMap tests, Status status) {//存在父节点时,获取父节点的标签String[] categories=new String[0];if(extenttest != null ){List<TestAttribute> categoryList = extenttest.getModel().getCategoryContext().getAll();categories = new String[categoryList.size()];for(int index=0;index<categoryList.size();index++){categories[index] = categoryList.get(index).getName();}}ExtentTest test;if (tests.size() > 0) {//调整用例排序,按时间排序Set<ITestResult> treeSet = new TreeSet<ITestResult>(new Comparator<ITestResult>() {@Overridepublic int compare(ITestResult o1, ITestResult o2) {return o1.getStartMillis()<o2.getStartMillis()?-1:1;}});treeSet.addAll(tests.getAllResults());for (ITestResult result : treeSet) {Object[] parameters = result.getParameters();String name="";//如果有参数,则使用参数的toString组合代替报告中的namefor(Object param:parameters){name+=param.toString();}if(name.length()>0){if(name.length()>50){name= name.substring(0,49)+"...";}}else{name = result.getMethod().getMethodName();}if(extenttest==null){test = extent.createTest(name);}else{//作为子节点进行创建时,设置同父节点的标签一致,便于报告检索。test = extenttest.createNode(name).assignCategory(categories);}//test.getModel().setDescription(description.toString());//test = extent.createTest(result.getMethod().getMethodName());for (String group : result.getMethod().getGroups())test.assignCategory(group);List<String> outputList = Reporter.getOutput(result);for(String output:outputList){//将用例的log输出报告中test.debug(output);}if (result.getThrowable() != null) {test.log(status, result.getThrowable());}else {test.log(status, "Test " + status.toString().toLowerCase() + "ed");}test.getModel().setStartTime(getTime(result.getStartMillis()));test.getModel().setEndTime(getTime(result.getEndMillis()));}}}private Date getTime(long millis) {Calendar calendar = Calendar.getInstance();calendar.setTimeInMillis(millis);return calendar.getTime();}
}

修改testng.xml中的监听器为

    <listeners>
<!--        <listener class-name="com.vimalselvam.testng.listener.ExtentTestNgFormatter"/>--><listener class-name="com.tester.extend.demo.ExtentTestNGIReporterListener"></listener></listeners>

再次运行testng.xml,生成报告后,test-output/index.html,得到正常css样式的报告。

网上看到些比较详细的文章,分享给大家
测试报告ExtentReport改进
ExtentReports 测试报告框架简单总结介绍
ExtentReports 官方说明文档翻译

ExtentReport生成漂亮的测试报告相关推荐

  1. 【newman】postman生成漂亮的测试报告

    文章目录 一.Postman生成html报告: 1.node.js安装: 2.下载安装完成并配置环境变量: 3.安装cnpm:(淘宝镜像下载速度更快) 4.添加到path系统环境变量中:(查看) 5. ...

  2. html兴趣测试生成图表源码,用 Pytest+Allure 生成漂亮的 HTML 图形化测试报告

    原标题:用 Pytest+Allure 生成漂亮的 HTML 图形化测试报告 对于软件测试来说,测试报告是非常重要的工作产出.一个漂亮.清晰.格式规范的测试报告,能够减少开发人员和测试人员的沟通成本. ...

  3. 图形化编写html,怎么使用Pytest+Allure生成漂亮的HTML图形化测试报告

    怎么使用Pytest+Allure生成漂亮的HTML图形化测试报告 发布时间:2021-05-22 14:13:52 来源:亿速云 阅读:95 作者:小新 这篇文章给大家分享的是有关怎么使用Pytes ...

  4. python怎么输出图像测试_【Python】使用Pytest集成Allure生成漂亮的图形测试报告

    前言 大概两个月前写过一篇<[测试设计]使用jenkins 插件Allure生成漂亮的自动化测试报告>的博客,但是其实Allure首先是一个可以独立运行的测试报告生成框架,然后才有了Jen ...

  5. JMeter:No-GUI运行及生成漂亮的HTML报告

    JMeter:No-GUI运行及生成漂亮的HTML报告 我们做性能测试的时候需要借助一些性能测试工具,由于Loadrunner体积太大且需要授权,虽然功能完善,但我个人比较喜欢Jmeter这个工具,一 ...

  6. Jmeter 生成HTML性能测试报告

    文章目录 一.生成HTML测试报告的两种方式 1.1. 利用已有.jtl文件生成报告 1.2. 无.jtl文件生成测试报告 二.图表信息详解 2.1. Dashboard(概览仪表盘) 2.2. Ch ...

  7. junit return null该怎么测试_3 分钟生成一个单元测试报告,这个样式爱了

    昨天有个小伙伴问我,有没有什么现成的测试报告模板,由于昨天实在比较忙就没顾上,所以今个有时间赶紧补上.一般力所能及的事,只要我有时间都会为大家解决,但毕竟能力有限做不到的地方小伙伴们也多理解. 在这里 ...

  8. python节日快乐_【python】一键生成漂亮的节日快乐词云图

    一键生成漂亮的节日快乐词云图,给女神一个特别的礼物~ # Python 实用宝典 # 2020/03/23 先看效果图: 代码传送门: import numpy import multidict im ...

  9. 使用echarts生成漂亮的3D地图

    使用echarts生成漂亮的3D地图 echarts是非常好用的图表插件,本文使用echarts来生成一个漂亮的3D地图 效果 准备资料 第三方插件 <script type="tex ...

最新文章

  1. swift3.0UIAlertController使用方法
  2. 简单粗暴理解与实现机器学习之逻辑回归:逻辑回归介绍、应用场景、原理、损失以及优化...
  3. classpath详解
  4. 活动社交产品怎么设计排序算法?
  5. MySQL 5.1同步到5.5卡库问题一则
  6. LeetCode Algorithm 589. N 叉树的前序遍历
  7. x722网卡linux,Centos6.5 Intel X722 编译安装网卡驱动
  8. oracle跳出while循环,【shell编程】for循环、while循环、break跳出循环、continue结束本次循环和exit退出整个脚本...
  9. 计算机网络入门知乎,网络工程师论文发表范文简述计算机网络基础教学
  10. linux 批量ping ip脚本,Linux下批量ping某个网段ip的脚本
  11. 大家口中所说的A站、B站、C站、D站、E站、F站、G站、H站、I站、J站、K站、L站、M站、N站、O站、P站、Q站、R站、S站、T站、U站、V站、W站、X站、Y站、Z站都是什么网站?
  12. HTML基本语法总结
  13. 【自考】数据结构导论
  14. 思科模拟器的远程连接交换机的实现
  15. 从内容打到社交,头腾大战矛头又指向了游戏
  16. Linux高性能并发服务器发开学习(二进程和线程)
  17. 免费的 XShell 替代品,我推荐这5款软件,一个比一个香!
  18. 计算机网络:从入门到放弃
  19. traditional 和conventional区别
  20. 原生app登录 后台方案(token方案)

热门文章

  1. MATLAB simiulink永磁直驱风力发电系统
  2. Gem.source_index is deprecated
  3. 腾讯云公布5G产品矩阵,年底前交付300个边缘计算中心
  4. 神策数据发布融媒行业版,驱动媒体深度融合转型
  5. 飞桨升级 创新引领!发布飞桨最新技术成果及产业实践,共话AI创新引领新征途...
  6. My A710, wait me
  7. npm WARN deprecated core-js@2.6.12: core-js@<3.23.3 is no longer maintained and not recommended for
  8. 千万不要点进来,否则你会后悔的
  9. 秒杀系统设计(分布式微服务)
  10. 某打折app api_sign分析