这里我们使用的断言方式是BeanShell断言,做一个新增功能的接口测试,

1.发一个post请求,新增测试数据,然后做一个返回数据的响应断言-------大部分人都可以实现这个功能

2.如果是后台业务的话,我们的数据时会录入到后端数据库的,那么这里我们使用JDBC后置处理器,来获取数据

3.获取数据后,我们怎么来比较我们取得值是否和数据库中的一致呢----这里我们引用BeanShell断言

String name = vars.getObject("devName").get(0).get("name");      //获取SQL查询到的name,有时候会报错declaration----解决办法String改Object
log.info("name结果是:"+name);                   //打印log,方便调试
vars.put("resdevName",name.toString());               //把name值传给resdevName,方便后续使用,和正则表达式提取器一样
String nameExp = "${name}";                    //赋值,期望的name值。这里我传的是一个动态的值,用户定义的变量
log.info("nameExp结果是:"+nameExp);                
vars.put("ExpDevName",nameExp.toString());  
if(!name.equals(nameExp)) {                    //这里是比较语句,如果相等的话,断言成功-正常通过,如果不相等,断言失败-爆红色error
Failure = true; FailureMessage = "error,check error"; } else { FailureMessage = "ok,check current"; }

4.运行查看结果,这里的Debug Sampler中记录了值,故意在比较的时候加了一个“1”看一下失败的效果

扩展:

当然我们也可以多次断言,也可以获取select中的多个值

