Fix bug 58760: non-standard namespace-key breaks parsing XLSX files

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1722433 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Dominik Stadler 2015-12-31 09:56:33 +00:00
parent b4c4740f98
commit 4b37b0d47d
4 changed files with 3 additions and 7 deletions

View File

@ -259,9 +259,6 @@ public class TestAllFiles {
// non-TNEF files // non-TNEF files
EXPECTED_FAILURES.add("ddf/Container.dat"); EXPECTED_FAILURES.add("ddf/Container.dat");
EXPECTED_FAILURES.add("ddf/47143.dat"); EXPECTED_FAILURES.add("ddf/47143.dat");
// will be fixed as part of bug 58760
EXPECTED_FAILURES.add("spreadsheet/58760.xlsx");
} }
private static final Set<String> IGNORED = new HashSet<String>(); private static final Set<String> IGNORED = new HashSet<String>();

View File

@ -320,7 +320,7 @@ public final class PackageRelationshipCollection implements
// Check OPC compliance M4.1 rule // Check OPC compliance M4.1 rule
boolean fCorePropertiesRelationship = false; boolean fCorePropertiesRelationship = false;
NodeList nodeList = root.getElementsByTagName(PackageRelationship.RELATIONSHIP_TAG_NAME); NodeList nodeList = root.getElementsByTagNameNS(PackageNamespaces.RELATIONSHIPS, PackageRelationship.RELATIONSHIP_TAG_NAME);
int nodeCount = nodeList.getLength(); int nodeCount = nodeList.getLength();
for (int i = 0; i < nodeCount; i++) { for (int i = 0; i < nodeCount; i++) {
Element element = (Element)nodeList.item(i); Element element = (Element)nodeList.item(i);

View File

@ -377,7 +377,7 @@ public abstract class ContentTypeManager {
Document xmlContentTypetDoc = DocumentHelper.readDocument(in); Document xmlContentTypetDoc = DocumentHelper.readDocument(in);
// Default content types // Default content types
NodeList defaultTypes = xmlContentTypetDoc.getDocumentElement().getElementsByTagName(DEFAULT_TAG_NAME); NodeList defaultTypes = xmlContentTypetDoc.getDocumentElement().getElementsByTagNameNS(TYPES_NAMESPACE_URI, DEFAULT_TAG_NAME);
int defaultTypeCount = defaultTypes.getLength(); int defaultTypeCount = defaultTypes.getLength();
for (int i = 0; i < defaultTypeCount; i++) { for (int i = 0; i < defaultTypeCount; i++) {
Element element = (Element) defaultTypes.item(i); Element element = (Element) defaultTypes.item(i);
@ -387,7 +387,7 @@ public abstract class ContentTypeManager {
} }
// Overriden content types // Overriden content types
NodeList overrideTypes = xmlContentTypetDoc.getDocumentElement().getElementsByTagName(OVERRIDE_TAG_NAME); NodeList overrideTypes = xmlContentTypetDoc.getDocumentElement().getElementsByTagNameNS(TYPES_NAMESPACE_URI, OVERRIDE_TAG_NAME);
int overrideTypeCount = overrideTypes.getLength(); int overrideTypeCount = overrideTypes.getLength();
for (int i = 0; i < overrideTypeCount; i++) { for (int i = 0; i < overrideTypeCount; i++) {
Element element = (Element) overrideTypes.item(i); Element element = (Element) overrideTypes.item(i);

View File

@ -2879,7 +2879,6 @@ public final class TestXSSFBugs extends BaseTestBugzillaIssues {
* ! Rule: Package require content types when retrieving a part from a package. [M.1.14] * ! Rule: Package require content types when retrieving a part from a package. [M.1.14]
*/ */
@Test @Test
@Ignore
public void test58760() throws Exception { public void test58760() throws Exception {
Workbook wb = XSSFTestDataSamples.openSampleWorkbook("58760.xlsx"); Workbook wb = XSSFTestDataSamples.openSampleWorkbook("58760.xlsx");
assertEquals(1, wb.getNumberOfSheets()); assertEquals(1, wb.getNumberOfSheets());