从数据库取值和响应值做比较,使用beanshell如下:

  1. import org.json.JSONArray;
  2. import org.json.JSONObject;
  3.  
  4. res_str = prev.getResponseDataAsString();
  5. JSONObject res_json_obj = new JSONObject(res_str);
  6. JSONArray dbd_json_array = new JSONArray("${dbd}"); // 数据库转json
  7. JSONObject dbd_json_obj = new JSONObject();
  8. FailureMessage = "";
  9. Failure = true;
  10.  
  11. res_json_obj = new JSONObject(res_json_obj.get("data").toString());
  12. if (!res_json_obj.isNull("list")) {
  13. JSONArray res_json_array = new JSONArray(res_json_obj.get("list").toString());
  14. log.info("响应长度:" + res_json_array.length());
  15. log.info("数据返回长度:" + dbd_json_array.length());
  16.  
  17. if (res_json_array.length() == dbd_json_array.length()) {
  18. for (int i = 0; i < dbd_json_array.length(); i++) {
  19. Message = "\n第"+i+"条记录:";
  20. res_json_obj = res_json_array.getJSONObject(i);
  21. dbd_json_obj = dbd_json_array.getJSONObject(i);
  22.  
  23. System.out.println(res_json_obj);
  24.  
  25. Iterator keys = dbd_json_obj.keys();
  26. while (keys.hasNext()) {
  27. String key = (String) keys.next();
  28. String resvalue="";
  29. String dbdvalue="";
  30.  
  31. System.out.println("key:" + key);
  32. if (key.equals(null) || key.equals("")) {
  33. Message += key + "不存在;";
  34. FailureMessage += Message;
  35. Failure = true;
  36. log.info(Message);
  37. break;
  38. }
  39.  
  40. if(res_json_obj.has(key) && dbd_json_obj.has(key)) {
  41. resvalue = res_json_obj.getString(key);
  42. dbdvalue = dbd_json_obj.getString(key);
  43. }else {
  44. Message += key + "不存在;";
  45. FailureMessage += Message;
  46. Failure = true;
  47. log.info(Message);
  48. break;
  49. }
  50.  
  51. if (resvalue.equals(dbdvalue)) {
  52. Message += key + "匹配成功;";
  53. Failure = false;
  54. } else {
  55. Message += key + "匹配不成功,数据库值:" + dbdvalue + ",响应值:"+resvalue;
  56. FailureMessage += Message;
  57. Failure = true;
  58. log.info(Message);
  59. break;
  60.  
  61. }
  62.  
  63. log.info("value:" + res_json_obj.get(key));
  64. }
  65. }
  66.  
  67. } else {
  68. Message += "接口响应与数据库数据不匹配;";
  69. Message += "响应数据:" + res_json_array + "|数据库查询结果:" + dbd_json_array;
  70. FailureMessage += Message;
  71. Failure = true;
  72. log.info("value:" + res_json_obj.get(key));
  73. break;
  74. }
  75.  
  76. } else {
  77. FailureMessage = "返回数据为空";
  78. log.info(FailureMessage);
  79. Failure = true;
  80. return;
  81. }

import org.json.JSONArray;
import org.json.JSONObject;

res_str = prev.getResponseDataAsString();
JSONObject res_json_obj = new JSONObject(res_str);
JSONArray dbd_json_array = new JSONArray("${dbd}"); // 数据库转json
JSONObject dbd_json_obj = new JSONObject();
FailureMessage = "";
Failure = true;

res_json_obj = new JSONObject(res_json_obj.get("data").toString());
if (!res_json_obj.isNull("list")) {
JSONArray res_json_array = new JSONArray(res_json_obj.get("list").toString());
log.info("响应长度:" + res_json_array.length());
log.info("数据返回长度:" + dbd_json_array.length());

if (res_json_array.length() == dbd_json_array.length()) {
for (int i = 0; i < dbd_json_array.length(); i++) {
Message = "\n第"+i+"条记录:";
res_json_obj = res_json_array.getJSONObject(i);
dbd_json_obj = dbd_json_array.getJSONObject(i);

System.out.println(res_json_obj);

Iterator keys = dbd_json_obj.keys();
while (keys.hasNext()) {
String key = (String) keys.next();
String resvalue="";
String dbdvalue="";

System.out.println("key:" + key);
if (key.equals(null) || key.equals("")) {
Message += key + "不存在;";
FailureMessage += Message;
Failure = true;
log.info(Message);
break;
}

if(res_json_obj.has(key) && dbd_json_obj.has(key)) {
resvalue = res_json_obj.getString(key);
dbdvalue = dbd_json_obj.getString(key);
}else {
Message += key + "不存在;";
FailureMessage += Message;
Failure = true;
log.info(Message);
break;
}

if (resvalue.equals(dbdvalue)) {
Message += key + "匹配成功;";
Failure = false;
} else {
Message += key + "匹配不成功,数据库值:" + dbdvalue + ",响应值:"+resvalue;
FailureMessage += Message;
Failure = true;
log.info(Message);
break;

}

log.info("value:" + res_json_obj.get(key));
}
}

} else {
Message += "接口响应与数据库数据不匹配;";
Message += "响应数据:" + res_json_array + "|数据库查询结果:" + dbd_json_array;
FailureMessage += Message;
Failure = true;
log.info("value:" + res_json_obj.get(key));
break;
}

} else {
FailureMessage = "返回数据为空";
log.info(FailureMessage);
Failure = true;
return;
}
这个脚本有个前提,先建立了返回值的对象,当通过jmeter从数据库获得需要验证的数值的时候,需要指定数据库查询返回值字段名与java对象字段名一致。

