zoukankan      html  css  js  c++  java
  • Ant+Jmeter自动化接口测试的部署 及 部署过程中的坑

    一、环境准备:

       配置环境变量-系统变量
     
    JAVA_HOME  C:Program Files (x86)Javajdk1.8.0_111
    Path       %JAVA_HOME%in;%JAVA_HOME%jrein;
    CLASSPATH  .;%JAVA_HOME%lib;%JAVA_HOME%lib ools.jar(注意最前面有一点)
     
      命令行输入:java -version,出现如下提示说明安装成功
     
            解压缩并配置好环境变量-系统变量
     
                 ANT_HOME    D:/ apache-ant-1.9.0
                 path             D:/ apache-ant-1.9.0/bin
                 classpath      D:/apache-ant-1.9.0/lib
            
          命令行输入:ant -v,出现如下提示说明安装成功
     

      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  

      

    二、准备Jmeter脚本:
       1、脚本目录:D:apache-jmeter-3.0in
     
    三、修改D:apache-jmeter-3.0extras 目录下的 build.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
    eport"/>
        <!-- jmeter生成html格式的结果报告的路径-->
        <property name="jmeter.result.html.dir" value="D:apache-jmeter-3.0
    eport"/>
        <!-- 生成的报告的前缀-->
        <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.0in" 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、cmd进入extras 目录:D:apache-jmeter-3.0extras
         输入ant
     
    执行结果:
     
      2、测试报告目录:D:apache-jmeter-3.0 eport ,查看其中的html报告
     
     五、解决生成的报告中的问题
           1、Date report这里的时间没有正确显示出来
           2、Summary里的字段Min Time和Max Time显示的是NaN,没有显示正确的时间。
    修改build.xml中的如下代码:
     
     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
    eport"/>
    10     <!-- jmeter生成html格式的结果报告的路径-->
    11     <property name="jmeter.result.html.dir" value="D:apache-jmeter-3.0
    eport"/>
    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.0in" 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.0extras 目录下,并修改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

  • 相关阅读:
    MySQL性能优化的最佳经验
    18个网站SEO建议
    sql之left join、right join、inner join的区别
    PHP与MYSQL事务处理
    Firefox上Web开发工具库一览
    SphinxSE的安装
    python XML
    python yaml
    C语言文本处理
    Linux strace命令
  • 原文地址:https://www.cnblogs.com/shenfangfang/p/6401484.html
Copyright © 2011-2022 走看看