- 接口添加断言
以删除购物车货品为例,我们首先右键添加断言----这是对响应数据json 的断言
提取断言需要的数据
断言介绍:
断言失败展示:
通常情况下我们哪些数据需要断言,当数据多的时候我们可以挑选一下重要的字段进行断言,当数据较少时我们可以都进行断言比如:
那接下来我们再来对code和data进行断言
运行成功不会显示json断言,只有运行不成的时候才会触发
三个断言中任何一个不成立都有运行不成功
如何判断,这个接口时间是否正真的删了了数据,或者说真正的运行成功了呢?
这里我们就需要用到数据库来查询
jmeter连接数据库
前提:我们使用jmerter链接数据库是需要架包的不然会报错(使⽤jmeter连接数据库,是不是需要数据库开放⼀个连
接的⼝⼦给你?所以这个驱动应该去找MySQL拿)
进入官网:https://www.mysql.com/cn/products/connector/
点击后进入这个页面
然后下载的是⼀个压缩⽂件,解压后请在⾥⾯找到 mysql-connector-java-<版本号>.jar ⽂
件;
然后将该⽂件放到jmeter的lib⽂件夹中
记得重启jmeter
第一步:我们通过添加JDBC Connection Configuration来链接数据库
添加连接数据库的相关信息--------Aa9999!
第二步:我们通过添加JDBC Request来访问数据库
填写访问数据的查询语句并执行
连接成功后我们可以在响应数据中看到数据库的数据
以上就代表数据库连接成功了
根据数据库进行断言
这里我们需要对访问数据库请求添加变量
接下来我们运行它,会发现不知道在哪查看结果
添加后再次运行,然后我们就可以在查看结构树里面看到请求成功可以下拉,这里就是返回的数据
我们点击查看返回的数据
然后我们再来看看我们设置的变量value
这时我们是不是就明白了我们可以通过value 和result来进行断言
如果统计数据的字段value=0或者接收数据的result=[],就代表数据被删掉了,这里差不到数据
- 这里我们要对访问数据库的请求进行断言,我们需要添加Bean Shell来进行断言,普通的断言不行
// 下⽅语句构建⼀个if 断⾔语句;
if ("预期断⾔值" != "实际断⾔值" ) {
// 下⽅语句为条件达成后执⾏的语句:设置Failure属性值为True;
//如果if条件语句不达成,我们就将Failure设置成False,将结果变为失败
Failure = true;
// 下⽅语句为条件达成后执⾏的语句:设置断⾔失败后返回的语句;
FailureMessage = "⽤例失败,因为数据实际为:xxxx,预期为:1";
};
点击运行后,查看断言结果
这时一个针对于访问数据库断言就执行成功了
测试计划添加自定义变量
我们给登录接口添加断言
一个网页登录的账号及密码不可能永远只有一个人可以登录,用户不止一个人,所有这里我们进行断言时,username 不能写死
所有我们就得添加一个自定义变量,在测试计划里面
原来写死的数据
替换后:
断言的时间直接写上这个变量