JMeter进阶——详解Java请求关于事务的操作 (附源码)

57 篇文章 2 订阅
18 篇文章 1 订阅

 

Jmeter事务操作

前面写过一篇文章,介绍Jmeter如何来调用java请求的,可以参考文章 详解JMeter Java请求的设计方法

但这篇文章中有一个问题,在方法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中无法实现该功能!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

测试开发Kevin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值