jmeter用java代码怎样编写接口测试源码
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jmeter用java代码怎样编写接口测试源码相关的知识,希望对你有一定的参考价值。
我们在做性能测试时,有时需要自己编写测试脚本,很多测试工具都支持自定义编写测试脚本,比如LoadRunner就有很多自定义脚本的协议,比如"C Vuser","Java Vuser"等协议.同样,Jmeter也支持自定义编写的测试代码,不过与LoadRunner不同的是,Jmeter没有自带编译器,需要借助第三方编译器才能实现.下面举一个简单的Java自定义测试代码例子,使用Java编译器编写测试代码(Java编译器可以用Eclipse,JBulider等),实现功能为:在测试前输入任意一个字符串,然后判断该字符串的长度是否大于5,如果大于则测试结果成功,否则测试结果位失败,然后在放到Jmeter中模拟10个用户测试,同时运行这段代码,具体实现如下:1.打开Java编译器,新建一个项目"TestLength",然后新建一个包"app".
2.从Jmeter的安装目录lib/ext中拷贝两个文件"ApacheJMeter_core.jar"和"ApacheJMeter_java.jar"到"Tester"的项目中,然后引入这两个JAR文件.(具体的引入方法参考各个Java编译器的使用方法)
3.在"app"包中新建一个类,名字叫"TestLength",不过这个类要继承"AbstractJavaSamplerClient"类,如果项目引入步骤二中的两个文件,就可以找到"AbstractJavaSamplerClient"类了.
4."TestLength"类在继承"AbstractJavaSamplerClient"类的同时也会继承四个方法,分别是"getDefaultParameters","setupTest","runTest"和"teardownTest"方法."getDefaultParameters"方法主要用于设置传入的参数;"setupTest"方法为初始化方法,用于初始化性能测试时的每个线程."runTest"方法为性能测试时的线程运行体;"teardownTest"方法为测试结束方法,用于结束性能测试中的每个线程.
5.具体实现代码如下:
package app;
import org.apache.jmeter.config.Arguments;
import org.apache.jmeter.protocol.java.sampler.AbstractJavaSamplerClient;
import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext;
import org.apache.jmeter.samplers.SampleResult;
import com.passpod.core.t8.*;
/**
* @author乐以忘忧
*
* TODO To change the template for this generated type comment go to
* Window - Preferences - Java - Code Style - Code Templates
*/
public class TestLength extends AbstractJavaSamplerClient
private SampleResult results;
private String testStr;
//初始化方法,实际运行时每个线程仅执行一次,在测试方法运行前执行,类似于LoadRunner中的init方法
public void setupTest(JavaSamplerContext arg0)
results = new SampleResult();
testStr = arg0.getParameter("testString", "");
if (testStr != null && testStr.length() > 0)
results.setSamplerData(testStr);
//设置传入的参数,可以设置多个,已设置的参数会显示到Jmeter的参数列表中
public Arguments getDefaultParameters()
Arguments params = new Arguments();
params.addArgument("testStr", ""); //定义一个参数,显示到Jmeter的参数列表中,第一个参数为参数默认的显示名称,第二个参数为默认值
return params;
//测试执行的循环体,根据线程数和循环次数的不同可执行多次,类似于LoadRunner中的Action方法
public SampleResult runTest(JavaSamplerContext arg0)
int len = 0;
results.sampleStart(); //定义一个事务,表示这是事务的起始点,类似于LoadRunner的lr.start_transaction
len = testStr.length();
results.sampleEnd(); //定义一个事务,表示这是事务的结束点,类似于LoadRunner的lr.end_transaction
if(len < 5)
System.out.println(testStr);
results.setSuccessful(false); //用于设置运行结果的成功或失败,如果是"false"则表示结果失败,否则则表示成功
else
results.setSuccessful(true);
return results;
//结束方法,实际运行时每个线程仅执行一次,在测试方法运行结束后执行,类似于LoadRunner中的end方法
public void teardownTest(JavaSamplerContext arg0)
6.把上面的例子打包,然后把生成的"TestLength.jar"文件拷贝到Jmeter的安装目录lib/ext下.
7.运行Jmeter,添加一个线程组,然后在该线程组下面添加一个Java请求(在Sampler中),在Java请求的类名称中选择咱们刚创建的类"app.TestLength",在下面参数列表的"testStr"后面输入要测试的字符串,然后添加一个监听器(聚合报告),设置一下模拟的用户数就可以测试了.如果测试不成功,Jmeter会在它自己个输出框中抛出这个字符串.
通过上面的例子我们可以发现,使用Jmeter自定义Java测试代码,配合Jmeter自带的函数,就可以实现出LoadRunner中"Java Vuser"协议的绝大多数功能,而且是没有用户数限制和完全免费的(嘿嘿).上面的例子非常简单,而且没有任何实际意义,只是一个简单的Jmeter测试代码示例,用于抛砖引玉,希望大家一起交流,共同 进步. 参考技术A import javax.swing.* ;
import java.awt.* ;
import java.awt.event.* ;
public class ZiMu extends JFrame
ZiMu()
this.setSize(300 , 600) ;
this.setResizable(false) ;
this.setTitle("打字游戏") ;
this.setBackground(Color.BLACK) ;
MyPanel mp = new MyPanel() ;
this.add(mp) ;
this.addKeyListener(mp) ;
Thread t = new Thread (mp) ;
t.start() ;
public static void main(String args[])
ZiMu w = new ZiMu () ;
w.setVisible(true) ;
class MyPanel extends JPanel implements Runnable, KeyListener
int x[] = new int[10] ;
int y[] = new int[10] ;
int sum = 0 ;
String z[] = new String[10] ;
MyPanel()
for(int i=0;i<10;i++)
x[i] = (int)(Math.random()*300) ;
y[i] = (int)(Math.random()*300) ;
z[i] = new String(""+(char)(Math.random()*25+65)) ;
public void paint(Graphics g)
super.paint(g) ;
this.setBackground(Color.black) ;
g.setColor(Color.WHITE) ;
g.drawString("一分钟正确打对的字母: "+sum , 10 , 560) ;
for(int i=0;i<10;i++)
g.drawString(z[i] , x[i] , y[i]) ;
public void run()
long g = System.currentTimeMillis() ;
while(System.currentTimeMillis()-g<=60000)
for(int i=0;i<10;i++)
y[i] ++ ;
if(y[i]>= 600)
sum -= 1 ;
y[i] = (int)(Math.random()*50) ;
x[i] = (int)(Math.random()*280) ;
z[i] = new String(""+(char)(Math.random()*25+65)) ;
try
Thread.sleep(20) ;
catch(Exception e)
this.repaint() ;
public void keyTyped(KeyEvent e)
// TODO: Add your code here
public void keyPressed(KeyEvent e)
String keychar = new String(""+e.getKeyChar()) ;
int yy = 0 ;
int j = -1 ;
for(int i=0;i<10;i++)
if(keychar.equals(z[i]))
if(yy<y[i])
yy = y[i] ;
j = i ;
if(j!=-1)
z[j] = new String(""+(char)(Math.random()*25+65)) ;
y[j] = 0 ;
sum += 1 ;
else
sum -= 1 ;
public void keyReleased(KeyEvent e)
// TODO: Add your code here
基于jmeter+ant实现的接口自动化测试
jmeter+ANT接口自动化测试框架
项目说明
- 本框架是一套基于jmeter+Ant+Excel+Python而设计的数据驱动接口自动化测试框架,jmeter 作为执行器,Ant 作为构建工具,进行构建测试,本框架无需你使用代码编写用例,测试用例存储在csv中,在csv中可以进行接口用例编写,接口断言,用例运行控制。
技术栈
- jmeter
- Ant
- Python
环境部署
1、安装JDK
2、安装Jmeter
3、安装 ANT
- 1、解压apache-ant-1.10.5-bin.zip到任意目录,比如 E:apache-ant-1.10.5
- 2、windows中配置ANT环境变量,如下为我的配置
ANT_HOME E:apache-ant-1.10.5
Path E:apache-ant-1.10.5in
CLASSPATH E:apache-ant-1.10.5lib
- 3、ANT安装验证
验证安装结果,命令行输入ant -v ,出现版本信息则安装成功,如图
4、ANT与Jmeter集成
1、配置库文件
将jmeterextras目录下的ant-jmeter-1.1.1.jar 文件拷贝到ant安装目录下的lib文件夹中,如图
2、配置ANT与Jmeter的配置文件
新建ant的编译文件,命名为 build.xml,其内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<project name="ant-jmeter-test" default="run" basedir=".">
<tstamp>
<format property="time" pattern="yyyy_MM_dd_HH_mm" />
</tstamp>
<!-- 需要改成自己本地的 项目路径根 目录,即jmeter安装文件所在的目录-->
<property name="project.home" value=".." />
<!-- 需要改成自己本地的 Jmeter 目录-->
<property name="jmeter.home" value="${project.home}apache-jmeter-3.2" />
<!-- jmeter生成jtl格式的结果报告的路径-->
<property name="jmeter.result.jtl.dir" value="${project.home}
eportjtl" />
<!-- jmeter生成html格式的结果报告的路径-->
<property name="jmeter.result.html.dir" value="${project.home}
eporthtml" />
<!-- 生成的报告的前缀-->
<property name="ReportName" value="TestReport" />
<property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${ReportName}_${time}.jtl" />
<property name="jmeter.result.all_htmlName" value="${jmeter.result.html.dir}/All_Report/All${ReportName}_${time}.html" />
<property name="jmeter.result.detail_htmlName" value="${jmeter.result.html.dir}/Detail_Report/Detail${ReportName}_${time}.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="${project.home}jmeter_Code" 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.all_htmlName}"
style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl" />
<xslt
classpathref="xslt.classpath"
force="true"
in="${jmeter.result.jtlName}"
out="${jmeter.result.detail_htmlName}"
style="${jmeter.home}/extras/jmeter.results.shanhe.me.xsl" />
<!-- 因为上面生成报告的时候,不会将相关的图片也一起拷贝至目标目录,所以,需要手动拷贝 -->
<copy todir="${jmeter.result.html.dir}/All_Report">
<fileset dir="${jmeter.home}/extras">
<include name="collapse.png" />
<include name="expand.png" />
</fileset>
</copy>
</target>
</project>
按实际情况修改build.xml文件,相关说明如下
- 3、配置jmeter.properties
- 配置jmeter报告输出格式为xml。在jmeter根目录下apache-jmeter-3.2injmeter.properties文件中修改
jmeter.save.saveservice.output_format=csv
为jmeter.save.saveservice.output_format=xml
,并去掉前面的注释符号#,如图所示
- 配置jmeter报告输出格式为xml。在jmeter根目录下apache-jmeter-3.2injmeter.properties文件中修改
框架代码与用例设计及相关说明
1、用例设计
- 测试用例保存在csv文件中,如图所示
2、脚本代码说明
测试计划中定义用户变量,以供后面的脚本使用,如图
循环控制器设置永远循环,如图
循环控制器下新增CSV Data Set ConFig控件,循环读取用例文件中的测试用例,如图
- Allow quoted data?:是否允许带双引号的数据
- 此项实际是控制csv文件中的双引号是否为有效字符;
- 如果数据带有双引号且此项设置TRUE,则会自动去掉数据中的引号使能够正常读取数据,且即使引号之间的内容包含有分隔符时,仍作为一个整体而不进行分隔;
- 如果数据带有引号且此项设置为FALSE,则读取数据报错;
- 如果希望双引号字段中间再包含双引号,则需要加两个双引号来代表单个双引号。
- 比如此项设置为true时,"2,3"-->2,3;"4""5"-->4"5
- Sharing mode:共享模式
- All threads:针对所有线程组的所有线程,每个线程取值不一样,依次取csv文件中的下一行。即不管是单个线程组还是多个线程组,每个线程都是依次取下一行。
- Current thread group:当前线程组。以线程组为单位,每个线程组内的线程都会从第1行开始取值并依次往下进行取值。
- Current thread:当前线程。每个线程都会从第1行开始取值并依次往下进行取值,在同一次循环中所有的线程取值一样。
添加执行控制器,筛选测试用例执行,如下,可执行所有用例、可执行其中某部分用例、也可按用例的优先级执行测试用例。
- 根据调用方法选择请求方式
通过if选择器区分GET与POST方法的请求,配置http请求,如图
- Post请求的配置方式 :post请求参数放在body data中
- 响应结果配置如图
Get 请求的配置方式:get请求的参数配置url后面,如图
结合Python发送测试报告到邮箱
#encoding=utf-8
import time
import smtplib
import email
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
import sys
import os.path
reload(sys)
sys.setdefaultencoding('utf-8')
#收件箱,如果是list请以逗号分隔
mailto_list=['testXXX1@126.com','testXXX2@126.com']
#发件箱
mail_host="smtp.126.com"
mail_user="XXXXtest"
mail_pass="XXXXXX"
mail_postfix="126.com"
def send_mail(attfile1, attfile2):
today = time.strftime('%Y-%m-%d',time.localtime(time.time()))
detailTime = time.strftime('%H:%M:%S',time.localtime(time.time()))
todaytime = today + ' 00:00:00'
selectres = todaytime
send_header = "[demo项目][线上环境][自动化用例测试报告]- ".encode("utf-8") + today +" "+detailTime
me= mail_user+"@"+mail_postfix
msg = MIMEMultipart()
msg['Subject'] = send_header
msg['From'] = me
msg['To'] = ";".join(mailto_list)
#正文
fp = open(attfile1,"r")
content1 = fp.read()
fp.close()
content2 = '<html><h3>测试结果及更多详情请查看邮件附件【All_Report.html】和【Detail_Report.html】!!!</h3></html>'
msg.attach(MIMEText(content1 + content2, 'html', 'utf-8'))
#总体报告目录
att1 = MIMEText(open(attfile1, 'rb').read(), 'base64', 'gb2312')
att1["Content-Type"] = 'application/octet-stream'
att1["Content-Disposition"] = 'attachment; filename="All_Report.html"'
msg.attach(att1)
#详细报告目录
att2 = MIMEText(open(attfile2, 'rb').read(), 'base64', 'gb2312')
att2["Content-Type"] = 'application/octet-stream'
att2["Content-Disposition"] = 'attachment; filename="Detail_Report.html"'
msg.attach(att2)
try:
server = smtplib.SMTP()
server.connect(mail_host)
server.ehlo()
server.starttls()
server.login(mail_user,mail_pass)
server.sendmail(me, mailto_list, msg.as_string())
server.quit()
return True
except Exception, e:
print str(e)
return False
#======查找测试报告目录,找到最新生成的测试报告文件====
def new_report(testreport):
result_dir = testreport
#获取该目录下的所有文件,将文件存到列表lists里
lists=os.listdir(result_dir)
#重新按时间先后对目录下(列表lists里)的文件进行排列,最新文件排末尾
lists.sort(key=lambda fn: os.path.getmtime(result_dir+""+fn))
#找到最新生成的文件,并加上路径,lists(-1)倒数第一个
file_new = os.path.join(result_dir,lists[-1])
return file_new
if __name__ == '__main__':
report_dir1 = "../report/html/Detail_Report" #详细报告目录
report_dir2 = "../report/html/All_Report" #总体报告目录
#找到生成的最新的测试报告
file_new1 = new_report(report_dir1)
file_new2 = new_report(report_dir2)
print(file_new2)
if send_mail(file_new2, file_new1):
print u"测试报告邮件发送成功!"
else:
print u"测试报告邮件发送失败!"
3、执行测试,查看结果
build配置文件放在与测试脚本同目录下
- 执行测试
- 命令行cd到build.xml文件所在目录,输入
ant run
,执行测试,如图
- 看到build successful 则说明构建测试成功
- 测试报告
- 概要报告如下
- 详细报告如下
以上是关于jmeter用java代码怎样编写接口测试源码的主要内容,如果未能解决你的问题,请参考以下文章