Apply patch for bug 55864 - XSSFImportFromXML.importFromXML() does not support optional elements

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1633404 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Dominik Stadler 2014-10-21 15:56:45 +00:00
parent 3c37d8f3cd
commit 2e283f2ebf
3 changed files with 157 additions and 108 deletions

View File

@ -97,12 +97,15 @@ public class XSSFImportFromXML {
String xpathString = singleXmlCell.getXpath(); String xpathString = singleXmlCell.getXpath();
Node result = (Node) xpath.evaluate(xpathString, doc, XPathConstants.NODE); Node result = (Node) xpath.evaluate(xpathString, doc, XPathConstants.NODE);
String textContent = result.getTextContent(); // result can be null if value is optional (xsd:minOccurs=0), see bugzilla 55864
logger.log(POILogger.DEBUG, "Extracting with xpath " + xpathString + " : value is '" + textContent + "'"); if (result != null) {
XSSFCell cell = singleXmlCell.getReferencedCell(); String textContent = result.getTextContent();
logger.log(POILogger.DEBUG, "Setting '" + textContent + "' to cell " + cell.getColumnIndex() + "-" + cell.getRowIndex() + " in sheet " logger.log(POILogger.DEBUG, "Extracting with xpath " + xpathString + " : value is '" + textContent + "'");
+ cell.getSheet().getSheetName()); XSSFCell cell = singleXmlCell.getReferencedCell();
cell.setCellValue(textContent); logger.log(POILogger.DEBUG, "Setting '" + textContent + "' to cell " + cell.getColumnIndex() + "-" + cell.getRowIndex() + " in sheet "
+ cell.getSheet().getSheetName());
cell.setCellValue(textContent);
}
} }
for (XSSFTable table : tables) { for (XSSFTable table : tables) {
@ -160,6 +163,7 @@ public class XSSFImportFromXML {
_docElem = doc.getDocumentElement(); _docElem = doc.getDocumentElement();
} }
@Override
public String getNamespaceURI(String prefix) { public String getNamespaceURI(String prefix) {
return getNamespaceForPrefix(prefix); return getNamespaceForPrefix(prefix);
} }
@ -214,11 +218,13 @@ public class XSSFImportFromXML {
} }
// Dummy implementation - not used! // Dummy implementation - not used!
@Override
public Iterator getPrefixes(String val) { public Iterator getPrefixes(String val) {
return null; return null;
} }
// Dummy implementation - not used! // Dummy implementation - not used!
@Override
public String getPrefix(String uri) { public String getPrefix(String uri) {
return null; return null;
} }

View File

