Beanshell脚本断言Mock接口
我们在做接口断言的时候,如果遇到复杂的json,可以考虑用beanshell脚本去解析list,同时加入自定义的断言
为黄岛等地区用户提供了全套网页设计制作服务,及黄岛网站建设行业解决方案。主营业务为网站制作、成都网站设计、黄岛网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
Mock例:https://www.easy-mock.com/mock/5cb46739edfdac7de69fe792/example/provider
如图所示,我们在json返回中有name和remark字段,希望断言remark和name的返回值。如果断言失败,抛出自定义的异常信息
我们在mock接口下添加一个后置处理器的beanshell
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); } }
日志等级调整为info
启动脚本,打开log,查看结果
网页名称:Beanshell脚本断言Mock接口
链接分享:http://pcwzsj.com/article/ggojsj.html