使用 Jmeter,我通过 REST API 将值传递给网络服务。成功后,API 将值更新为 mongo DB。
在使用 JMeter BeanShell Assertion 进行断言时……我想显示请求中发送的值和存储在数据库中的值。
我使用下面的脚本..
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 文件并且不会因超过屏幕缓冲区大小而被“吃掉”。见 How to use BeanShell: JMeter's favorite built-in component有关 Beanshell 脚本和暴露给 Beanshell 的各种 JMeter API 对象的更多信息的指南。
关于web-services - 如何在 JMeter bean shell 断言中打印变量的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24993001/