Beanshell断言
Beanshell断言示例一:通过从数据库查询结果集,和从接口返回中解析json格式的返回内容,比较两者来验证sample请求是否成功
1>先通过JDBC PreProcessor把测试计划中所有接口请求涉及到的表的列名和对应的数据类型从information_schema库的COLUMNS表中查询出来存到一个变量里面
SELECT DISTINCT column_name, data_type
FROM COLUMNS
WHERE table_name IN ("t_bd_block",
"t_bd_build",
"t_bd_build_detail",
"t_bd_build_education",
"t_bd_build_hospital",
"t_bd_build_project",
"t_bd_build_schdist",
"t_bd_build_tag",
"t_bd_build_traffic",
"t_bd_floor",
"t_bd_house",
"t_bd_house_type",
"t_bd_picture",
"t_bd_project",
"t_bd_seo",
"t_bd_tag",
"t_bd_unit",
"t_bd_use",
"t_bd_use_sub",
"t_city",
"t_county",
"t_developer_company",
"t_idcenter",
"t_nation",
"t_poi",
"t_poi_education",
"t_poi_education_pic",
"t_poi_enrollment_plan",
"t_poi_graduation",
"t_poi_hospital",
"t_poi_station_pic",
"t_poi_sub",
"t_poi_subway_stations",
"t_poi_traffic_bus_station",
"t_poi_traffic_line",
"t_poi_traffic_line_station",
"t_poi_traffic_station",
"t_property_company",
"t_province",
"t_region",
"t_static_type");

2>把第1步中查出来的getColumnType解析出来,以键值对的形式存到变量vars供后面使用,因为json格式的数据有些类型的数据要加双引号,有些不需要,这时候就需要知道字段类型来判断下


ArrayList getColumnType1=vars.getObject("getColumnType");
ArrayList column_name = new ArrayList();
ArrayList data_type = new ArrayList();
for(HashMap row : getColumnType1){
Iterator it = row.entrySet().iterator();
while(it.hasNext()){
Map.Entry pair = (Map.Entry)it.next();
log.info(pair.getKey()+"="+pair.getValue());
if(pair.getKey().toString().equals("column_name")){
column_name.add(pair.getValue().toString());
}else if(pair.getKey().toString().equals("data_type")){
data_type.add(pair.getValue().toString());
}
}
}
for(int i=0;i<column_name.size();i++){
vars.put(column_name.get(i).toUpperCase(),data_type.get(i));
}
3>从数据库中把要验证的结果查询出来存到变量里面,变量存的是结果集


4> 对结果进行断言
ArrayList sqlResult1=vars.getObject("sqlResult");
String json = "";
if(sqlResult1.size()==0){
json= "[]"; //如果jdbc request查询结果为空,返回[]
}else{
for(HashMap row : sqlResult1){
String r="";
Iterator it = row.entrySet().iterator();
ArrayList keyAndValue = new ArrayList();
while(it.hasNext()){
Map.Entry pair = (Map.Entry)it.next();
log.info("pair:"+pair);
log.info(pair.getKey()+"="+pair.getValue());
if(pair.getValue()==null){
continue;
}else{
String[] subKey = pair.getKey().toString().split("_");
String key = subKey[0];
for(int k=1; k<subKey.length; k++){
key += Character.toUpperCase(subKey[k].charAt(0))+ subKey[k].substring(1);
}
if("varchar".equals(vars.get(pair.getKey().toString().toUpperCase())) || "char".equals(vars.get(pair.getKey().toString().toUpperCase())) || "text".equals(vars.get(pair.getKey().toString().toUpperCase()))){
keyAndValue.add("\""+key+"\":\""+pair.getValue()+"\",");
}else{
keyAndValue.add("\""+key+"\":"+pair.getValue()+",");
}
}
} //while循环结束
Collections.sort(keyAndValue);
for(int i=0;i<keyAndValue.size();i++){
r+=keyAndValue.get(i);
}
r="{"+r.substring(0,r.length()-1)+"},";
json+=r;
}
if(sqlResult1.size() > 1){
json="{\"code\":\"0001\",\"data\":{\"A-G\":["+json.substring(0,json.length()-1)+"]},\"message\":\"ok\"}";
}else{
json="{\"code\":\"0001\",\"data\":{"+json.substring(0,json.length()-1)+"},\"message\":\"ok\"}";
}
}
log.info(json);
String response_data = prev.getResponseDataAsString();
log.info(response_data);
import org.json.*;
log.info("进去了json对象");
JSONObject sql_data_obj = new JSONObject(json);
JSONObject response_data_obj = new JSONObject(response_data);
log.info("进去了json对象");
log.info("拿到了response的json对象"+response_data_obj);
log.info("拿到了sql的json对象"+sql_data_obj);
String responses_str = response_data_obj.get("data").get("A-G").toString();
String sqls_str = sql_data_obj.get("data").get("A-G").toString();
log.info("进去了responses的A-G"+responses_str);
JSONArray responses_array = new JSONArray(responses_str);
JSONArray sqls_array = new JSONArray(sqls_str);
//String[] result = new String[responses_array.length()];
boolean flag=true;
for(int i=0;i<responses_array.length();i++){
JSONObject response_obj = new JSONObject(responses_array.get(i).toString());
JSONObject sql_obj = new JSONObject(sqls_array.get(i).toString());
// String name = app_obj.get("cityId").toString();
Iterator it = response_obj.keys();
while(it.hasNext()){
//获取map的key
String key = (String) it.next();
System.out.println("key: "+key);
//得到value的值
Object response_value = response_obj.get(key);
Object sql_value=sql_obj.get(key);
if(!(sql_value.toString().equals(response_value.toString()))){
flag=false;
break;
}
//递归遍历
// jsonObj.put(key, traveseJson(value));
}
// result[i] = name;
}
//vars.put("result", Arrays.toString(result));
if(flag)//请求的response中有包含自定义字符,则断言结果为false
{
Failure=false;
String message="${__time(yyyy-MM-dd HH:mm:ss,)} 结果比对成功";
FailureMessage=message;
log.info(FailureMessage);
}else
{
Failure=true;
String message="${__time(yyyy-MM-dd HH:mm:ss,)} 结果比对失败";
String response="本次请求response数据:"+prev.getResponseDataAsString()+"----------";
String need_assert="需要断言的数据:"+ json;
FailureMessage=message+response+need_assert;
}
Beanshell断言示例二:从SampleResult对象中获取请求的响应结果码,如果不是200,那就直接让断言失败,如果成功,才去获取json格式的返回内容中的某个值,然后判断后再通过Fqilure对象去设置结果是成功还是失败


