前言:利用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编辑框中输入实现代码
[java] view plain copy 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步骤循环,这样就可以遍历数组中的每个数据了
以上是内存溢出为你收集整理的SoapUI用groovy脚本提取json数组数据全部内容,希望文章能够帮你解决SoapUI用groovy脚本提取json数组数据所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)