Object status = vars.getObject("status").get(0).get("status").toString();
log.info("上线状态的status是多少"+status);
String statusExp = "1";
log.info("上线状态的statusExp希望是"+statusExp); Object valid_status = vars.getObject("status").get(0).get("valid_status").toString();
log.info("上线状态的valid_status是多少"+valid_status);
String valid_statusExp = "1";
log.info("上线状态的valid_statusExp希望是"+valid_statusExp); Object name = vars.getObject("status").get(0).get("name").toString();
log.info("上线状态的name是多少"+name);
String nameExp = "${editName}"; //这里的值取得是编辑后的editName,如果是直接新增的话,应该是newName
log.info("上线状态的nameExp希望是"+nameExp); if((!valid_status.equals(valid_statusExp))||(!status.equals(statusExp))||(!name.equals(nameExp))) { //所有条件都满足才通过,否则error Failure = true; FailureMessage = "${status} != ${statusExp}"; } else { FailureMessage = "ok,check current"; } //本次有2个JDBC后置处理器需要处理,使用了2个判断;不知道有没有跟高级的写法
Object name_new = vars.getObject("name_version").get(0).get("name").toString();
log.info("上线状态后编辑的name_new是多少"+name_new);
String name_newExp = "${onlineName}";
log.info("上线状态后编辑的name_newExp希望是"+name_newExp); Object version = vars.getObject("name_version").get(0).get("version").toString();
log.info("上线状态后编辑的version是多少"+version);
String versionExp = "2";
log.info("上线状态后编辑的versionExp希望是"+versionExp); if((!valid_status.equals(valid_statusExp))||(!status.equals(statusExp))) { Failure = true; FailureMessage = "${status} != ${statusExp}"; } else { FailureMessage = "ok,check current"; }

JDBC 与 Bean Shell的使用(二)获取值,并且断言的更多相关文章

  1. JDBC 与 Bean Shell的使用(一)获取值,并且传递

    1.在使用Jmeter进行接口测试的时候,会使用到JDBC,连接数据库,操作数据库其得到的数据后续操作需要使用,这里我们使用了BeanShell的概念来获取JDBC的返回值 如下说明了联合使用的2种方 ...

  2. Jmeter之Bean shell使用(二)

    上一篇Jmeter之Bean shell使用(一)简单介绍了下Jmeter中的Bean shell,本文是对上文的一个补充,主要总结下常用的几种场景和方法,相信这些基本可以涵盖大部分的需求.本节内容如 ...

  3. (十二)Jmeter之Bean Shell的使用(一)

    一.什么是Bean Shell BeanShell是一种完全符合Java语法规范的脚本语言,并且又拥有自己的一些语法和方法; BeanShell是一种松散类型的脚本语言(这点和JS类似); BeanS ...

  4. 转 Jmeter之Bean shell使用(二)

    上一篇Jmeter之Bean shell使用(一)简单介绍了下Jmeter中的Bean shell,本文是对上文的一个补充,主要总结下常用的几种场景和方法,相信这些基本可以涵盖大部分的需求.本节内容如 ...

  5. Jmeter之Bean shell使用(二)

    上一篇Jmeter之Bean shell使用(一)简单介绍了下Jmeter中的Bean shell,本文是对上文的一个补充,主要总结下常用的几种场景和方法,相信这些基本可以涵盖大部分的需求.本节内容如 ...

  6. 转:Jmeter之Bean shell使用(二)

    上一篇Jmeter之Bean shell使用(一)简单介绍了下Jmeter中的Bean shell,本文是对上文的一个补充,主要总结下常用的几种场景和方法,相信这些基本可以涵盖大部分的需求.本节内容如 ...

  7. 【jmeter】Bean shell使用(二)

    上一篇Jmeter之Bean shell使用(一)简单介绍了下Jmeter中的Bean shell,本文是对上文的一个补充,主要总结下常用的几种场景和方法,相信这些基本可以涵盖大部分的需求.本节内容如 ...

  8. jmeter bean shell断言加密的响应信息(加密接口测试二)

    断言加密的响应信息 1.在http请求-->添加-->断言-->bean shell 断言 import com.changfu.EncryptAndDecryptInterface ...

  9. jmeter Bean Shell的使用(二)

    BeanShell的用法 在此介绍下BeanShell PreProcessor的用法,其它的beahshell可以类推.在此我们使用beahshell调用自己写的工具类,工具类实现了密码的加.解密功 ...

随机推荐

  1. python , 顺序迭代合并后的list对象

    有一系列排序序列,想将它们合并后得到一个排序序列并在上面迭代遍历 heapq.merge() 函数可以帮你解决这个问题.比如: >>> import heapq >>&g ...

  2. hive 配置参数说明(收藏版)

    问题导读: 如何设置reduce的个数? Hive 默认的数据文件存储路径? Hive 默认的输出文件格式? 是否开启 map/reduce job的并发提交? 所允许的最大的动态分区的个数? hiv ...

  3. tomcat启动失败问题排除及解决办法 Server Tomcat v7.0 Server at localhost failed to start.

    tomcat启动失败问题排除及解决办法 Server Tomcat v7.0 Server at localhost failed to start. 导致上面问题的原因可能有很多种,每种的解决办法都 ...

  4. mysql8.0无法给用户授权或提示You are not allowed to create a user with GRANT的问题

    提示意思是不能用grant创建用户,mysql8.0以前的版本可以使用grant在授权的时候隐式的创建用户,8.0以后已经不支持,所以必须先创建用户,然后再授权,命令如下: mysql> CRE ...

  5. 04:sqlalchemy操作数据库

    目录: 1.1 ORM介绍(作用:不用原生SQL语句对数据库操作) 1.2 安装sqlalchemy并创建表 1.3 使用sqlalchemy对表基本操作 1.4 一对多外键关联 1.5 sqlalc ...

  6. 使用CSP防止XSS攻击

    转载自阮一峰博客:http://www.ruanyifeng.com/blog/2016/09/csp.html 跨域脚本攻击 XSS 是最常见.危害最大的网页安全漏洞. 为了防止它们,要采取很多编程 ...

  7. HTML语法分析

    什么是HTML htyper text markup language 即超文本标记语言HTML是一个网页的主体部分,也是一个网页的基础.因为一个网页可以没有样式,可以没有交互,但是必须要有网页需要呈 ...

  8. win10 字体渲染优化 色彩调整

    最近烧包买了个2k显示器,发现跟win10使用,一堆问题,最大的就是字体,其实应该买4k,那样正好设置200%字体,现在设置的124% 字体: 以前使用的是mactype这个软件 https://pa ...

  9. (转)Spring Boot(一)

    (二期)4.springboot的综合讲解 [课程四]springbo...概念.xmind64.5KB [课程四]spring装配方式.xmind0.2MB [课程四预习]spri...解读.xmi ...

  10. Spring Boot详细学习地址转载

    阿里中间件牛人,学习榜样,源码分析: https://fangjian0423.github.io/ 基础.详细.全面的教程: https://gitee.com/roncoocom/spring-b ...