具体问题如下:

  1、Date report这里的时间没有正确显示出来

  2、Summary里的字段Min Time和Max Time显示的是NaN,没有显示正确的时间。

本文主要解决上述两个问题,具体报告如何生成可参考上面提到的两篇文章。

二、Jmeter+Ant报告生成原理:

  在解决问题之前,让我们先弄清楚Jmeter+Ant是生成报告的原理,知道原理后我们就可以很从容的解决问题了。另外,如果后续我们想定制报告也就很容易了。

  1、在Jmeter的extras目录下,官方已经为我们提供了一个现成的实例,我们只需要在该目录下执行ant命令就可以生成一个数据文件Test.jtl和一个报告Test.html(PS:如果没有安装ant需要先去安装,不会用ant的自行百度)。

  2、知道了上一步后,接下来我们研究的重点就是extras目录下的build.xml文件了,具体研究细节就不在此细说了,因为这就部分内容属于ant的范围,有需要的可以自行补充下ant的知识。

三、解决问题:

1、找到extras目录下build.xml文件内容的如下部分:它的作用就是把生成的.jtl数据文件转换为.html格式的报告

具体属性的含义:

  • in:生成的.jtl文件的路径
  • out:生成的.html文件的路径
  • style:从.jtl转换成.html所使用的样式,这些文件也在extras目录下,这个是最重要的部分,如果我们想定制报告可以自行定义这个文件或者从网上找一些合适的文件。
  • param:参数,这几个参数可以在style中使用,下面会讲到。
  • path:添加jar包的路径,在下面的target中有引用到(下面第9行)。
  1. 1 <path id="xslt.classpath">//jar的路径
  2. 2 <fileset dir="${lib.dir}" includes="xalan*.jar"/>
  3. 3 <fileset dir="${lib.dir}" includes="serializer*.jar"/>
  4. 4 </path>
  5. 5    //把生成的.jtl数据文件转换成.html格式的报告
  6. 6 <target name="xslt-report" depends="_message_xalan">
  7. 7 <tstamp><format property="report.datestamp" pattern="yyyy/MM/dd HH:mm"/></tstamp>
  8. 8 <xslt
  9. 9 classpathref="xslt.classpath"
  10. 10 force="true"
  11. 11 in="${testpath}/${test}.jtl"
  12. 12 out="${testpath}/${test}.html"
  13. 13 style="${basedir}/jmeter-results-detail-report${style_version}.xsl">
  14. 14 <param name="showData" expression="${show-data}"/>
  15. 15 <param name="titleReport" expression="${report.title}"/>
  16. 16 <param name="dateReport" expression="${report.datestamp}"/>
  17. 17 </xslt>
  18. 18 </target>

2、通过上面的分析,style 文件是整成报告转换的关键,那我们就打开jmeter-results-detail-report_21.xsl这个文件看看,找到如下几行,这里也定义了三个参数跟build.xml文件中一样,由此可猜测,我们只要在build.xml文件中定义dateReport这个参数和值,在style中就可以按如下方式使用,经过测试证明猜测是正确的,那么第一个问题就解决了:

  1. 1 <xsl:param name="showData" select="'n'"/>
  2. 2 <xsl:param name="titleReport" select="'Load Test Results'"/>
  3. 3 <xsl:param name="dateReport" select="'date not defined'"/>

3、对于第二个问题,其实把第1步中的代码复制到我们自己的build.xml文件中后,可以一并解决这两个问题。解决第二个总是的关键代码是第9行和第10行:

  classpathref="xslt.classpath"

  force="true"

而第9行又引用了第1~4行

4、到此,两个问题都解决了,最终修改后的build.xml文件如下,标黄是解决总是添加的代码:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project name="ant-jmeter-test" default="run" basedir=".">
  3. <!-- 需要改成自己本地的 Jmeter 目录-->
  4. <property name="jmeter.home" value="/Users/Tools/Jmeter" />
  5. <property name="report.title" value="接口测试"/>
  6. <!-- jmeter生成jtl格式的结果报告的路径-->
  7. <property name="jmeter.result.jtl.dir" value="/Users/Desktop/jmx/report" />
  8. <!-- jmeter生成html格式的结果报告的路径-->
  9. <property name="jmeter.result.html.dir" value="/Users/Desktop/jmx/report" />
  10. <!-- 生成的报告的前缀-->
  11. <property name="ReportName" value="TestReport" />
  12. <property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}.jtl" />
  13. <property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${ReportName}.html" />
  14.  
  15. <target name="run">
  16. <antcall target="test" />
  17. <antcall target="report" />
  18. </target>
  19.  
  20. <target name="test">
  21. <taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" />
  22. <jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}">
  23. <!-- 声明要运行的脚本"*.jmx"指包含此目录下的所有jmeter脚本-->
  24. <testplans dir="/Users/Desktop/jmx" includes="*.jmx" />
  25.  
  26. <property name="jmeter.save.saveservice.output_format" value="xml"/>
  27. </jmeter>
  28. </target>
  29.  
  30. <path id="xslt.classpath">
  31. <fileset dir="${jmeter.home}/lib" includes="xalan*.jar"/>
  32. <fileset dir="${jmeter.home}/lib" includes="serializer*.jar"/>
  33. </path>
  34.  
  35. <target name="report">
  36. <tstamp> <format property="report.datestamp" pattern="yyyy/MM/dd HH:mm" /></tstamp>
  37. <xslt
  38. classpathref="xslt.classpath"
  39. force="true"
  40. in="${jmeter.result.jtlName}"
  41. out="${jmeter.result.htmlName}"
  42. style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl">
  43. <param name="dateReport" expression="${report.datestamp}"/>
  44. </xslt>
  45.  
  46. <!-- 因为上面生成报告的时候,不会将相关的图片也一起拷贝至目标目录,所以,需要手动拷贝 -->
  47. <copy todir="${jmeter.result.html.dir}">
  48. <fileset dir="${jmeter.home}/extras">
  49. <include name="collapse.png" />
  50. <include name="expand.png" />
  51. </fileset>
  52. </copy>
  53. </target>
  54.  
  55. </project>