@ -37,119 +37,162 @@ public class TestXSSFImportFromXML extends TestCase {
public void testImportFromXML() throws Exception{ public void testImportFromXML() throws Exception{
XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("CustomXMLMappings.xlsx"); XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("CustomXMLMappings.xlsx");
try {
String name = "name"; String name = "name";
String teacher = "teacher"; String teacher = "teacher";
String tutor = "tutor"; String tutor = "tutor";
String cdl = "cdl"; String cdl = "cdl";
String duration = "duration"; String duration = "duration";
String topic = "topic"; String topic = "topic";
String project = "project"; String project = "project";
String credits = "credits"; String credits = "credits";
String testXML = "<CORSO>"+ String testXML = "<CORSO>"+
"<NOME>"+name+"</NOME>"+ "<NOME>"+name+"</NOME>"+
"<DOCENTE>"+teacher+"</DOCENTE>"+ "<DOCENTE>"+teacher+"</DOCENTE>"+
"<TUTOR>"+tutor+"</TUTOR>"+ "<TUTOR>"+tutor+"</TUTOR>"+
"<CDL>"+cdl+"</CDL>"+ "<CDL>"+cdl+"</CDL>"+
"<DURATA>"+duration+"</DURATA>"+ "<DURATA>"+duration+"</DURATA>"+
"<ARGOMENTO>"+topic+"</ARGOMENTO>"+ "<ARGOMENTO>"+topic+"</ARGOMENTO>"+
"<PROGETTO>"+project+"</PROGETTO>"+ "<PROGETTO>"+project+"</PROGETTO>"+
"<CREDITI>"+credits+"</CREDITI>"+ "<CREDITI>"+credits+"</CREDITI>"+
"</CORSO>\u0000"; "</CORSO>\u0000";
XSSFMap map = wb.getMapInfo().getXSSFMapByName("CORSO_mapping"); XSSFMap map = wb.getMapInfo().getXSSFMapByName("CORSO_mapping");
assertNotNull(map); assertNotNull(map);
XSSFImportFromXML importer = new XSSFImportFromXML(map); XSSFImportFromXML importer = new XSSFImportFromXML(map);
importer.importFromXML(testXML); importer.importFromXML(testXML);
XSSFSheet sheet=wb.getSheetAt(0); XSSFSheet sheet=wb.getSheetAt(0);
XSSFRow row = sheet.getRow(0); XSSFRow row = sheet.getRow(0);
assertTrue(row.getCell(0).getStringCellValue().equals(name)); assertTrue(row.getCell(0).getStringCellValue().equals(name));
assertTrue(row.getCell(1).getStringCellValue().equals(teacher)); assertTrue(row.getCell(1).getStringCellValue().equals(teacher));
assertTrue(row.getCell(2).getStringCellValue().equals(tutor)); assertTrue(row.getCell(2).getStringCellValue().equals(tutor));
assertTrue(row.getCell(3).getStringCellValue().equals(cdl)); assertTrue(row.getCell(3).getStringCellValue().equals(cdl));
assertTrue(row.getCell(4).getStringCellValue().equals(duration)); assertTrue(row.getCell(4).getStringCellValue().equals(duration));
assertTrue(row.getCell(5).getStringCellValue().equals(topic)); assertTrue(row.getCell(5).getStringCellValue().equals(topic));
assertTrue(row.getCell(6).getStringCellValue().equals(project)); assertTrue(row.getCell(6).getStringCellValue().equals(project));
assertTrue(row.getCell(7).getStringCellValue().equals(credits)); assertTrue(row.getCell(7).getStringCellValue().equals(credits));
} finally {
wb.close();
}
} }
public void testMultiTable() throws Exception{ public void testMultiTable() throws Exception{
XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("CustomXMLMappings-complex-type.xlsx"); XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("CustomXMLMappings-complex-type.xlsx");
try {
String cellC6 = "c6"; String cellC6 = "c6";
String cellC7 = "c7"; String cellC7 = "c7";
String cellC8 = "c8"; String cellC8 = "c8";
String cellC9 = "c9"; String cellC9 = "c9";
String testXML = "<ns1:MapInfo xmlns:ns1=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" SelectionNamespaces=\"\">" + String testXML = "<ns1:MapInfo xmlns:ns1=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" SelectionNamespaces=\"\">" +
"<ns1:Schema ID=\""+cellC6+"\" SchemaRef=\"a\" />"+ "<ns1:Schema ID=\""+cellC6+"\" SchemaRef=\"a\" />"+
"<ns1:Schema ID=\""+cellC7+"\" SchemaRef=\"b\" />"+ "<ns1:Schema ID=\""+cellC7+"\" SchemaRef=\"b\" />"+
"<ns1:Schema ID=\""+cellC8+"\" SchemaRef=\"c\" />"+ "<ns1:Schema ID=\""+cellC8+"\" SchemaRef=\"c\" />"+
"<ns1:Schema ID=\""+cellC9+"\" SchemaRef=\"d\" />"+ "<ns1:Schema ID=\""+cellC9+"\" SchemaRef=\"d\" />"+
"<ns1:Map ID=\"1\" Name=\"\" RootElement=\"\" SchemaID=\"\" ShowImportExportValidationErrors=\"\" AutoFit=\"\" Append=\"\" PreserveSortAFLayout=\"\" PreserveFormat=\"\">"+ "<ns1:Map ID=\"1\" Name=\"\" RootElement=\"\" SchemaID=\"\" ShowImportExportValidationErrors=\"\" AutoFit=\"\" Append=\"\" PreserveSortAFLayout=\"\" PreserveFormat=\"\">"+
"<ns1:DataBinding DataBindingLoadMode=\"\" />"+ "<ns1:DataBinding DataBindingLoadMode=\"\" />"+
"</ns1:Map>"+ "</ns1:Map>"+
"<ns1:Map ID=\"2\" Name=\"\" RootElement=\"\" SchemaID=\"\" ShowImportExportValidationErrors=\"\" AutoFit=\"\" Append=\"\" PreserveSortAFLayout=\"\" PreserveFormat=\"\">"+ "<ns1:Map ID=\"2\" Name=\"\" RootElement=\"\" SchemaID=\"\" ShowImportExportValidationErrors=\"\" AutoFit=\"\" Append=\"\" PreserveSortAFLayout=\"\" PreserveFormat=\"\">"+
"<ns1:DataBinding DataBindingLoadMode=\"\" />"+ "<ns1:DataBinding DataBindingLoadMode=\"\" />"+
"</ns1:Map>"+ "</ns1:Map>"+
"<ns1:Map ID=\"3\" Name=\"\" RootElement=\"\" SchemaID=\"\" ShowImportExportValidationErrors=\"\" AutoFit=\"\" Append=\"\" PreserveSortAFLayout=\"\" PreserveFormat=\"\">"+ "<ns1:Map ID=\"3\" Name=\"\" RootElement=\"\" SchemaID=\"\" ShowImportExportValidationErrors=\"\" AutoFit=\"\" Append=\"\" PreserveSortAFLayout=\"\" PreserveFormat=\"\">"+
"<ns1:DataBinding DataBindingLoadMode=\"\" />"+ "<ns1:DataBinding DataBindingLoadMode=\"\" />"+
"</ns1:Map>"+ "</ns1:Map>"+
"</ns1:MapInfo>\u0000"; "</ns1:MapInfo>\u0000";
XSSFMap map = wb.getMapInfo().getXSSFMapByName("MapInfo_mapping"); XSSFMap map = wb.getMapInfo().getXSSFMapByName("MapInfo_mapping");
assertNotNull(map); assertNotNull(map);
XSSFImportFromXML importer = new XSSFImportFromXML(map); XSSFImportFromXML importer = new XSSFImportFromXML(map);
importer.importFromXML(testXML); importer.importFromXML(testXML);
//Check for Schema element //Check for Schema element
XSSFSheet sheet=wb.getSheetAt(1); XSSFSheet sheet=wb.getSheetAt(1);
assertEquals(cellC6,sheet.getRow(5).getCell(2).getStringCellValue()); assertEquals(cellC6,sheet.getRow(5).getCell(2).getStringCellValue());
assertEquals(cellC7,sheet.getRow(6).getCell(2).getStringCellValue()); assertEquals(cellC7,sheet.getRow(6).getCell(2).getStringCellValue());
assertEquals(cellC8,sheet.getRow(7).getCell(2).getStringCellValue()); assertEquals(cellC8,sheet.getRow(7).getCell(2).getStringCellValue());
assertEquals(cellC9,sheet.getRow(8).getCell(2).getStringCellValue()); assertEquals(cellC9,sheet.getRow(8).getCell(2).getStringCellValue());
} finally {
wb.close();
}
} }
public void testSingleAttributeCellWithNamespace() throws Exception{ public void testSingleAttributeCellWithNamespace() throws Exception{
XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("CustomXMLMapping-singleattributenamespace.xlsx"); XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("CustomXMLMapping-singleattributenamespace.xlsx");
try {
String id = "a"; String id = "a";
String displayName = "dispName"; String displayName = "dispName";
String ref="19"; String ref="19";
String count = "21"; String count = "21";
String testXML = "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>"+ String testXML = "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>"+
"<ns1:table xmlns:ns1=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" id=\""+id+"\" displayName=\""+displayName+"\" ref=\""+ref+"\">"+ "<ns1:table xmlns:ns1=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" id=\""+id+"\" displayName=\""+displayName+"\" ref=\""+ref+"\">"+
"<ns1:tableColumns count=\""+count+"\" />"+ "<ns1:tableColumns count=\""+count+"\" />"+
"</ns1:table>\u0000"; "</ns1:table>\u0000";
XSSFMap map = wb.getMapInfo().getXSSFMapByName("table_mapping"); XSSFMap map = wb.getMapInfo().getXSSFMapByName("table_mapping");
assertNotNull(map); assertNotNull(map);
XSSFImportFromXML importer = new XSSFImportFromXML(map); XSSFImportFromXML importer = new XSSFImportFromXML(map);
importer.importFromXML(testXML); importer.importFromXML(testXML);
//Check for Schema element //Check for Schema element
XSSFSheet sheet=wb.getSheetAt(0); XSSFSheet sheet=wb.getSheetAt(0);
assertEquals(id,sheet.getRow(28).getCell(1).getStringCellValue()); assertEquals(id,sheet.getRow(28).getCell(1).getStringCellValue());
assertEquals(displayName,sheet.getRow(11).getCell(5).getStringCellValue()); assertEquals(displayName,sheet.getRow(11).getCell(5).getStringCellValue());
assertEquals(ref,sheet.getRow(14).getCell(7).getStringCellValue()); assertEquals(ref,sheet.getRow(14).getCell(7).getStringCellValue());
assertEquals(count,sheet.getRow(18).getCell(3).getStringCellValue()); assertEquals(count,sheet.getRow(18).getCell(3).getStringCellValue());
} finally {
wb.close();
}
}
public void testOptionalFields_Bugzilla_55864() throws Exception {
XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("55864.xlsx");
try {
String testXML = "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>" +
"<PersonInfoRoot>" +
"<PersonData>" +
"<FirstName>Albert</FirstName>" +
"<LastName>Einstein</LastName>" +
"<BirthDate>1879-03-14</BirthDate>" +
"</PersonData>" +
"</PersonInfoRoot>";
XSSFMap map = wb.getMapInfo().getXSSFMapByName("PersonInfoRoot_Map");
assertNotNull(map);
XSSFImportFromXML importer = new XSSFImportFromXML(map);
importer.importFromXML(testXML);
XSSFSheet sheet=wb.getSheetAt(0);
XSSFRow rowHeadings = sheet.getRow(0);
XSSFRow rowData = sheet.getRow(1);
assertEquals("FirstName", rowHeadings.getCell(0).getStringCellValue());
assertEquals("Albert", rowData.getCell(0).getStringCellValue());
assertEquals("LastName", rowHeadings.getCell(1).getStringCellValue());
assertEquals("Einstein", rowData.getCell(1).getStringCellValue());
assertEquals("BirthDate", rowHeadings.getCell(2).getStringCellValue());
assertEquals("1879-03-14", rowData.getCell(2).getStringCellValue());
// Value for OptionalRating is declared optional (minOccurs=0) in 55864.xlsx
assertEquals("OptionalRating", rowHeadings.getCell(3).getStringCellValue());
assertNull("", rowData.getCell(3));
} finally {
wb.close();
}
} }
} }

Binary file not shown.