51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 561|回复: 0

Java请求关于事务的操作之JMeter进阶

[复制链接]
  • TA的每日心情
    无聊
    10 小时前
  • 签到天数: 919 天

    连续签到: 1 天

    [LV.10]测试总司令

    发表于 2023-5-6 13:13:40 | 显示全部楼层 |阅读模式
    这篇文章中有一个问题,在方法public SampleResult runTest(JavaSamplerContext arg0) 中只对一个类的一个api 进行调用,如果需求是在jmeter中对多个类的多个api进行调用该如何实现呢?同学们会说,简单呀,我们创建多个类然后分别继承AbstractJavaSamplerClient就可以了呀!这样做当然可以,但是这要创建太多的类啦,Jmeter提供了方法可以实现事务操作,即 在一个runTest 方法中创建一个事务,然后一个事务中包括多个请求,话不多说直接上代码:
      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;
      public class DemoTransaction extends AbstractJavaSamplerClient {
      private SampleResult sr;
      public static final String PARAM_PARA1 = "para1";
      public Arguments getDefaultParameters() {
      Arguments params = new Arguments();
      params.addArgument("para1", "");
      return params;
      }
      public SampleResult runTest(JavaSamplerContext arg0) {
      /**创建事务demo**/
      this.sr = new SampleResult();
      this.sr.setSampleLabel("demo ");
      this.sr.sampleStart();
      /**创建事务demo中的第一个子请求**/
      SampleResult result1= new SampleResult();
      result1.setSampleLabel("demo1");
      result1.sampleStart();
      /**写子请求的具体逻辑,这里用等待时间代替**/
      try {
      Thread.sleep(1000);
      } catch (InterruptedException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }
      /**写子请求的具体逻辑,这里用等待时间代替**/
      this.sr.addSubResult(result1,false); //重点把子请求的测试结果放到事务中
      result1.sampleEnd(); //子请求1结束
      /**创建事务demo中的第二个子请求**/
      SampleResult result2= new SampleResult();
      result2.setSampleLabel("demo2");
      result2.sampleStart();
      /**写子请求的具体逻辑,这里用等待时间代替**/
      try {
      Thread.sleep(500);
      } catch (InterruptedException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
      }
      /**写子请求的具体逻辑,这里用等待时间代替**/
      result2.setSuccessful(true);
      this.sr.addSubResult(result2,false); //重点把子请求的测试结果放到事务中
      result2.sampleEnd(); //子请求2结束
      /**判断子请求是否都成功执行,如果其中一个失败,则认定事务执行失败**/
      if( result1.isSuccessful() & result2.isSuccessful())
      {
      this.sr.setSuccessful(true);
      }else {
      this.sr.setSuccessful(false);
      }
      /**判断子请求是否都成功执行,如果其中一个失败,则认定事务执行失败**/
      this.sr.sampleEnd(); //事务结束
      return this.sr;
      }
      public void setupTest(JavaSamplerContext context) {
      super.setupTest(context);
      }
      public void teardownTest(JavaSamplerContext context) {
      super.teardownTest(context);
      }
      }


      使用JMeter 5.x API
      这里需要强调的是方法 addSubResult(result2,false) 这个方法是在jmeter 5.x 才提供的(4.x中是addSubResult(result2)), 第一个参数是传入的result值,第二个参数是是否把子线程改名字,jmeter 5.x的maven配置如下。
      <dependency>
      <groupId>org.apache.jmeter</groupId>
      <artifactId>ApacheJMeter_core</artifactId>
      <version>5.5</version>
      </dependency>
      <dependency>
      <groupId>org.apache.jmeter</groupId>
      <artifactId>ApacheJMeter_java</artifactId>
      <version>5.5</version>
      </dependency>


      使用这个方法才能实现——在聚合报告中显示事务中子请求的响应时间和处理能力。
      把java文件打包放到\lib\ext 目录下,然后添加java sampler ,选择类DemoTransaction,运行测试,结果如下:
      在查看结果树中可以看到事务demo包括了两个子请求demo1和demo2。

      在聚合报告中只有demo的整体信息,我们看到实例中demo1 和demo2 分别等待1s和0.5s,而下图中Average是1500毫秒,这点证明事务的响应时间等于两个请求之和。

      测试报告优化方案
      上面的聚合报告是有缺陷的,没有列出每一个子请求的响应时间和处理能力!目前我还没有通过编码来搞定这个问题,但是我们可以通过其他方式实现,即在测试过程中,把测试结果写到一个文件中,然后测试结束后打开这个文件就可以了!

      再次强调!想要实现该功能一定要使用jmeter 5.x的ApacheJMeter_java和ApacheJMeter_core,本人亲测在jmeter 4.x中无法实现该功能!

    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-3-29 19:46 , Processed in 0.065552 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表