接口測試之Jmeter接口測試自動化

  Jmeter是壓力測試、接口測試工具,Ant是基於Java的構建工具,具有跨平臺的作用,jenkins是持續集成工具。將這三者結合起來可以搭建一套webservice接口測試的持續構建環境。

 

1、安裝JDK,配置java環境變量(這裏用的是 jdk1.8)

2、安裝Jmeter,(這裏用到的版本是 jmeter4.0)

 

3、安裝 ANT    (這是使用的是 apache-ant-1.10.3)

    3.1 下載安裝

      下載地址 http://ant.apache.org/bindownload.cgi,下載後解壓到指定位置即可,

      比如:D:/program files/apache-ant-1.10.3

    3.2 配置環境變量(window中)

        ANT_HOME D:/apache-ant-1.10.3

       path D:/apache-ant-1.10.3

       classpath D:/apache-ant-1.10.3

    3.3 安裝驗證

      驗證安裝結果,命令行輸入ant -v ,出現版本信息則安裝成功

      

 

 

4.創建腳本:(可以使用jmeter錄製一個腳本,需要jmx腳本文件)

4.1 啓動jmeter:通過jmeter安裝目錄,進入到bin目錄,通過jmeter.bat(win端)啓動jmeter

4.2創建一個線程組:設置10個線程,2秒時間執行完成,執行10次

4.3設置一個http請求:

4.4設置請求頭信息:Content-Type:application/json

4.5保存腳本到jmeter目錄:Ctrl+s  (我在jmeter目錄下創建了一個文件名稱爲壓力測試的文件夾,用來保存腳本)

 

 

 

5、ANT中配置Jmeter   

 5.1 將jmeter extras目錄下的ant-jmeter-1.1.1.jar 文件拷貝到ant安裝目錄下的lib文件夾中

      

 

 

 

 

 

5.2  配置ANT與Jmeter的配置文件

 

  5.2.1 配置ant 編譯文件 build.xml

    在保存腳本的目錄下,拷貝下面的內容到新建的.txt文件中,並將此文件改名爲:build.xml    

<?xml version="1.0" encoding="UTF-8"?>


<project name="ant-jmeter-test" default="run" basedir=".">
    <tstamp>
        <format property="time" pattern="yyyyMMddhhmm" />
    </tstamp>
    <!-- 需要改成自己本地的 Jmeter 目錄-->  
    <property name="jmeter.home" value="D:\jmeter\apache-jmeter-4.0\apache-jmeter-4.0" />
    <!-- jmeter生成jtl格式的結果報告的路徑--> 
    <property name="jmeter.result.jtl.dir" value="D:\jmeter\apache-jmeter-4.0\apache-jmeter-4.0\ResultReport\jtl" />
    <!-- jmeter生成html格式的結果報告的路徑-->
    <property name="jmeter.result.html.dir" value="D:\jmeter\apache-jmeter-4.0\apache-jmeter-4.0\ResultReport\html" />
    <!-- 生成的報告的前綴-->  
    <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}.html" />
    
    <target name="run">
        <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:\jmeter\apache-jmeter-4.0\apache-jmeter-4.0\backups" includes="*.jmx" />


             <property name="jmeter.save.saveservice.output_format" value="xml"/>
        </jmeter>
    </target>
    
     <path id="xslt.classpath">
        <fileset dir="${jmeter.home}/lib" includes="xalan*.jar"/>
        <fileset dir="${jmeter.home}/lib" includes="serializer*.jar"/>
     </path>
        
    <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" />  
				
        <!-- 因爲上面生成報告的時候,不會將相關的圖片也一起拷貝至目標目錄,所以,需要手動拷貝 --> 
        <copy todir="${jmeter.result.html.dir}">
            <fileset dir="${jmeter.home}/extras">
                <include name="collapse.png" />
                <include name="expand.png" />
            </fileset>
        </copy>
    </target>    
    
</project>
				
        <!-- 因爲上面生成報告的時候,不會將相關的圖片也一起拷貝至目標目錄,所以,需要手動拷貝 --> 
        <copy todir="${jmeter.result.html.dir}">
            <fileset dir="${jmeter.home}/extras">
                <include name="collapse.png" />
                <include name="expand.png" />
            </fileset>
        </copy>
    </target>    
    
</project>

      

5.2.2按實際情況修改build.xml文件,如下:

    注意:生成報告路徑,ResultReport可以不用創建,如果創建了必須保證文件夾中爲空

 

 

5.2.3 配置jmeter.properties

       配置jmeter報告輸出格式爲xml

                在jmeter安裝目錄bin目錄下jmeter.properties文件中修改jmeter.save.saveservice.output_format=csv 爲

               jmeter.save.saveservice.output_format=xml,並去掉前面的註釋符號#

 

 

 

6 驗證配置,執行構建測試

    6.1進入到腳本保存目錄

6.2 在地址欄輸入cmd進入命令行,輸入ant run ,執行測試

看到build successful 則說明構建測試成功:

6.3 進入保存報告的路徑下查看測試結果報告:

按build.xml文件中設置的測試報告地址找到html版測試報告,在build.xml我們設置的路徑是:ResultReport目錄

打開看看:測試結果展現了用例數、成功率、用例執行時間等結果參數:

 

7  測試報告優化:更換模板

      用jmeter自帶的測試報告得到的測試報告信息並不是很全,這裏參考網上的方法,做一個優化

 

    7.1 下載優化模板 jmeter.results.shanhe.me.xsl,拷貝到jmeter的extras目錄中,

           如C:\apache-jmeter-2.12\extras

    百度雲下載地址:https://pan.baidu.com/s/1TPZFEJdtgAohDLZFg4TsiQ 密碼:zwp3

     CSDN 下載:https://download.csdn.net/download/qq_37138756/10493615

    

    

   7.2 設置測試輸出報告要輸出的內容

          同樣在jmeter.properties中,設置需要輸出的內容爲true,並去掉前面的註釋符號#,這裏全部設置成true

    

    

    7.3  設置build文件的報告模板爲優化後的模板:jmeter.results.shanhe.me.xsl

 

7.4    按步驟6的方式再次用ant構建測試,查看優化後的測試報告

(注意: ResultReport 文件是生成報告文件夾。每次啓動命令之前,爲了避免模板信息,數據信息錯誤,文件夾內容必須清空)

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章