web-services – 如何在JMeter bean shell断言中打印变量的值

使用Jmeter,我通过REST API将值传递给Web服务.在成功时,API会将值更新为mongo DB.
使用JMeter Bean Shell Assertion断言时,我想显示请求中发送的值和存储在DB中的值.

我使用下面的脚本..

String req_data="${Request_Configuration}";
String res_data="${mongo_db_Configuration}";


if(res_data.equalsIgnoreCase(req_data)){
   Failure=false;
   FailureMessage = "Data stored in DB is correct";
   System.out.println("ReqData="+req_data);
   System.out.println("ResData="+res_data);
}
else{
   Failure = true;
   FailureMessage = "Data Stored in DB is NOT correct";
   System.out.println("ReqData="+req_data);
   System.out.println("ResData="+res_data);
}

我只是无法打印ReqData和ResData.请帮忙.

解决方法

您的脚本中存在问题.在Beanshell中,您无法访问${Request_Configuration}之类的变量,您需要使用vars.get(“Request_Configuration”).

vars是当前上下文的JMeterVariables类实例的简写.

因此,您的Beanshell断言代码应如下所示:

String req_data=vars.get("Request_Configuration");
String res_data=vars.get("mongo_db_Configuration");


if(res_data.equalsIgnoreCase(req_data)){
   Failure=false;
   FailureMessage = "Data stored in DB is correct";
   System.out.println("ReqData="+req_data);
   System.out.println("ResData="+res_data);
}
else{
   Failure = true;
   FailureMessage = "Data Stored in DB is NOT correct";
   System.out.println("ReqData="+req_data);
   System.out.println("ResData="+res_data);
}

我还建议使用log.info()而不是System.out.println(),因为在这种情况下,结果将转到jmeter.log文件,并且不会因超过屏幕缓冲区大小而被“吃掉”.

有关Beanshell脚本和有关Beanshell解释的各种JMeter API对象的更多信息,请参阅How to use BeanShell: JMeter’s favorite built-in component指南.

相关文章

vue阻止冒泡事件 阻止点击事件的执行 <div @click=&a...
尝试过使用网友说的API接口获取 找到的都是失效了 暂时就使用...
后台我拿的数据是这样的格式: [ {id:1 , parentId: 0, name:...
JAVA下载文件防重复点击,防止多次下载请求,Cookie方式快速简...
Mip是什么意思以及作用有哪些