5、修改后的报告:

 

【jmeter】测试报告优化<一>的更多相关文章

  1. 【jmeter】测试报告优化<二>

    如果按JMeter默认设置,生成报告如下: 从上图可以看出,结果信息比较简单,对于运行成功的case,还可以将就用着.但对于跑失败的case,就只有一行assert错误信息.(信息量太少了,比较难找到 ...

  2. jmeter测试报告优化

    1.下载jmeter.results.shanhe.me.xsl 将该文件拷贝到jmeter\extras目录下 2.修改jmeter.results.shanhe.me.xsl 这里直接拷贝 jme ...

  3. EMW 性能优化二之---并发配置

    EMW 性能优化二之---并发配置 在前一个日志中写到交货的异步更新,对于RFUI RF的前台操作会提升效率,异步更新不用等待更新状态的返回,启用更新队列的方式执行(SM13). 下面再补全性能相关的 ...

  4. MySQL优化二(连接优化和缓存优化)

    body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-top: 10 ...

  5. mysql优化二之锁机制

    mysql优化二之锁机制 mysql提供了锁机制和MVCC机制来保证并发操作的安全性,这里主要讨论锁机制, MVCC见下篇文章 mysql的锁按照锁粒度可分为行锁与表锁,按照操作类型划分可读锁和写锁 ...

  6. Jmeter测试报告生成

    Jmeter测试报告生成 本文使用的 Jmeter 版本为 apache-jmeter-3.2 1. 命令行模式将 jtl 文件转成测试图表 注意: 这种方式只适用于jmeter3.0以后的版本 1. ...

  7. Jmeter(七)Jmeter脚本优化(数据与脚本分离)

    午休时间再来记一记,嗯..回顾着使用Jmeter的历程,想着日常都会用到的一些功能.一些组件:敲定了本篇的主题----------是的.脚本优化. 说起脚本优化,为什么要优化?又怎么优化?是个永恒的话 ...

  8. Emacs 启动优化二三事

    Emacs 启动优化二三事 */--> div.org-src-container { font-size: 85%; font-family: monospace; } p {font-siz ...

  9. JMeter 源码二次开发函数示例

    JMeter 源码二次开发函数示例 一.JMeter 5.0 版本 实际测试中,依靠jmeter自带的函数已经无法满足我们需求,这个时候就需要二次开发.本次导入的是jmeter 5.0的源码进行实际的 ...

  10. MySQL性能优化(二):优化数据库的设计

    原文:MySQL性能优化(二):优化数据库的设计 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.n ...

随机推荐

  1. C++ 并发消息队列

    C++ 并发消息队列 在网上找到了一份POSIX线程显示的并发消息队列示例代码: http://codereview.stackexchange.com/questions/41604/thread- ...

  2. LK 光流法简介

    前言 若假定一个局部区域的像素运动是一致的,则可以用这个新的约束条件替代前文中提到的全局速度平滑约束条件.这种光流算法就叫做 LK 光流法. LK 光流法的推导 首先,需要推导出光流约束方程. 这一步 ...

  3. java中replace和replaceAll的区别

    replace和replaceAll是JAVA中常用的替换字符的方法,它们的区别是: 1)replace的参数是char和CharSequence,即可以支持字符的替换,也支持字符串的替换(CharS ...

  4. 229. Majority Element II

    Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. The algorit ...

  5. eclipse template里面的${user}更改

    打开eclipse目录下的eclipse.ini文件,添加上一行 -Duser.name="whateveryouwant" 这样在eclipse中的${user}变量的值就变成了 ...

  6. shell脚本处理大数据系列之(一)方法小结

    转自:http://longriver.me/?p=57 方法1: 单进程处理大规模的文件速度如(上million量级)比较慢,可以采用awk取模的方法,将文件分而治之,这样可以利用充分的利用多核CP ...

  7. HDU-4455 Substrings(DP)

    题目大意:给一个长度为n的整数序列,定义egg(i,j)表示区间[i,j]中不同的数的个数.q次询问,每次询问x,表示求所有长度为x连续区间的 egg 之和. 题目分析:定义dp(len)表示所有长度 ...

  8. 【转】IOS学习笔记29—提示框第三方库之MBProgressHUD

    原文网址:http://blog.csdn.net/ryantang03/article/details/7877120 MBProgressHUD是一个开源项目,实现了很多种样式的提示框,使用上简单 ...

  9. 通过 Javacore 诊断线程挂起等性能问题

    http://www.ibm.com/developerworks/cn/websphere/library/techarticles/1406_tuzy_javacore/1406_tuzy_jav ...

  10. JS页面间传值

    一:JavaScript静态页面值传递之URL篇 能过URL进行传值.把要传递的信息接在URL上. 例子: 参数传出页面Post.htm—>   <input type="tex ...