项目背景 最近测试了一个文化旅游相关的项目 后台给出的一个住宿的接口是按照时间显示 前端则要求随机显示 那怎么样去做数据比对呢??? 我用了2个id和名称这两字段对比,因为我怕有名称一样的
第一步: jmeter链接数据库获取数据库的数据 @1链接数据库 @2数据库的查询 一般我们会用**${参数名字_#}**表示数据库才查出来的值是多少个 第二步 写个接口 第三步接口数据json提取,其中-1表示全部 其中
**一般会用${参数名称_matchNr}**来表示接口匹配的数量
第四步骤 在接口的请求后面加一个beanshell断言 这个是id断言
import java.util.HashMap;// 引入 HashMap 类; 思路是先创建一个集合写入数据{A=1,B=1,c=1}如果出现A有多个就+1; HashMap nameSet=new HashMap(); boolean flag=false;
if(KaTeX parse error: Expected group after '_' at position 5: {sid_?#}=={jid_matchNr}){ for(int i=1;i<=${jid_matchNr};i++){//将页面结果名称写入Map集合; String res_name= vars.get(“jid_”+i);
if(nameSet.get(res_name)!=null){//存在该res_name,则数量+1
int num=nameSet.get(res_name);
nameSet.put(res_name,++num);
}else{
nameSet.put(res_name,1);//不存在,数量就是1
}
}
for(int i=1;i<=${sid_#};i++){//数据库名称存在map集合中,则数量-1;
//String dbtitle=vars.getObject("resultt").get(i).get("title");
String sql_name= vars.get("sid_"+i);
if(nameSet.get(sql_name)==null){ //从集合中判断是否存在数据库返回的结果
flag=true;
Failure=true;
FailureMessage="接口返回内容与数据库查询结果内容不一致;";
break;//不存在直接退出
}
int num=nameSet.get(sql_name); //存在则获取对应的数量
nameSet.put(sql_name,--num); //数量-1
}
for(int i=1;i<${sid_#};i++){//遍历最终的map集合,如果所有键的值=0,则页面与数据库搜索处理的产品名称完全一致
//String pgtitle=ptitle.getJSONObject(i).getString("title");
String res_name= vars.get("jid_"+i);
log.info("======="+res_name);
if(nameSet.get(res_name)!=0){
log.info("======="+res_name);
flag=true;
Failure=true;
FailureMessage="接口返回结果内容与数据库结果比对,住宿名称个数不正确;";
break;
}
}
}else{//页面查询条数与数据库查询条数不一致; flag=true; Failure=true; FailureMessage=“接口返回结与数据库结果条数不一致”; } if(!flag){ Failure=false; System.out.println(“接口返回结与数据库结果完全一致”); }
=================================
import java.util.HashMap;// 引入 HashMap 类; 思路是先创建一个集合写入数据{A=1,B=1,c=1}如果出现A有多个就+1; HashMap nameSet=new HashMap(); boolean flag=false;
if(KaTeX parse error: Expected group after '_' at position 7: {sname_?#}=={jname_matchNr}){ for(int i=1;i<=${jname_matchNr};i++){//将页面结果名称写入Map集合; String res_name= vars.get(“jname_”+i);
if(nameSet.get(res_name)!=null){//存在该res_name,则数量+1
int num=nameSet.get(res_name);
nameSet.put(res_name,++num);
}else{
nameSet.put(res_name,1);//不存在,数量就是1
}
}
for(int i=1;i<=${sname_#};i++){//数据库名称存在map集合中,则数量-1;
//String dbtitle=vars.getObject("resultt").get(i).get("title");
String sql_name= vars.get("sname_"+i);
if(nameSet.get(sql_name)==null){ //从集合中判断是否存在数据库返回的结果
flag=true;
Failure=true;
FailureMessage="接口返回内容与数据库查询结果内容不一致;";
break;//不存在直接退出
}
int num=nameSet.get(sql_name); //存在则获取对应的数量
nameSet.put(sql_name,--num); //数量-1
}
for(int i=1;i<${sname_#};i++){//遍历最终的map集合,如果所有键的值=0,则页面与数据库搜索处理的产品名称完全一致
//String pgtitle=ptitle.getJSONObject(i).getString("title");
String res_name= vars.get("jname_"+i);
log.info("======="+res_name);
if(nameSet.get(res_name)!=0){
log.info("======="+res_name);
flag=true;
Failure=true;
FailureMessage="接口返回结果内容与数据库结果比对,住宿名称个数不正确;";
break;
}
}
}else{//页面查询条数与数据库查询条数不一致; flag=true; Failure=true; FailureMessage=“接口返回结与数据库结果条数不一致”; } if(!flag){ Failure=false; System.out.println(“接口返回结与数据库结果完全一致”); }
这个是名称断言 然后就结束拉,记得看日记
|