项目背景 最近测试了一个文化旅游相关的项目 后台给出的一个住宿的接口是按照时间显示 前端则要求随机显示 那怎么样去做数据比对呢??? 我用了2个id和名称这两字段对比,因为我怕有名称一样的
第一步: jmeter链接数据库获取数据库的数据 @1链接数据库![在这里插入图片描述](https://img-blog.csdnimg.cn/bbb95510d1054219aa98fb701332d59e.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAeWVsbG935bCP6buE5LuZ,size_20,color_FFFFFF,t_70,g_se,x_16) @2数据库的查询 ![在这里插入图片描述](https://img-blog.csdnimg.cn/79cf01e1ed5841fea4c58c6617eb2740.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAeWVsbG935bCP6buE5LuZ,size_20,color_FFFFFF,t_70,g_se,x_16) 一般我们会用**${参数名字_#}**表示数据库才查出来的值是多少个 第二步 写个接口 ![在这里插入图片描述](https://img-blog.csdnimg.cn/f63c7d9ca3954e27a0b42edb9e9cdc60.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAeWVsbG935bCP6buE5LuZ,size_20,color_FFFFFF,t_70,g_se,x_16) 第三步接口数据json提取,其中-1表示全部 其中 ![在这里插入图片描述](https://img-blog.csdnimg.cn/9734eeb38c864e55b8a0a90d5eaefa41.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAeWVsbG935bCP6buE5LuZ,size_20,color_FFFFFF,t_70,g_se,x_16)
![在这里插入图片描述](https://img-blog.csdnimg.cn/df58d0640597406db85cd4516b74d346.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAeWVsbG935bCP6buE5LuZ,size_20,color_FFFFFF,t_70,g_se,x_16) **一般会用${参数名称_matchNr}**来表示接口匹配的数量
第四步骤 在接口的请求后面加一个beanshell断言 这个是id断言 ![在这里插入图片描述](https://img-blog.csdnimg.cn/4c8dcaeacacd417880415262665ed0d2.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAeWVsbG935bCP6buE5LuZ,size_20,color_FFFFFF,t_70,g_se,x_16)
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(“接口返回结与数据库结果完全一致”); }
这个是名称断言 ![在这里插入图片描述](https://img-blog.csdnimg.cn/50b91b1d72c44c2d9e6fd8006b83af3b.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAeWVsbG935bCP6buE5LuZ,size_20,color_FFFFFF,t_70,g_se,x_16) 然后就结束拉,记得看日记 ![在这里插入图片描述](https://img-blog.csdnimg.cn/87c0bbc5e5984bad83e28f0f8f40b4e3.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBAeWVsbG935bCP6buE5LuZ,size_20,color_FFFFFF,t_70,g_se,x_16)
|