SoapUI中XML解析
From http://www.robert-nemet.com/2011/11/groovy-xml-parsing-in-soapui.html
Introduction
Since soapUI allows users to add Groovy scripts in large number of
places ( property expansions, setup /teardown scripts, listeners, test
step, etc... ) users can use any technology to reach to the goal. Lets
look at those which can make our life easier when it comes to XML
parsing.
soapUI XML Support
Old way would be soapUI way or using GroovyUtils from soapUI. Its goal is to simplify scripting and it can be instantiate from any Groovy script in soapUI, with:
where context is available in any Groovy script in soapUI. Lets look at GroovyUtils:
def groovyUtils = new com.eviware.soapui.support.GroovyUtils( context )
| GroovyUtils Methods | |
|---|---|
| expand(property)  | returns value of property, if there are property expansions they are expanded. | 
| extractErrorLineNumber(error) | returns line number where error occurred | 
| 
getProjectPath()  | returns path to project file | 
| 
getXml(node) | returns xml as a string from passed node | 
| getXmlHolder(xmlPropertyOrString) | returns XmlHolder as a result of parsing passed Xml string | 
| registerJdbcDriver(driver) | register JDBC driver for use in Groovy script | 
| setPropertyValue(testStep, property, value) | sets a value for given test step property | 
This time getXmlHolder is one that does what we need. Pars a given string as XML and returns object which we can use to manipulate with it.
| XmlHolder Methods | |
|---|---|
| declareNamespace(prefix, uri) | declare namespace prefix and URI | 
| getDomNode(xpath) | returns a DOM node pointed by XPath expression | 
| getDomNodes(xpath) | returns an array of DOM nodes pointed by XPath expression | 
| getNamespaces() | returns a Map of namespaces | 
| getNodeValue(xpath) | returns a value of node specified by XPath expression | 
| getNodeValues(xpath) | returns an array of values specified by XPath expression | 
| getPrettyXml() | returns a formatted XML | 
| getXml() | returns a XML | 
| getXmlObject() | returns a XmlBean Object | 
| removeDomNodes(xpath) | removes a nodes specified by XPath expression | 
| setNodeValue(xpath, value) | set a node value | 
| updateProperty() | if a XmlHolder is created from test step property this updates that property | 
| updateProperty(prettyPrint)
 | if a XmlHolder is created from test step property this updates that property with well formatted XML | 
Few Examples
Assume you have response:
For this examples I added a Properties Test Step with property response.
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:sim="http://www.example.org/SimpleSocialSOA/">
<soapenv:Header/>
<soapenv:Body>
<sim:LoginResponse>
<id>4456643453</id>
</sim:LoginResponse>
</soapenv:Body>
</soapenv:Envelope>
1. Parsing XML
According to that to get id from response you can do:
def groovyUtils = new com.eviware.soapui.support.GroovyUtils( context )
def holder = groovyUtils.getXmlHolder("Properties#response")
log.info holder.getNodeValue("//id")
log.info holder['//id']
notice two ways to get node value with getNodeValue method and with [] operator. Difference is that getNodeValue will return first value that can be found with set XPath, while [] operator returns a array of values.
If you assume that response is like:
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:sim="http://www.example.org/SimpleSocialSOA/">
<soapenv:Header/>
<soapenv:Body>
<sim:LoginResponse>
<id>4456643453</id>
<id>4456643452</id>
<id>4456643451</id>
<id>4456643450</id>
</sim:LoginResponse>
</soapenv:Body>
</soapenv:Envelope>
Than this script:
def groovyUtils = new com.eviware.soapui.support.GroovyUtils( context )
def holder = groovyUtils.getXmlHolder("Properties#response")
log.info holder.getNodeValue("//id")
for( node in holder['//id'] )
log.info node
will produce result like this:

2. Updating XML
Response as above and we do:
def groovyUtils = new com.eviware.soapui.support.GroovyUtils( context )
def holder = groovyUtils.getXmlHolder("Properties#response")
holder.setNodeValue("//id", "aaaaa")
for( node in holder['//id'] )
log.info node
def holder2 = groovyUtils.getXmlHolder("Properties#response")
holder2.getNodeValue("//id")
for( node in holder2['//id'] )
log.info node
Result is:

from this we can learn:
- if there are several nodes as result of XPath expression only first's node value will be changed with setNodeValue
- setting node value is not enough to update property value, we forgot to use updateProperty method
def groovyUtils = new com.eviware.soapui.support.GroovyUtils( context )
def holder = groovyUtils.getXmlHolder("Properties#response")
holder.setNodeValue("//id", "aaaaa")
for( node in holder['//id'] )
log.info node
holder.updateProperty()
def holder2 = groovyUtils.getXmlHolder("Properties#response")
holder2.getNodeValue("//id")
for( node in holder2['//id'] )
log.info node
Instead of using:
holder.setNodeValue("//id", "aaaaa")
you can use also:
holder["//id"] = "aaaaa"
And if XmlNode is created from property as in example above use updateProperty method to apply your changes to property or use GroovyUtils.setPropertyValue method.
Groovy XML
There are three classes built in Groovy for processing XML: XMLParser, XMLSlurper and DOMCategory. Best practice is to use XMLSlurper in
 soapUI. Reason is that it have smallest memory footprint from all
