注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

笑遍世界@网易博客

明天还会在路上……

 
 
 

日志

 
 
关于我

Stay hungry, stay foolish. 工作用脑,生活用心! 走过山重水复,必然迎来柳暗花明! 受苦的人没有悲观的权利,远征的人没有流泪的资格。 Live each day as if we should die tomorrow.

网易考拉推荐
 
 

JMeter-Java Sampler编写范例(Java请求性能测试)  

2010-08-15 17:56:34|  分类: 编程技术 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
今天,听段念的培训,学了一下Jmeter写Java请求的过程。
根据某博文,修改其中代码的bug后,贴在下面吧;另外公司一同学Raylupas在半年前也写过关于JMeter写Java Sampler的文章,现在终于看明白了,写得非常的好啊,其Word版作为附件吧
我们在 做性能测试时,有时需要自己编写测试脚本,很多测试工具都支持自定义编写测试脚本,比如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.具体实现代码如下:
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;
/**
 * @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) {
          testStr = arg0.getParameter("testStr", "");
  }
 }
 //设置传入的参数,可以设置多个,已设置的参数会显示到Jmeter的参数列表中
     public Arguments getDefaultParameters() {
             Arguments params = new Arguments();
             params.addArgument("testStr", "abc");   //定义一个参数,显示到Jmeter的参数列表中,第一个参数为参数默认的显示名称,第二个参数为默认值
            return params;
 }
 //测试执行的循环体,根据线程数和循环次数的不同可执行多次,类似于LoadRunner中的Action方法
     @SuppressWarnings("deprecation")
    public SampleResult runTest(JavaSamplerContext context) {
          int len = 0;
          results = new SampleResult();
          results.sampleStart();     //定义一个事务,表示这是事务的起始点,类似于LoadRunner的 lr.start_transaction
          testStr = context.getParameter("testStr");
          len = testStr.length();
          results.sampleEnd();     //定义一个事务,表示这是事务的结束点,类似于LoadRunner的 lr.end_transaction
          results.setDataEncoding("UTF-8");
          if(len < 5){
                  System.out.println(testStr);
                  results.setResponseCode("testStr:"+testStr);
                  results.setResponseData("testStr:"+testStr);
                  results.setSuccessful(false);   //用于设置运行结果的成功或失败,如果是"false"则表示结果失败,否则则表示成功
         }else{
             results.setResponseCode("testStr:"+testStr);
             results.setResponseData("testStr:"+testStr);
             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测 试代码示例,用于抛砖引玉,希望大家一起交流,共同进步.

注:
results = new SampleResult();”最初写在了setUp()方法中了,在runTest()中再写sampleStart()、sampleEnd()时,如果线程多次循环,在jmeter.log中有Error的,具体原因,请见我两外一篇博文进行了说明。
  评论这张
 
阅读(2647)| 评论(2)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017