SoapUI常用的参数化方法

时间:2024-03-08 21:02:50

  本篇文章来讲一下SoapUI在使用中常用的参数化方法字段参数化和使用DataSource调用Excel中的

数据给接口参数化,其中DataSource功能SoapUI开源版没有,大家可以使用破解版,

破解地址:https://www.cnblogs.com/Sweettesting/p/11399534.html

一、准备工作

  为了方便大家上手实操,本次我们使用公用的WEB服务。

  

公用事业:国内飞机航班时刻表 WEB 服务
Endpoint:http://ws.webxml.com.cn/webservices/DomesticAirline.asmx 
Disco:http://ws.webxml.com.cn/webservices/DomesticAirline.asmx?disco 
WSDL:http://ws.webxml.com.cn/webservices/DomesticAirline.asmx?wsdl

  关于接口方法“getDomesticAirlinesTime”的介绍:

输入参数:startCity = 出发城市(中文城市名称或缩写、空则默认:上海);

     lastCity = 抵达城市(中文城市名称或缩写、空则默认:北京);

     theDate = 出发日期(String 格式:yyyy-MM-dd,如:2007-07-02,空则默认当天);

     userID = 商业用户ID(免费用户不需要)


返回数据:DataSet,Table(0)结构为 Item(Company)航空公司、

     Item(AirlineCode)航班号、Item(StartDrome)出发机场、

     Item(ArriveDrome)到达机场、Item(StartTime)出发时间、

     Item(ArriveTime)到达时间、Item(Mode)机型、

     Item(AirlineStop)经停、Item(Week)飞行周期(星期)

二、参数化之Properties

  Property 是一个命名的字符串可以被 Groovy Script,Property Transfer 或者 Property-Expansion 引用,目前所有的变量均被处理为字符串。

SoapUI允许在项目的各个层次中定义变量,常用的层次包括: Project,TestSuite,TestCase,Global等。

官方文档:https://www.soapui.org/docs/functional-testing/teststep-reference/properties.html

  1.首先,我们New Soap Project,新建一个Soap接口项目,命名为DomesticAirline

 

  2.我们鼠标双击Request1,依据接口方法要求输入入参,测试一下此接口的正确性

  3.为Request1新增一个TestCase,命名为“获取航班时刻表”,此时会发现之前我们测试接口的入参数据跟着带入进来

  4.右键Test Steps>>>Add Step>>>Properties,然后添加需要进行参数化的变量,变量名自定义为startCity、lastCity、theDate,填写对应的Value

  5.双击“获取航班时刻表”请求,对请求中的参数进行变量引用,格式:${#Properties#变量名}

第一个#后定义哪个级别的属性变量,第二个#后定义属性名称。REST类接口请求同理。

 

  6.双击TestCase1,点击绿色三角图标运行请求,进度条绿色表示请求通过。在TestCase Log中双击Step可以查看运行结果。

 三、参数化之DataSource

对于DataSource工具栏中各项属性的含义,大家可以阅读官方文档:https://www.soapui.org/docs/data-driven-tests/reference/datasources.html

DataSource Type:

  a.本次我们使用DataSource调用Excel中的数据给接口参数化,先准备Excel文件,内容如下:

这里要注意,入参theDate的值要使用文本格式,不然SoapUI会读取出错。

  b.右键Test Steps-->Add Step-->DataSource,添加变量名startCity、lastCity、theDate,

DataSource选择Excel,Configuration配置见图解。

  c.配置好DataSource,接下来在接口中进行参数化,如起始城市${DataSource#startCity},其它参数同理

 

  d.此时,我们需要遍历DataSource中的所有内容,这里就要用到DataSource Loop这个步骤。

右键Test Steps-->Add Step-->DataSource Loop,设置DataSource Loop的数据来源、Target step

  e.调整Test Steps的顺序,正确的步骤应当是“数据源>>>请求>>>数据源循环”,

双击TestCase1,运行,我们可以看到Excel的数据均被调用。