遇到Typed variable declaration : Object constructor

发现数据库结果数组如下:

dbd=[{cardType=1, cardTypeText=, cardNo=62260906, bankType=1}]

原因是cardTypeText无值,将cardTypeText赋值可以解决。

相同的代码在eclipse中运行没有问题,但是在jmeter中有问题,可能是对空值的默认处理方法不一样。
---------------------
作者:谁知道丶
来源:CSDN
原文:https://blog.csdn.net/chyo098/article/details/82151019
版权声明:本文为博主原创文章,转载请附上博文链接!

jmeter beanshell Typed variable declaration : Object constructor错误的更多相关文章

  1. jmeter报错:响应数据HTTP Status 500 & 后台日志Typed variable declaration : Object constructor

    今天在测试文件下载接口,发现在测试单个文件下载1次时,文件成功下载.但是在测试单个文件并发下载50次时,Jmeter报错了,后台服务器tomcat竟然没有发现报错信息. Jmeter响应信息报错: H ...

  2. Jmeter BeanShell断言

    这篇文章用来记录编写beanshell断言遇到得问题. 问题1:JSONObject not found in namespace 流程:在beanshell下写代码如下: 1 String resp ...

  3. jmeter beanshell postprocessor 使用

    String newtoken=bsh.args[0];print(newtoken);${__setProperty(newtoken,${token},)}; String newcompanyI ...

  4. Testing Complex Logic with JMeter Beanshell

    BeanShell是最先进的JMeter内置组件之一.JMeter具有丰富的内置插件,可满足性能测试的许多需求.例如,在编写一些复杂的测试时,您可能需要一些额外的脚本.在这种情况下,值得使用Beans ...

  5. jmeter beanshell

    //获取返回数据 String json = prev.getResponseDataAsString(); ///加入变量vars.put("restr",json); //获取 ...

  6. JMeter BeanShell示例

    翻译:https://blog.trigent.com/jmeter-blog-series-jmeter-beanshell-example 在这个例子中,我们将演示在Apache JMeter中使 ...

  7. JMeter博客系列:JMeter BeanShell示例

    1.简介 Apache JMeter是一个基于Java的开源工具,使您可以在应用程序上执行功能,负载,性能和回归测试.应用程序可以在Web服务器上运行,也可以是独立的.它支持在包含静态和动态资源的客户 ...

  8. Relevance Between Variable Declaration and Definition in C++

    A declaration makes a name known to a programm. A definition creates the assocatied entity. A variab ...

  9. Object constructor

    1. Object is an instance of Function.2. Object does not have a property called constructor so when w ...

随机推荐

  1. 2.4 AppDelegate 的 3 个生命周期

    Classed/AppDelegate.cpp 文件内容如下: #include "cocos2d.h" #include "CCEGLView.h" #inc ...

  2. 优秀开源项目之二:流媒体直播系统Open Broadcaster Software

    Open Broadcaster Software(OBS)是一款用于音视频录制和直播的免费开源软件.可以轻松部署到多种平台,目前支持Windows.MAC和Linux. 特性: 1.高性能的实时视频 ...

  3. opensource mcu

    1 OpenVCS - Open Source Video Conferencing Server it is used as Multipoint Control Unit (MCU) manage ...

  4. 幻想乡三连C:狂飙突进的幻想乡

    题解: 不难发现,对于每一条从$S$到$T$的路径,设其$x.y$的和为$S_x.S_y$,其对答案的贡献是$a\cdot S_x+(1-a)\cdot S_y$,这是一个关于$a$的一次函数.而所有 ...

  5. poj 1845 Sumdiv(约数和,乘法逆元)

    题目: 求AB的正约数之和. 输入: A,B(0<=A,B<=5*107) 输出: 一个整数,AB的正约数之和 mod 9901. 思路: 根据正整数唯一分解定理,若一个正整数表示为:A= ...

  6. ACM学习历程—HDU1030 Delta-wave(数学)

    Description A triangle field is numbered with successive integers in the way shown on the picture be ...

  7. InvalidOperationException: out of sync

    C#中不能在集合的迭代中修改集合数据

  8. jexus入门

    参考:https://www.linuxdot.net/bbsfile-3084 一.Jexus简介:Jexus web server for linux 是一款基于.NET兼容环境,运行于Linux ...

  9. poj 2390 Bank Interest(计算本利和)

    一.Description Farmer John made a profit last year! He would like to invest it well but wonders how m ...

  10. 【转】 Pro Android学习笔记(七一):HTTP服务(5):多线程调用HttpClient

    目录(?)[-] 应用共享HttpClient对象的同步问题 创建共享HttpClient代码 创建共享对象 创建可共享的HttpClient对象 使用共享HttpClient对象的代码 基础代码 修 ...