diff options
author | jsdelfino <jsdelfino@13f79535-47bb-0310-9956-ffa450edef68> | 2012-02-27 03:26:51 +0000 |
---|---|---|
committer | jsdelfino <jsdelfino@13f79535-47bb-0310-9956-ffa450edef68> | 2012-02-27 03:26:51 +0000 |
commit | a07d4945c1a301aeaf4b67411065b9adcfac1065 (patch) | |
tree | c605de13425e7ecdcd8ee4c941a8ce97a881731a /sca-cpp/trunk/kernel/xml-test.cpp | |
parent | edc083d8056557814691d49d45b56f8244558bae (diff) |
Fix mapping between repeating XML elements, S-expression lists, and JSON array cells.
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1294006 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'sca-cpp/trunk/kernel/xml-test.cpp')
-rw-r--r-- | sca-cpp/trunk/kernel/xml-test.cpp | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/sca-cpp/trunk/kernel/xml-test.cpp b/sca-cpp/trunk/kernel/xml-test.cpp index 7149d1bc41..c505cae9cf 100644 --- a/sca-cpp/trunk/kernel/xml-test.cpp +++ b/sca-cpp/trunk/kernel/xml-test.cpp @@ -73,6 +73,35 @@ const string customerXML = " </account>\n" "</customer>\n"; +const string abcXML = +"<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" +"<a>\n" +" <m>abc</m>\n" +" <m>def</m>\n" +" <m>xyz</m>\n" +" <m>tuv</m>\n" +"</a>\n"; + +const string xyzXML = +"<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" +"<a>\n" +" <m>\n" +" <id>123</id>\n" +" <name>abc</name>\n" +" </m>\n" +" <m>\n" +" <id>234</id>\n" +" <name>def</name>\n" +" </m>\n" +" <m>\n" +" <id>345</id>\n" +" <name>xyz</name>\n" +" </m>\n" +" <m>\n" +" <id>456</id>\n" +" <name>tuv</name>\n" +" </m>\n" +"</a>\n"; const bool isName(const value& token) { return isTaggedList(token, attribute) && attributeName(token) == "name"; @@ -145,6 +174,24 @@ bool testElements() { } } { + istringstream is(abcXML); + const list<value> c = readXML(streamList(is)); + const list<value> v = elementsToValues(c); + const list<value> e = valuesToElements(v); + ostringstream os; + writeXML<ostream*>(xmlWriter, &os, e); + assert(str(os) == abcXML); + } + { + istringstream is(xyzXML); + const list<value> c = readXML(streamList(is)); + const list<value> v = elementsToValues(c); + const list<value> e = valuesToElements(v); + ostringstream os; + writeXML<ostream*>(xmlWriter, &os, e); + assert(str(os) == xyzXML); + } + { istringstream is(customerXML); const list<value> c = readXML(streamList(is)); const list<value> v = elementsToValues(c); |