Beanshell断言的更多相关文章
- Jmeter接口测试使用beanshell断言json返回
一般情况下响应断言就能解决很多问题,但是返回复杂的json时就需要用到beanshell断言. 举个例子 免费的接口API www.sojson.com/api/beian/sojson.com ho ...
- JMeter中BeanShell断言使用一
Jmeter Ant Task如何让beanshell断言失败的详细信息展示在report里面 首先必须给beanshell断言添加FailureMessage if(${TotalClient_SS ...
- jmeter BeanShell断言(一)
原文地址https://blog.csdn.net/lijing742180/article/details/81157947 原文地址https://blog.csdn.net/zailushang ...
- Jmeter Ant Task如何让beanshell断言失败的详细信息展示在report里面
首先必须给beanshell断言添加FailureMessage if(${TotalClient_SS}+2!=${TotalClient_SS2}){Failure=true; Fai ...
- jmeter之beanshell断言实例
.首先储存一个接口的响应结果,比如在http请求的后面添加beanshell后置处理器(BeanShell PostProcessor)来储存http请求的响应结果: import org.json. ...
- jmeter之beanshell断言---数据处理
在做接口测试时,对响应数据的校验是非常重要的部分:在使用Jmeter进行接口测试时,有多种respone校验方式,比如响应断言.BeanShell断言等等,BeanShell断言可以自定义断言,自由灵 ...
- 【Jmeter测试】如何使用BeanShell断言判断请求返回的Json相应结果
脚本结构上图中,queryMaterialApiDTOListByPkIds是返回Json格式响应结果的请求,然后添加BeanShell断言详细判断Json结果中的值是否正确. Json格式的相 ...
- jmeter断言之BeanShell断言
1.添加BeanShell断言,在Script下面写断言脚本,常用的BeanShell脚本如下: if(!SampleResult.getResponseCode().equals("200 ...
- jmeter使用BeanShell断言
1. 首先存储一个接口的响应结果,如在http请求的BeanShell PostProcessor: import java.io.UnsupportedEncodingException; Syst ...
随机推荐
- 剑指offer(29)最小的K个数
题目描述 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,. 题目分析 这题有两种方法来做. 第一种就是基于partition的 ...
- Bootstrap3基础 table-responsive 响应式表格
内容 参数 OS Windows 10 x64 browser Firefox 65.0.2 framework Bootstrap 3.3.7 editor ...
- innoDB锁小结
innodb的锁分两类:lock和latch. 其中latch主要是保证并发线程操作临界资源的正确性,要求时间非常短,所以没有死锁检测机制.latch包括mutex(互斥量)和rwlock(读写锁). ...
- jsp/servlet学习三之会话管理初解
由于http的无状态性,使得会话管理或会话跟踪成为web应用开发一个无可避免的主题.默认下,一个web服务器无法区分一个http请求是否为第一次访问.例如,一个web邮件应用要求用户登陆后才能查看邮件 ...
- Foxmail7.2新建的文件夹不见了
Foxmail在客户端上,新建了几个文件夹,并把相应的邮件都都选择了“总是把**邮件转移到”这个选项. 今天早上打开电脑一看,所有的邮件连同对应的文件夹都找不到了 Foxmail中没显示因为默认是隐藏 ...
- 路由表flags的U值引起的能ping通网关,ping不通其它网段的案例
故障的: 正常的: 初步分析: 看路由表的flags ,之前故障时是U.现在正常的是UG查了下说明,应该是这个原因.U — 路由是活动的G — 路由指向网关
- django之admin管理工具
admin组件 admin是django提供的基于web的管理工具 >如何使用: 1.激活管理工具 通常会在生成项目时在urls.py中自动设置好 from django.urls import ...
- PI上导入RFC
ERP中创建函数:ZERP_GETSPAREPART 传入参数:SOLD_TO_ID SHIP_TO_ID 表:INTABLE OUTABLE 登陆PI, 后面正常做data type DT_PART ...
- springboot整合mybatis遇到无法扫描MaperScan包的问题
1.启动类加上@MaperScan注解后,一直报错如下: Error creating bean with name 'platUserMapper' defined in file [D:\work ...
- myhome vscode plugins
├─ 1194979849.code-snippets-0.1.18├─ adamwalzer.string-converter-0.1.1├─ alefragnani.bookmarks-9.3.0 ...