使用jmeter进行接口的无序对比~

项目背景
最近测试了一个文化旅游相关的项目
后台给出的一个住宿的接口是按照时间显示
前端则要求随机显示
那怎么样去做数据比对呢???
我用了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(“接口返回结与数据库结果完全一致”);
}

这个是名称断言
在这里插入图片描述
然后就结束拉,记得看日记
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值