Improve XML to JSON convert logic
Opened this issue · 1 comments
The introducing of #240 brought in an error that it cannot handle simple XML without attributes conversion correctly.
This CR is to improve XML to JSON convert logic to handle XML with or without attributes correctly.
Case 1.1 - simple XML without attributes
<root>
<parent>
<child>123</child>
</parent>
</root>
converted ($.convert(xmlDoc).to(JSONObject.class)
) into
{
"parent": {
"child": 123
}
}
Case 1.2 - simple XML list without attributes
<root>
<parent>
<child>123</child>
</parent>
<parent>
<child>456</child>
</parent>
</root>
converted into
JSON without MERGE_MAP hint:
{
"parent": [
{
"child": 123
},
{
"child": 456
}
]
}
JSON with MERGE_MAP hint ($.convert(xmlDoc).hint(XmlToJson.HINT_MERGE_MAP).to(JSONObject.class)
) turned on:
{
"parent": {
"child": [123, 456]
}
}
Case 1.3 - simple mixed XML list without attributes
<root>
<parent>
<child>123</child>
</parent>
<parent>
<child>456</child>
</parent>
<parent2>
<child>789</child>
</parent2>
<someone>abc</someone>
</root>
converted into
JSON without MERGE_MAP hint:
{
"parent": [
{
"child": 123
},
{
"child": 456
}
],
"parent2": {
"child": 789
},
"someone": "abc"
}
JSON with MERGE_MAP hint turned on
{
"parent": {
"child": [123, 456]
},
"parent2": {
"child": 789
},
"someone": "abc"
}
Case 2.1 - XML with attributes and no text
<root>
<parent>
<child value="123"/>
</parent>
</root>
converted into
{
"parent": {
"child": {
"value": 123
}
}
}
Case three - XML with attributes and value
<root>
<parent>
<child value="123">abc</child>
</parent>
</root>
converted into
{
"parent": {
"child": {
"value": 123,
"innerValue": "abc"
}
}
}
Note
OSGL tool XML to JSON convert tool require at least one ELEMENT type node inside the root node, otherwise it returns an empty JSONObject.
E.g. converting the following xml document will return an empty JSONObject:
<root>abc</root>