Ant+Jmeter自动化接口测试的部署 及 部署过程中的坑
一、环境准备:
3、Jmeter下载:http://jmeter.apache.org/download_jmeter.cgi
4、将 jmeter的extras目录中ant-jmeter-1.1.1.jar包拷贝至ant安装目录下的lib目录中
5、修改Jmeter的bin目录下jmeter.properties文件的配置:jmeter.save.saveservice.output_format=xml
<?xml version="1.0" encoding="UTF-8"?> <project name="ant-jmeter-test" default="all" basedir="."> <tstamp> <format property="time" pattern="yyyyMMddhhmm" /> </tstamp> <!-- 需要改成自己本地的 Jmeter 目录--> <property name="jmeter.home" value="D:\apache-jmeter-3.0"/> <!-- jmeter生成jtl格式的结果报告的路径--> <property name="jmeter.result.jtl.dir" value="D:\apache-jmeter-3.0\report"/> <!-- jmeter生成html格式的结果报告的路径--> <property name="jmeter.result.html.dir" value="D:\apache-jmeter-3.0\report"/> <!-- 生成的报告的前缀--> <property name="ReportName" value="TestReport" /> <property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}${time}.jtl" /> <property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${ReportName}${time}.html" /> <target name="all"> <antcall target="test" /> <antcall target="report" /> </target> <target name="test"> <taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" /> <jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}"> <!-- 声明要运行的脚本。"*.jmx"指包含此目录下的所有jmeter脚本--> <testplans dir="D:\apache-jmeter-3.0\bin" includes="APP服务接口.jmx" /> <!-- 增加如下一行代码,否则会报错误,经测试使用jmeter3.0版本不增加下面一行代码不会报告错误--> <!--<property name="jmeter.save.saveservice.output_format" value="xml"/>--> </jmeter> </target> <!-- html报告中时间显示为NAN,原因是ant中缺失了两个lib库 xalan-2.7.2.jar和serializer-2.7.2.jar ,将这两个库拷贝到ant的lib目录下,或者在这里增加如下代码均可解决--> <path id="xslt.classpath"> <fileset dir="${jmeter.home}/lib" includes="xalan*.jar"/> <fileset dir="${jmeter.home}/lib" includes="serializer*.jar"/> </path> <!-- html报告中Date report这里的时间没有正确显示出来,原因是未设定report.datestamp 属性值--> <target name="report"> <tstamp> <format property="report.datestamp" pattern="yyyy/MM/dd HH:mm" /></tstamp> <xslt classpathref="xslt.classpath" force="true" in="${jmeter.result.jtlName}" out="${jmeter.result.htmlName}" style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl"> <param name="dateReport" expression="${report.datestamp}"/> </xslt> <!-- 因为上面生成报告的时候,不会将相关的图片也一起拷贝至目标目录,所以,需要手动拷贝 --> <copy todir="${jmeter.result.html.dir}"> <fileset dir="${jmeter.home}/extras"> <include name="collapse.png" /> <include name="expand.png" /> </fileset> </copy> </target> </project>
四、运行脚本:
1 <?xml version="1.0" encoding="UTF-8"?> 2 <project name="ant-jmeter-test" default="all" basedir="."> 3 <tstamp> 4 <format property="time" pattern="yyyyMMddhhmm" /> 5 </tstamp> 6 <!-- 需要改成自己本地的 Jmeter 目录--> 7 <property name="jmeter.home" value="D:\apache-jmeter-3.0"/> 8 <!-- jmeter生成jtl格式的结果报告的路径--> 9 <property name="jmeter.result.jtl.dir" value="D:\apache-jmeter-3.0\report"/> 10 <!-- jmeter生成html格式的结果报告的路径--> 11 <property name="jmeter.result.html.dir" value="D:\apache-jmeter-3.0\report"/> 12 <!-- 生成的报告的前缀--> 13 <property name="ReportName" value="TestReport" /> 14 <property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}${time}.jtl" /> 15 <property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${ReportName}${time}.html" /> 16 <target name="all"> 17 <antcall target="test" /> 18 <antcall target="report" /> 19 </target> 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="D:\apache-jmeter-3.0\bin" includes="APP服务接口.jmx" /> 25 <!-- 增加如下一行代码,否则会报错误,经测试使用jmeter3.0版本不增加下面一行代码不会报告错误--> 26 <!--<property name="jmeter.save.saveservice.output_format" value="xml"/>--> 27 </jmeter> 28 </target> 29 <!-- html报告中时间显示为NAN,原因是ant中缺失了两个lib库 xalan-2.7.2.jar和serializer-2.7.2.jar ,将这两个库拷贝到ant的lib目录下,或者在这里增加如下代码均可解决--> 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 <!-- html报告中Date report这里的时间没有正确显示出来,原因是未设定report.datestamp 属性值--> 36 <target name="report"> 37 <tstamp> <format property="report.datestamp" pattern="yyyy/MM/dd HH:mm" /></tstamp> 38 <xslt 39 classpathref="xslt.classpath" 40 force="true" 41 in="${jmeter.result.jtlName}" 42 out="${jmeter.result.htmlName}" 43 style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl"> 44 <param name="dateReport" expression="${report.datestamp}"/> 45 </xslt> 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 </project>
2、Summary里的字段Min Time和Max Time显示的是NaN,没有显示正确的时间的第二种解决方法。
解决方法: 从Jmeter的lib包里把xalan-2.7.2.jar和serializer-2.7.2.jar copy到Ant的lib包里;
六、测试过程中遇到的其他问题
1、使用Jmeter3.0版本,产生的html测试报告中是没有数据的,原因是3.0中的 jmeter-results-detail-report.xsl 有一些错误,从github中下载2.X版本中的 jmeter-results-detail-report_21.xsl放置在D:\apache-jmeter-3.0\extras 目录下,并修改build-xml:
<xslt in="${jmeter.result.jtlName}" out="${jmeter.result.htmlName}" style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl" />
2、报错如下:
taskdef class org.programmerplanet.ant.taskdefs.jmeter.JMeterTask cannot be found
using the classloader AntClassLoader[]
原因:Ant 的ant-jmeter-1.1.1.jar这个文件缺失
解决方法:将 jmeter的extras目录中ant-jmeter-1.1.1.jar包拷贝至ant安装目录下的lib目录中
参考地址:
http://www.cnblogs.com/puresoul/p/4808416.html
http://www.cnblogs.com/puresoul/p/5053035.html
http://www.jianshu.com/p/b606b27b7155