SoapUI用groovy脚本提取json数组数据
来源:互联网 发布:冰川网络客服 编辑:程序博客网 时间:2024/05/18 21:44
SOAPUI 中如何用Groovy 读取数据
前言:利用SoapUI进行数据源驱动测试,如果数据源是固定的,使用DataSource方法读取xls文件中的数据是很方便的,但是如果数据源不是固定的,需要从接口返回中的数据中动态获取的,这时就得动态去获取返回值的数据了。
在android中json数组数据是比较常见的,如先请求一组数据得到新闻列表,当点击列表中的新闻时,再根据ID去请求新闻正文。
例如如下数据,calendar_id是需要根据返回值动态获取的,此时需要通过获得数组中的calendar_id
{"calendar":
[
{"calendar_id":"1705","showtime":"1288927800","endshowtime":"1288931400","allDay":false},
{"calendar_id":"1706","showtime":"1288933200","endshowtime":"1288936800","allDay":false},
{"calendar_id":"1709","showtime":"1288935600","endshowtime":"1288938900","allDay":false}
]
}
在SoapUI中可以通过groovy脚本实现提取json数组数据,提取到数据后就可以遍历访问列表中的每条新闻正文了
1.新建一个REST请求步骤,获取接口返回的数据
2.新建一个DataSource步骤,选择Groovy方式
3.添加一个名为cal_id的Properties
4.groovy编辑框中输入实现代码
- import groovy.json.JsonSlurper
- def xresponse = testRunner.testCase.testSteps["getCalendarListByCoid"].testRequest.response.contentAsString
- def slurper = new JsonSlurper()
- def re = slurper.parseText(xresponse)
- def num=re.calendar.size()
- def i = testRunner.testCase.testSteps["DataSource"].currentRow
- if(i<num)
- {
- result["cal_id"]=String.valueOf(re.calendar_id.id[i])
- }
5.新建一个Property Transfer步骤,将DataSource的cal_id传递给当前testCase的变量
6.新建 一个REST请求步骤,将得到的cal_id去请求另一个接口
7.新建一个DataSource Loop步骤,使DataSource与Property Transfer步骤循环,这样就可以遍历数组中的每个数据了
你好
以博文中的json为例,新增的groovy步骤则如下:
def xresponse = testRunner.testCase.testSteps["getCalendarListByCoid"].testRequest.response.contentAsString
def slurper = new JsonSlurper()
def re = slurper.parseText(xresponse)
def id = re.calendar.calendar_id[i] //i为json数组中的第i个子json对象
若为在脚本断言处添加groovy断言,则如下:
def xresponse = messageExchange.modelItem.testCase.testSteps["getCalendarListByCoid"].testRequest.response.contentAsString
def slurper = new JsonSlurper()
def result = slurper.parseText(xresponse)
def id = re.calendar.calendar_id[i] //i为json数组中的第i个子json对象
如需知道更加详细的内容,请在百度阅读输入SOAPUI 就可以找到
- SoapUI用groovy脚本提取json数组数据
- SoapUI用groovy脚本提取json数组数据
- SoapUI中使用Groovy脚本操作数据库 .
- SoapUI中使用Groovy脚本操作数据库
- SoapUI自动化--Groovy脚本常用操作
- SoapUI中使用Groovy脚本操作数据库
- 【SoapUI】在soapui中使用Groovy脚本常用方法
- SoapUI自动化--Groovy脚本实现随机抽取DataSource(Excel)
- SoapUI利用Groovy把外部数据加载到request中
- SoapUI利用Groovy把外部数据加载到request中
- Groovy and SoapUI
- SoapUI + Groovy 接口自动化
- SoapUI Groovy Script
- .net 提取 json 数据
- json数据提取
- soapUI(groovy脚本作用1)请不要问为什么系列1
- SOAPUI 接口自动化学习笔记节选 如何用Groovy 脚本读取CSV 文件
- SOAPUI 接口自动化学习笔记节选 如何用Groovy 脚本读取CSV 文件
- oom(4)LeakCanary和eventbus的使用总结
- 【Android实测】取系统信息
- The application's PagerAdapter changed the adapter's contents without calling PagerAdapter#notifyDat
- jersey框架发送图片到另一台服务器
- 小程序
- SoapUI用groovy脚本提取json数组数据
- extern "c"用法解析
- PHP判断当前是否utf-8
- Android 常用参考文档
- SoapUI命令行方式运行
- 极光IM简单的聊天测试
- 基于STM8的小型操作系统
- LeetCode91. Decode Ways
- PHP检查是否BOM头