Jmeter实例(一)_Beanshell脚本断言Mock接口

时间:2022-04-29 09:16:47

我们在做接口断言的时候,如果遇到复杂的json,可以考虑用beanshell脚本去解析list,同时加入自定义的断言

Mock例:https://www.easy-mock.com/mock/5cb46739edfdac7de69fe792/example/provider

Jmeter实例(一)_Beanshell脚本断言Mock接口

如图所示,我们在json返回中有name和remark字段,希望断言remark和name的返回值。如果断言失败,抛出自定义的异常信息

我们在mock接口下添加一个后置处理器的beanshell

Jmeter实例(一)_Beanshell脚本断言Mock接口

beanshell中写断言脚本

import org.apache.jmeter.assertions;
import org.apache.jmeter.samplers.SampleResult;
import org.apache.jmeter.assertions.AssertionResult;
import org.json.*;
String response_data = prev.getResponseDataAsString();
JSONObject data_obj = new JSONObject(response_data);
log.info(response_data);
String code = data_obj.get("remark");
log.info(code);
if(code.equals("接口测试服务商"))
{
String user_name = data_obj.get("dockedContact").get("name").toString();
if(user_name.equals("zhufc")){
Failure = true;
log.info(user_name);
log.info("提取值与预期相符,断言通过");
FailureMessage = "断言通过";
}
else{
Failure = false;
log.info("名称不同,断言失败");
FailureMessage = "断言失败";
prev.setStopThread(true);
}
}

Jmeter实例(一)_Beanshell脚本断言Mock接口

日志等级调整为info

Jmeter实例(一)_Beanshell脚本断言Mock接口

启动脚本,打开log,查看结果

Jmeter实例(一)_Beanshell脚本断言Mock接口