技術小白又來寫流水賬了~轉載請注明出處~
一、搭建測試環境:
環境搭建
工具:jmeter2.13、mysql-connector-java-5.1.18-bin.jar、Jenkins、ant
流程:
(1)解壓jemeter2.13.zip,
配置jmeter環境變量:
新建JMETER_HOME,變量值中輸入:F:\apache-jmeter-2.13(jmeter所在文件夾)
修改CLASSPATH變量,變量值中添加如下值:
%JMETER_HOME%\lib\ext\ApacheJMeter_core.jar;%JMETER_HOME%\lib\jorphan.jar;%JMETER_HOME%\lib\logkit-2.0.jar
打開jmeter bin目錄下的jmeter.bat顯示如下則配置成功。
(2)配置ant
(3) 測試jmeter是否可用
可以先找到一個jmx文件測試下jmeter是否可用,在文件中打開jmx文件:
找到線程組,拉至最下點擊查看結果樹:
在此處找到一個jtl文件(事先在某目錄下新一個jtl),之后后點擊 開始測試。
生成的結果就會在此jtl中。
3、修改配置
(1)jmeter.properties
如果我們想生成的文件中包含某些信息,則需要修改配置文件。
在命令行jmeter的bin目錄打開jmeter.properties。想顯示的信息去掉#並改成true。(命令行生成的jtl文件想包含某些信息,必須在jmeter.properties文件中修改,頁面上的修改對命令行沒有作用)
(2)因為將jtl轉換成html是引用了jmeter自帶的樣式,可根據測試的需求更改樣式。
三、測試結果生成html
在某目錄中新建build.xml文件(jmeter的extras目錄下有build.xml,可對此文件進行修改。
)
本例中將build文件放置在:D:\jenkins\workspace\API-Test
<?xml version="1.0" encoding="UTF-8"?>
<project name="ant-jmeter-test" default="run" basedir=".">
<!-- 需要改成自己本地的jmeter目錄-->
<property name="jmeter.home" value="F:\apache-jmeter-2.13" />
<!-- jmeter生成的jtl格式的結果報告的路徑-->
<property name="jmeter.result.jtl.dir" value="D:\jenkins\workspace\report\jtl" />
<!-- jmeter生成的html格式的結果報告的路徑-->
<property name="jmeter.result.html.dir" value="D:\jenkins\workspace\report\html" />
<!-- ʺ生成的報告的前綴-->
<property name="ReportName" value="TestReport" />
<property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}.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:\jenkins\workspace\" 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">
<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>
四、Jenkins集成jmeter
設置某服務器為slave節點,在服務器上跑測試用例。
獲取測試腳本
在服務器上執行batch語句;
:刪除上次生成的jtl文件
del /q/a/f D:\jenkins\workspace\report\jtl
:刪除上次生成的html文件
del /q/a/f D:\jenkins\workspace\report\html
:執行build.xml文件
cd D:\jenkins\workspace
ant
找到HTML文件顯示在Jenkins上
五、附加
tips:
(1)在測試機器上運行jmx 腳本,查看是否正常,如果在運行時報如下錯誤:
No suitable driver found for
jdbc:mysql://rdsw46k48c465jzyyih9.mysql.rds.aliyuncs.com:3306/APIManager?characterEncoding=utf8&autoReconnect=true
使用如下方法
下載MySQL的官方JDBC連接器mysql-connector-java-5.1.18-bin.jar
1、將mysql-connector-java-5.1.18-bin.jar放入下面目錄中
E:\apache-jmeter-2.11\lib
C:\Program Files (x86)\Java\jdk1.6.0_21\jre\lib\ext\mysql-connector-java-5.0.8-bin.jar
C:\Program Files (x86)\Java\jdk1.6.0_21\jre\lib\mysql-connector-java-5.0.8-bin.jar
2、將路徑加入到環境變量CLASSPATH中
E:\apache-jmeter-2.11\lib\mysql-connector-java-5.0.8-bin.jar ;C:\Program Files (x86)\Java\jdk1.6.0_21\jre\lib\mysql-connector-java-5.0.8-bin.jar ;