Reputation: 2595
I' am having some problems retrieving language localizations for teststep. I created the XML document down here and I want to have just <EN>Common Test</EN> <DE>Allgemeiner Test</DE>
elemnt values to be returned or just DE or EN
. If I have a NodeList
out of TESTSTEP
and I get the child nodes, I also get the language elements from the TEST
element, but I only want to have one language element from the TESTSTEP
element. How can I achieve this using DOM
?
<?xml version="1.0" encoding="ISO-8859-1" standalone="no"?>
<DSCT2C>
<TESTSTEPS APPLICATION="UGS">
<TESTSTEP ORDER_NUMBER="0">
<EN>Common Test</EN>
<DE>Allgemeiner Test</DE>
<TEST ORDER_NUMBER="0" NEED_FUNCTION="true" FUNCTION_NAME="functionName">
<DESCRIPTION>
<DE>Hallo</DE>
<EN>Hello</EN>
</DESCRIPTION>
<FILES>
<FILE>test.prt</FILE>
<FILE>test.drw</FILE>
</FILES>
</TEST>
<TEST ORDER_NUMBER="1" NEED_FUNCTION="false">
<DESCRIPTION>
<DE>Hallo2</DE>
<EN>Hello2</EN>
</DESCRIPTION>
<FILES>
</FILES>
</TEST>
</TESTSTEP>
</TESTSTEPS>
</DSCT2C>
EDIT: I found a solution by myself and it was quite simply ;) :
public String getTestStepDescription(String langCode, Integer orderNumber)
{
NodeList list = documentTest.getElementsByTagName(XmlElements.TESTSTEP.toString());
for (int i = 0; i < list.getLength(); i++)
{
Element e = (Element) list.item(i);
if (e.getAttribute(XmlAttributes.ORDER_NUMBER.toString()).equals(orderNumber.toString()))
{
NodeList neu = e.getElementsByTagName(langCode.toUpperCase());
for(int j = 0; j < neu.getLength(); j++)
{
Element e2 = (Element) neu.item(j);
if(e2.getParentNode().getNodeName().equals(XmlElements.TESTSTEP.toString()))
{
return neu.item(j).getFirstChild().getNodeValue();
}
}
}
}
return "ERROR_NO_TESTSTEP_DESC";
}
Upvotes: 0
Views: 1127
Reputation: 5366
Try this method.
public ArrayList<String> readXML(String xmlString, String elementName,
String textContent) {
ArrayList<String> resultValues = new ArrayList<String>();
try {
boolean elementNameFlag = false, nodenameFlag = false;
DocumentBuilder dbFactory = DocumentBuilderFactory.newInstance()
.newDocumentBuilder();
InputSource is = new InputSource();
is.setCharacterStream(new StringReader(xmlString));
Document doc = dbFactory.parse(is);
NodeList list = doc.getElementsByTagName("*");
String rootNodeName = doc.getDocumentElement().getNodeName();
if (elementName == rootNodeName || textContent == rootNodeName) {
gl.writeWarning("elementName or nodeName should not be root name");
} else {
for (int i = 0; i < list.getLength(); i++) {
Element element = (Element) list.item(i);
if (elementName == element.getNodeName()) {
elementNameFlag = true;
}
if (textContent == element.getNodeName()) {
nodenameFlag = true;
}
}
if (elementNameFlag == nodenameFlag) {
doc.getDocumentElement().normalize();
NodeList nList = doc.getElementsByTagName(elementName);
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
resultValues
.add(getTagValue(textContent, eElement));
}
}
} else {
}
}
} catch (Exception e) {
e.printStackTrace();
}
return resultValues;
}// readXML()
call like
objectname.readXML(xmlString,"TESTSTEP","EN")
Upvotes: 1