three. I would no go in depths for those, you can read here XML processing.
This for example:
import groovy.xml.StreamingMarkupBuilder
def response = context.testCase.testSteps['Properties'].properties['response'].value
def responseXml = new XmlSlurper().parseText(response)
responseXml.breadthFirst().each {
def v = it.toString()
if ( it.name() == 'id')
it.replaceBody("$v XX")
}
appends " XX" to values of all id nodes.
Generally it is easier to use GroovyUtils but if you are familiar or invest some time in XmlSlurper you can get better results and more flexible scripts.
SoapUI中XML解析的更多相关文章
- 2016 - 1- 23 iOS中xml解析  (!!!!!!!有坑要解决!!!!!!)
		一: iOS中xml解析的几种方式简介 1.官方原生 NSXMLParser :SAX方式解析,使用起来比较简单 2.第三方框架 libxml2 :纯C 同时支持DOM与SAX GDataXML: D ... 
- Android中XML解析-Dom解析
		Android中需要解析服务器端传过来的数据,由于XML是与平台无关的特性,被广泛运用于数据通信中,有的时候需要解析xml数据,格式有三种方式,分别是DOM.SAX以及PULL三种方式,本文就简单以D ... 
- Android中XML解析-SAX解析
		昨天由于时间比较匆忙只写了Android中的XML解析的Dom方式,这种方式比较方便,很容易理解,最大的不足就是内容多的时候,会消耗内存.SAX(Simple API for XML)是一个解析速度快 ... 
- Android中XML解析-PULL解析
		前面写了两篇XML解析的Dom和SAX方式,Dom比较符合思维方式,SAX事件驱动注重效率,除了这两种方式以外也可以使用Android内置的Pull解析器解析XML文件. Pull解析器的运行方式与 ... 
- Android中XML解析,保存的三种方法
		简单介绍 在Android开发中,关于XML解析有三种方式,各自是: SAX 基于事件的解析器.解析速度快.占用内存少.非常适合在Android移动设备中使用. DOM 在内存中以树形结构存放,因此检 ... 
- Android中XML解析
		package com.example.thebroadproject; public class Book { private int id; private String name; privat ... 
- xml解析----java中4中xml解析方法(转载)
		转载:https://www.cnblogs.com/longqingyang/p/5577937.html 描述 XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与 ... 
- cocos2d-x 中XML解析与数据存储
		一不小心就玩了一周的游戏了.哎.玩的时候时间过得总是这么快... 于是今天决定看一下之前不怎么非常熟悉的XML;(之前做游戏时数据的储存用到过XML,但这块是还有一个同事在做,所以不怎么熟悉), 看了 ... 
- C# 将XML格式字符串,写入数据集的表中 XML解析
		将XML格式字符串,写入数据集的表1中 命名空间:using System.Xml; string strRead;//strRead为以下xml值 ... 
随机推荐
- Hadoop的配置过程(虚拟机中的伪分布模式)
			1引言 hadoop如今已经成为大数据处理中不可缺少的关键技术,在如今大数据爆炸的时代,hadoop给我们处理海量数据提供了强有力的技术支撑.因此,了解hadoop的原理与应用方法是必要的技术知识. ... 
- (转)用JUnit4进行单元测试
			场景:从开始写代码至今,对于单元测试一直没有重视,但是也厌倦了了程序中的额System.out和log日志输出.单元测试使我看到了在开发过程中的安全性和便捷性,所以下决心好好整理下. 有感而发——&l ... 
- 读书笔记_MVC__关于通过js构建ORM,实现Model层
			最近一直在学习MVC构建富应用的WEB程序,自己一直对MVC的设计模式理解的不是十分透彻,终于在研读了github上Spine的源码之后,对构建Model层有了一点自己的理解. 本文仅为个人理解,如有 ... 
- [IB]PeopleSoft异步详细信息中状态“已完成”但订阅合同状态“新建”问题
			最近遇到一个IB异步程序状态不一致问题,异步详细信息中上面的状态是“DONE”但是订阅合同中还是“新建”状态.在域状态中清除域状态也不管用. 重启app server也不好使.最后执行了appmsgp ... 
- 主流页面编辑器比对:TinyMCE VS FCKeditor
			开发中先用的是 FCKeditor 编辑器,感觉页面展示的东西太繁琐,所以换了 TinyMCE 编辑器. 为了方便理解,本文不采用穿插比对 先看 FCKeditor : 1.jsp :结束标签不能贴着 ... 
- YII2 添加全局自定义函数
			方法一: 这种方法就是直接在入口文件web/index.php里面写函数,示例代码如下: 全局函数 function pr($var){ //do something } (new yii\web\A ... 
- docker在Centos上的安装
			Centos6安装docker 系统:centos6.5 内核:3.10.107-1(已升级),docker对RHEL/Centos的最低内核支持是2.6.32-431,epel源的docker版本推 ... 
- Python处理csv文件
			Python处理csv文件 CSV(Comma-Separated Values)即逗号分隔值,可以用Excel打开查看.由于是纯文本,任何编辑器也都可打开.与Excel文件不同,CSV文件中: 值没 ... 
- 办公楼[POI2007]
			题目描述 FGD开办了一家电话公司.他雇用了N个职员,给了每个职员一部手机.每个职员的手机里都存储有一些同事的电话号码.由于FGD的公司规模不断扩大,旧的办公楼已经显得十分狭窄,FGD决定将公司迁至一 ... 
- 获取本机IP(适用于Linux系统)
			获取本机IP(适用于Linux系统) /** * @desc 获取本机IP(适用于Linux系统) * @return Ip */ public static String getLocalIP() ... 
