实战示例

测试场景
  • 电商系统经常会涉及到商品的库存数量的压测,在用户下单前需要先做库存余量的判断,当余量不足时用户无法下单,保证商品的有效售卖
库存余量查询响应结果
  • 响应结果一般是json字符串的形式,响应示例如下:

2、期望获取的结果

通过上面响应结果,想获取参数为periods数组下的period_stock参数值和back_periods数组period_stock参数值。

标注如下:

3、jmeter bea

测试获取建议操作
  • 由于jmeter中beanshell断言中书写代码没有提示(超不方便),不过可提前在IEDA工具中先调试获取结果再复制到beanshell中。
  • IDEA调试结果如下:

然后就只把把代码复制到beanshell中即可。在jmeter中可以打印下获取的库存余量,结果如下:

  • 附测试脚本(当back_periods库存值=0时,beanshell断言生效,可及时查看订单创建数量是否与库存数量一致)
  import org.json.*;
//获取上一个请求的返回值
String response = prev.getResponseDataAsString();
//将返回值转换为json
JSONObject responseJson = new JSONObject(response);
//获取responseMessage
JSONArray data = responseJson.getJSONObject("data").getJSONArray("ticket_periods");
JSONObject ticket_periods = (JSONObject)data.get(0);
JSONObject periods =(JSONObject)(ticket_periods.getJSONArray("periods").get(0));
Integer period_stock = periods.getInt("period_stock");
JSONObject back_periods=(JSONObject)(ticket_periods.getJSONArray("back_periods").get(0));
Integer period_stock_back = back_periods.getInt("period_stock");
log.info("==========获取库存开始===========");
log.info("periods内余量值:" + period_stock);
log.info("back_periods内余量值:" +period_stock_back);
log.info("==========获取库存结束===========");
//beanshell断言
if(period_stock == 0){
Failure = true;
FailureMessage = "period_stock的值:" + period_stock +"警告:已无库存,请注意查看"+ "||period_id的值为:"+period_stock_back+"警告:已无库存,请注意查看";
}
  • 获取所有数组内的参数值,这个需要进行遍历操作



    附遍历代码
public void testCase() throws IOException {
// //将返回值转换为json
// JSONObject responseJson = new JSONObject(str);
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
Map map = objectMapper.readValue(str, Map.class);
Map dataMap = (Map) map.get("data");
List<Map<String, Object>> list = (List<Map<String, Object>>) dataMap.get("ticket_periods");
list.stream().forEach(item ->{
List<Map<String, Object>> periodsList = (List<Map<String, Object>>) item.get("periods");
periodsList.stream().forEach(periods ->{
System.out.println("当前period_stock的值:"+periods.get("period_stock"));
});
});
}

  • 另外使用jmeter的beanshell功能经常会用到以下方式传递变量

    1、在beanshell中如果拿到响应结果的某个值,可以通过赋值方式传入,然后通过变量取值即可
vars.put赋值,格式为 vars.put("key","value")
vars.get 获取变量,vars.get("period_stock")

2、特别说明:如果想把Integer类型通过vars放入的话需要加上toString()方法,上面需要把Integer 类型period_stock作为变量传递,示例

 vars.put("period_stock",period_stock.toString());

其它接口可通过变量名取值:{"period_stock":"${period_stock}"}

传递结果

GET http://127.0.0.1:8080/test

GET data:
{"period_stock":"80"} [no cookies] Request Headers:
Connection: keep-alive
Content-Type: application/json
Content-Length: 21
Host: 127.0.0.1:8080
User-Agent: Apache-HttpClient/4.5.5 (Java/1.8.0_181)
  • 常用变量总结:

    • vars: 实际引用Jmeter线程的局部变量, 连通Jmeter 和 beanshell

      vars.get(String key) //获取变量值

       vars.put(String key, String value) //存储value到变量key
    • log: 写入信息到日志中,log.info(""),括号放置需要的变量
    • prev:获取当前响应结果和响应状态;

       getResponseDataAsString()

       getResponseCode()
    • props:class java.util.Properties

      变量属性复制给变量props.put("some_variable",vars.get("some_variable"))

  • 更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:

