背景
最近在看Jmeter和接口测试,发现了几个问题,基于HTTP协议的接口测试实施起来很简单,但是怎么实施接口测试就是一个难点,而且接口测试如果不做成自动化,就纯粹靠手工执行,那么意义其实并不大。所以稍微看了一下Ant+Jmeter的组合,来实现自动化。
Ant驱动Jmeter
单独使用Jmeter来执行接口测试是非常简单的了,使用Ant来驱动Jmeter就需要些一个构建文件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="/Users/SvenWeng/apache-jmeter-3.0" /> <!-- jmeter生成jtl格式的结果报告的路径--> <property name="jmeter.result.jtl.dir" value="/Users/SvenWeng/Desktop" /> <!-- jmeter生成html格式的结果报告的路径--> <property name="jmeter.result.html.dir" value="/Users/SvenWeng/Desktop" /> <!-- 生成的报告的前缀--> <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="/Users/SvenWeng/Desktop" includes="获取用户ID.jmx" /> </jmeter> </target> <target name="report"> <xslt 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> |
只要Ant配置好,直接运行Ant就行了。结果如下:
SvenWeng@wengyanbin:~/Desktop|? ant Buildfile: /Users/SvenWeng/Desktop/build.xml all: test: [jmeter] Executing test plan: /Users/SvenWeng/Desktop/获取用户ID.jmx ==> /Users/SvenWeng/Desktop/TestReport201608220301.jtl [jmeter] Writing log file to: /Users/SvenWeng/apache-jmeter-3.0/bin/jmeter.log [jmeter] Creating summariser <summary> [jmeter] Created the tree successfully using /Users/SvenWeng/Desktop/获取用户ID.jmx [jmeter] Starting the test @ Mon Aug 22 15:01:29 CST 2016 (1471849289646) [jmeter] Waiting for possible Shutdown/StopTestNow/Heapdump message on port 4445 [jmeter] summary + 1 in 00:00:01 = 2.0/s Avg: 267 Min: 267 Max: 267 Err: 0 (0.00%) Active: 37 Started: 38 Finished: 1 [jmeter] summary + 3451 in 00:00:30 = 115.9/s Avg: 841 Min: 130 Max: 3745 Err: 0 (0.00%) Active: 100 Started: 101 Finished: 1 [jmeter] summary = 3452 in 00:00:30 = 114.0/s Avg: 841 Min: 130 Max: 3745 Err: 0 (0.00%) [jmeter] summary + 1548 in 00:00:14 = 107.7/s Avg: 792 Min: 32 Max: 5003 Err: 0 (0.00%) Active: 0 Started: 101 Finished: 101 [jmeter] summary = 5000 in 00:00:45 = 111.9/s Avg: 826 Min: 32 Max: 5003 Err: 0 (0.00%) [jmeter] Tidying up ... @ Mon Aug 22 15:02:14 CST 2016 (1471849334383) [jmeter] ... end of run report: [xslt] Processing /Users/SvenWeng/Desktop/TestReport201608220301.jtl to /Users/SvenWeng/Desktop/TestReport201608220301.html [xslt] Loading stylesheet /Users/SvenWeng/apache-jmeter-3.0/extras/jmeter-results-detail-report_21.xsl [copy] Copying 2 files to /Users/SvenWeng/Desktop BUILD SUCCESSFUL Total time: 47 seconds |
几个大坑
taskdef class org.programmerplanet.ant.taskdefs.jmeter.JMeterTask cannot be found
using the classloader AntClassLoader[]
这个报错非常坑爹,是由于Ant有一个ant-jmeter-1.1.1.jar这个文件缺失了,所以一直会报这个错。
stylesheet /Users/SvenWeng/apache-jmeter-3.0/extras/jmeter-results-detail-report_21.xsl doesn't exist.
这个报错是由于我使用的是Jmeter3.0。而3.0文件下面的对应文件是jmeter-results-detail-report.xsl 所以报了这个错,但是这个文件是有问题的,这个问题下面再说。
测试报告中没有数据
这个问题就是由于上面文件的不正确导致的。两个文件的不同点如下:
自己把这块改了,或者直接使用Jmeter2.*的文件也行。
测试报告中三个指标为NaN
这个问题也是一个坑,我找了好久才找到原因。
需要从Jmeter的lib包里把xalan-2.7.2.jar和serializer-2.7.2.jar copy到Ant的lib包里。
下一步
下一步当然是扔到jenkins里面啦,监控代码变动,然后自动执行接口测试。当然,也可以写一个Python的脚本定时执行或监控代码库执行都可以。