进行接口功能测试过程当中,常常会碰到,须要获取到上一个请求响应结果中数据,传递到下一个请求中来使用。在soapui中咱们经过Property Transfer来实现。html
右键项目project-->new TestSuite-->new TestCase-->右键Test Steps-->Add step-->Property Transfer数据库
详细参考官方文档:https://www.soapui.org/docs/functional-testing/teststep-reference/property-transfers.html测试
假设咱们有两个接口:登陆、查询用户信息。登陆后响应结果会返回一个token值;查询用户信息时,请求头中需带上这个token值,才能查询成功fetch
1)登陆请求,运行返回结果成功,且返回token值 ui
2)查询用户信息,请求头中添加token值,运行,成功查询到当前登陆用户的信息spa
若是只有以上2步,则每次都得先运行登陆,copy出token值,再粘贴到查询用户信息的请求头,再运行;至关麻烦;所以在以上2步中间,咱们须要插入一个step3d
3)右键loginIn-->Insert Step-->Property Transfer,可是在进行Target设置时,不能直接把值传到user请求头中,因此,先自定义设置一个变量,把token值传递到这个变量,再进行变量引用code
4)右键Test Steps-->Add step-->Properties,而且自定义一个变量名称为tokenxml
5)进行Property Transfer的设置以下,运行后查看Properties中token值获取成功htm
这里$.token表示获取根元素下的token对应的值。JSONPath详细请移步参考http://lemfix.com/topics/63
{ "code": "200", "message": "登陆成功", "token": "40c6d6e2d2a949f6d988c275fd4725ab31b6c14c33c2bbbee0d787b911af58f1" }
6)从上面步骤能够看到token已经获取成功了,怎么传递到查询信息接口的请求头呢?直接${变量名}引用
7)双击TestCase,运行成功
假设如今咱们要从数据库获取某一个用户信息,而后去登陆;soapui发起jdbc请求返回结果默认是xml格式的,这里要用到XPath表达式
1)发起JDBC Request,运行,返回数据库用户信息
2)而后再从JDBC Request的返回结果中,获取到name值进行登陆;这里右键JDBC Request-->Insert Step-->Property Transfer,而后进行以下设置
这里//Results/ResultSet/Row[1]/USER.NAME[1] 中 //表示不考虑Results在文档中的位置,选取Results下的全部ResultSet元素下的第一个Row元素下的第一个USER.NAME元素,因此在这里会取到tudou
XPath详细请移步参考:https://www.w3school.com.cn/xpath/xpath_syntax.asp
<Results> <ResultSet fetchSize="0"> <Row rowNumber="1"> <USER.NAME>tudou</USER.NAME> <USER.PWD>lemon123456</USER.PWD> <USER.AGE>30</USER.AGE> <USER.EMAIL>121313927@qq.com</USER.EMAIL> <USER.PHONE>18866668888</USER.PHONE> </Row> <Row rowNumber="2"> <USER.NAME>yameng</USER.NAME> <USER.PWD>lemon666</USER.PWD> <USER.AGE>30</USER.AGE> <USER.EMAIL>121313928@qq.com</USER.EMAIL> <USER.PHONE>15811112223</USER.PHONE> </Row> </ResultSet> </Results>
3)登陆请求这里,不用作什么设置
4)双击TestCase,运行,查看结果,成功
soapui的关联方式就整理到这,但愿你们学有所用