记录jmeter使用beanshell断言获取复杂的json字符串参数值的更多相关文章

  1. JMeter之BeanShell断言---获取时间戳

    1.创建线程组,创建一个BeanShell Sampler,在其中编写BeanShell脚本. 2.在Jmeter中,可以利用${__time(,)}时间戳函数来获取十位的时间戳,如: vars.pu ...

  2. jmeter之beanshell断言---数据处理

    在做接口测试时,对响应数据的校验是非常重要的部分:在使用Jmeter进行接口测试时,有多种respone校验方式,比如响应断言.BeanShell断言等等,BeanShell断言可以自定义断言,自由灵 ...

  3. Jmeter之BeanShell断言使用

    1.Bean Shell常用内置变量 JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互,其中主要的变量及其使用方法如下: log:用来记录日志文件,写入到j ...

  4. 『动善时』JMeter基础 — 31、JMeter中BeanShell断言详解

    目录 1.BeanShell简介 2.Beanshell的内置变量和方法 3.BeanShell断言界面详解 4.BeanShell断言的使用 (1)测试计划内包含的元件 (2)登陆接口请求界面内容 ...

  5. JMeter中BeanShell断言使用一

    Jmeter Ant Task如何让beanshell断言失败的详细信息展示在report里面 首先必须给beanshell断言添加FailureMessage if(${TotalClient_SS ...

  6. jmeter之beanshell断言实例

    .首先储存一个接口的响应结果,比如在http请求的后面添加beanshell后置处理器(BeanShell PostProcessor)来储存http请求的响应结果: import org.json. ...

  7. jmeter使用BeanShell断言

    1. 首先存储一个接口的响应结果,如在http请求的BeanShell PostProcessor: import java.io.UnsupportedEncodingException; Syst ...

  8. Jmeter之BeanShell 断言

    作者:季沐测试笔记 原文地址:https://www.cnblogs.com/testero/p/15436864.html 博客主页:https://www.cnblogs.com/testero ...

  9. Jmeter通过BeanShell Sampler获取Jmeter的Bin路径,并存入变量供后面的脚本调用

    Jmeter的Bin路径是其运行路径,当把自动化测试的脚本放在Bin目录下时,为了将存储CSV的数据文件以及脚本的路径都设置成相对路径,我们需要获取到Jmeter的运行路径: 通过BeanShell ...

随机推荐

  1. 尝试写一写4gl与4fd

    4gl DATABASE ds   GLOBALS "../../config/top.global"   DEFINE g_curs_index           LIKE t ...

  2. Java 接口简述

    Java 接口 接口(英文:Interface),在JAVA编程语言中是一个抽象类型,是抽象方法的集合,接口通常以interface来声明.一个类通过继承接口的方式,从而来继承接口的抽象方法. 接口并 ...

  3. LR与LR?

    目录 逻辑回归与线性回归 逻辑回归 1.建立目标函数 2. 梯度求解 3. 实现 线性回归 1. 建立目标函数 2. 求解 3. 实现 逻辑回归与交叉熵 逻辑回归与线性回归 逻辑回归 线性回归 目标函 ...

  4. python sqlite3简单操作

    python sqlite3简单操作(原创)import sqlite3class CsqliteTable: def __init__(self): pass def linkSqlite3(sel ...

  5. Min Cost Climbing Stairs [746]

    Min Cost Climbing Stairs [746] 题目描述 简单来说就是:要跳过当前楼梯需要花费当前楼梯所代表的价值cost[i], 花费cost[i]之后,可以选择跳一阶或者两阶楼梯,以 ...

  6. Android开发之SDCardUtils工具类。java工具详细代码,附源代码。判断SD卡是否挂载等功能

    package com.xiaobing.zhbj.utils; import java.io.BufferedInputStream; import java.io.BufferedOutputSt ...

  7. java生成四位随机数,包含数字和字母 区分大小写,特别适合做验证码,android开发

    private String generateWord() { String[] beforeShuffle = new String[] { "2", "3" ...

  8. Forward Rendering VS Deferred Rendering

    http://gad.qq.com/article/detail/32731 Forward Rendering Deferred Rendering

  9. jkd1.8 stream

    目录 Stream 创建流 通过集合创建,例如Map (常用) 通过数组方式创建 通过Stream静态方法创建 中间操作 筛选和切片 filter limit skip distinct 映射 map ...

  10. java 注解开发

    目录 注解 JDK自带的注解三个 注解分类 按照运行机制 按照来源分类 自定义注解的语法要求 元注解 解析注解 获取注解的注解 Spring中的注解 组合注解 注解 JDK自带的注解三个 @Overr ...