jmeter-beanshell学习2-beanshell断言

继续写,之前写了获取变量,设置变量,今天先写个简单点的断言。

一般情况用响应断言,就挺好使,但是自动化还要生成报告,如果断言失败了,要保存结果,只能用beanshell处理,顺便把断言一起做了,这时候用beanshell断言正合适。

还用这个接口,上次已经提取了id和name,这次直接用这俩断言。先写个简单的,为了看到断言效果,写个错误的:如果id不等于3,就报错。看断言

id=vars.get("id");

name=vars.get("name");

if (!id.equals("3")){

Failure=true;

}

再执行,Failure=true;表示断言没通过。

结果树显示为红色,看一下断言提示

如果存在多个断言,这里看不出来是哪个断言没通过,本来会生成报告的,结果树可能根本都不看,这个提示也没啥用,但是昨天遇到个报错,根据经验就是断言没通过,报告里就是给写了通过,看提示,应该也能打印出message,再给加上。

id=vars.get("id");

name=vars.get("name");

if (!id.equals("3")){

Failure=true;

FailureMessage="id不为3。";

}

如果同时判断id不等于3,且name等于xiaohua,就报错:

id=vars.get("id");

name=vars.get("name");

if ((!id.equals("3"))&&(name.equals("xiaohua"))){

Failure=true;

FailureMessage="id不为3。";

}

一定要把每个判断都用括号括起来,不然判断不生效。且用&&,或用||。

结果树报红只是顺便,自动化要生成报告,每次判断失败还要记录结果,再加上记录结果

result_message="";

id=vars.get("id");

name=vars.get("name");

if ((!id.equals("3"))&&(!name.equals("xiaohua"))){

Failure=true;

FailureMessage="id不为3。";

result_message+="id预期为:3,实际结果为:"+id+",";

vars.put("result_message",result_message);

return

}

先定义一个变量,result_message,用这个记录结果,接口自动化,不能只发个接口就结束了,还要判断数据库记录的对不对,或者可能还有后续接口,一起验,所以不管这里报错还是成功,后续该验的还是要有,如果后面还有报错,就一起都写在这个result_message里,下面用个vars.put,后面其他beanshell再get获取,就能继续加验证结果了。这一个接口已经有断言失败了,加上一个return,后面的其他断言分支就不会再走了,直接进行后面的其他请求。

写到这里有个问题,如果这个断言全部通过,就不会走到if分支里,也就不会再有vars.put("result_message",result_message);了,后面其他验证收不到result_message。这时候要优化脚本,我在断言前面加了个前置处理器:beanshell预处理器,把定义result_message直接放到这里,保证后面不管哪个断言失败,都能取到result_message,再往里添加其他报错。

在断言时候,先获取一次result_message就可以了。前面用的beansehll预处理,这个元件我也说不上来具体有什么特点,取请求报文内容的时候,也用的这个,如果想把result_message再往前放,也可以用取样器,看自己需要。

现在断言记录结果先这样,明天继续写。

相关推荐
声网3 分钟前
从语音识别到智能助手:Voice Agent 的技术进化与交互变革丨Voice Agent 学习笔记
学习·交互·语音识别
小咪一会24 分钟前
速学 RocketMQ
学习·rocketmq·java-rocketmq
future14121 小时前
项目开发日记
前端·学习·c#·游戏开发
每次的天空2 小时前
Android-重学kotlin(协程源码第一阶段)新学习总结
开发语言·学习·kotlin
Brookty2 小时前
【操作系统】线程
java·linux·服务器·后端·学习·java-ee·操作系统
数字芯片实验室8 小时前
分享一个可以学习正则表达式的网址:Pythex.org
学习·正则表达式
陈洪奇8 小时前
注册中心学习笔记整理
笔记·学习
光影少年8 小时前
从前端转go开发的学习路线
前端·学习·golang
财神爷首席大弟子12 小时前
jmeter做跨线程组
jmeter
fen_fen13 小时前
学习笔记(32):matplotlib绘制简单图表-数据分布图
笔记·学习·matplotlib