From 93c5fec349c1aa153bf2e6eba72df777acee55c8 Mon Sep 17 00:00:00 2001 From: Joe Wang Date: Thu, 22 Sep 2016 10:17:19 -0700 Subject: [PATCH] 8166398: CatalogSupport tests need to be fixed Reviewed-by: dfuchs --- .../internal/impl/XMLEntityManager.java | 8 ++-- .../internal/xinclude/XIncludeHandler.java | 21 +++++----- .../jaxp/unittest/catalog/CatalogSupport.java | 21 +++++----- .../jaxp/unittest/catalog/CatalogSupport.xml | 1 + .../unittest/catalog/CatalogSupportBase.java | 38 ++++++------------- .../unittest/catalog/XI_simple4Catalog.xml | 2 +- .../jaxp/unittest/catalog/XI_test2Catalog.xml | 10 +++++ 7 files changed, 46 insertions(+), 55 deletions(-) create mode 100644 jaxp/test/javax/xml/jaxp/unittest/catalog/XI_test2Catalog.xml diff --git a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java index d3b848c9847..5ed41e82fc8 100644 --- a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java +++ b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/XMLEntityManager.java @@ -1033,12 +1033,12 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver { staxInputSource = new StaxXMLInputSource(xmlInputSource, fISCreatedByResolver); } - if (staxInputSource == null) { + if (staxInputSource == null && fUseCatalog) { if (fCatalogFeatures == null) { fCatalogFeatures = JdkXmlUtils.getCatalogFeatures(fDefer, fCatalogFile, fPrefer, fResolve); } fCatalogFile = fCatalogFeatures.get(Feature.FILES); - if (fUseCatalog && fCatalogFile != null) { + if (fCatalogFile != null) { try { if (fCatalogResolver == null) { fCatalogResolver = CatalogManager.catalogResolver(fCatalogFeatures); @@ -1133,12 +1133,12 @@ public class XMLEntityManager implements XMLComponent, XMLEntityResolver { xmlInputSource = fEntityResolver.resolveEntity(resourceIdentifier); } - if (xmlInputSource == null) { + if (xmlInputSource == null && fUseCatalog) { if (fCatalogFeatures == null) { fCatalogFeatures = JdkXmlUtils.getCatalogFeatures(fDefer, fCatalogFile, fPrefer, fResolve); } fCatalogFile = fCatalogFeatures.get(Feature.FILES); - if (fUseCatalog && fCatalogFile != null) { + if (fCatalogFile != null) { /* since the method can be called from various processors, both EntityResolver and URIResolver are used to attempt to find diff --git a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/xinclude/XIncludeHandler.java b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/xinclude/XIncludeHandler.java index 3f5410c1741..5efe85f9410 100644 --- a/jaxp/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/xinclude/XIncludeHandler.java +++ b/jaxp/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/xinclude/XIncludeHandler.java @@ -34,6 +34,8 @@ import com.sun.org.apache.xerces.internal.impl.XMLEntityManager; import com.sun.org.apache.xerces.internal.impl.XMLErrorReporter; import com.sun.org.apache.xerces.internal.impl.io.MalformedByteSequenceException; import com.sun.org.apache.xerces.internal.impl.msg.XMLMessageFormatter; +import com.sun.org.apache.xerces.internal.parsers.XIncludeParserConfiguration; +import com.sun.org.apache.xerces.internal.parsers.XPointerParserConfiguration; import com.sun.org.apache.xerces.internal.util.AugmentationsImpl; import com.sun.org.apache.xerces.internal.util.HTTPInputSource; import com.sun.org.apache.xerces.internal.util.IntStack; @@ -129,8 +131,6 @@ import org.xml.sax.InputSource; public class XIncludeHandler implements XMLComponent, XMLDocumentFilter, XMLDTDFilter { - public final static String XINCLUDE_DEFAULT_CONFIGURATION = - "com.sun.org.apache.xerces.internal.parsers.XIncludeParserConfiguration"; public final static String HTTP_ACCEPT = "Accept"; public final static String HTTP_ACCEPT_LANGUAGE = "Accept-Language"; public final static String XPOINTER = "xpointer"; @@ -1624,12 +1624,12 @@ public class XIncludeHandler includedSource = fEntityResolver.resolveEntity(resourceIdentifier); - if (includedSource == null) { + if (includedSource == null && fUseCatalog) { if (fCatalogFeatures == null) { fCatalogFeatures = JdkXmlUtils.getCatalogFeatures(fDefer, fCatalogFile, fPrefer, fResolve); } fCatalogFile = fCatalogFeatures.get(CatalogFeatures.Feature.FILES); - if (fUseCatalog && fCatalogFile != null) { + if (fCatalogFile != null) { /* Although URI entry is preferred for resolving XInclude, system entry is allowed as well. @@ -1690,14 +1690,11 @@ public class XIncludeHandler if ((xpointer != null && fXPointerChildConfig == null) || (xpointer == null && fXIncludeChildConfig == null) ) { - String parserName = XINCLUDE_DEFAULT_CONFIGURATION; - if (xpointer != null) - parserName = "com.sun.org.apache.xerces.internal.parsers.XPointerParserConfiguration"; - - fChildConfig = - (XMLParserConfiguration)ObjectFactory.newInstance( - parserName, - true); + if (xpointer == null) { + fChildConfig = new XIncludeParserConfiguration(); + } else { + fChildConfig = new XPointerParserConfiguration(); + } // use the same symbol table, error reporter, entity resolver, security manager and buffer size. if (fSymbolTable != null) fChildConfig.setProperty(SYMBOL_TABLE, fSymbolTable); diff --git a/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupport.java b/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupport.java index 792cb13ee89..dc96ce2832e 100644 --- a/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupport.java +++ b/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupport.java @@ -32,7 +32,6 @@ import javax.xml.transform.dom.DOMSource; import javax.xml.transform.sax.SAXSource; import javax.xml.transform.stax.StAXSource; import javax.xml.transform.stream.StreamSource; - import org.testng.annotations.BeforeClass; import org.testng.annotations.DataProvider; import org.testng.annotations.Listeners; @@ -42,7 +41,7 @@ import org.xml.sax.InputSource; /** * @test - * @bug 8158084 8162438 8162442 8166220 + * @bug 8158084 8162438 8162442 8166220 8166398 * @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest * @run testng/othervm -DrunSecMngr=true catalog.CatalogSupport * @run testng/othervm catalog.CatalogSupport @@ -51,7 +50,7 @@ import org.xml.sax.InputSource; * A custom resolver is used whether or not there's a Catalog; * A Catalog is used when there's no custom resolver, and the USE_CATALOG * is true (which is the case by default). - */ +*/ /** * Support Catalog: @@ -177,13 +176,13 @@ public class CatalogSupport extends CatalogSupportBase { */ @DataProvider(name = "data_SAXA") public Object[][] getDataSAX() { - String[] systemIds = {"system.xsd"}; - InputSource[] returnValues = {new InputSource(new StringReader(dtd_systemResolved))}; - MyEntityHandler entityHandler = new MyEntityHandler(systemIds, returnValues, elementInSystem); + String[] systemIds = {"system.dtd"}; return new Object[][]{ {false, true, xml_catalog, xml_system, new MyHandler(elementInSystem), expectedWCatalog}, - {false, true, xml_catalog, xml_system, entityHandler, expectedWResolver}, - {true, true, xml_catalog, xml_system, entityHandler, expectedWResolver} + {false, true, xml_catalog, xml_system, getMyEntityHandler(elementInSystem, systemIds, + new InputSource(new StringReader(dtd_systemResolved))), expectedWResolver}, + {true, true, xml_catalog, xml_system, getMyEntityHandler(elementInSystem, systemIds, + new InputSource(new StringReader(dtd_systemResolved))), expectedWResolver} }; } @@ -209,7 +208,7 @@ public class CatalogSupport extends CatalogSupportBase { */ @DataProvider(name = "data_DOMA") public Object[][] getDataDOM() { - String[] systemIds = {"system.xsd"}; + String[] systemIds = {"system.dtd"}; InputSource[] returnValues = {new InputSource(new StringReader(dtd_systemResolved))}; MyEntityHandler entityHandler = new MyEntityHandler(systemIds, returnValues, elementInSystem); return new Object[][]{ @@ -230,8 +229,8 @@ public class CatalogSupport extends CatalogSupportBase { return new Object[][]{ {false, true, xml_catalog, xml_system, null, expectedWCatalog}, - {false, true, xml_catalog, xml_system, null, expectedWResolver}, - {true, true, xml_catalog, xml_system, null, expectedWResolver} + {false, true, xml_catalog, xml_system, new MyStaxEntityResolver(), expectedWResolver}, + {true, true, xml_catalog, xml_system, new MyStaxEntityResolver(), expectedWResolver} }; } diff --git a/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupport.xml b/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupport.xml index f889ac50a78..63432cb50e8 100644 --- a/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupport.xml +++ b/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupport.xml @@ -15,6 +15,7 @@ + diff --git a/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupportBase.java b/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupportBase.java index 27bf6b4b661..236e5cda0dc 100644 --- a/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupportBase.java +++ b/jaxp/test/javax/xml/jaxp/unittest/catalog/CatalogSupportBase.java @@ -276,7 +276,7 @@ public class CatalogSupportBase { SAXParser parser = getSAXParser(setUseCatalog, useCatalog, catalog); parser.parse(xml, handler); - assertEquals(expected, handler.getResult().trim(), ""); + Assert.assertEquals(handler.getResult().trim(), expected); } /* @@ -287,8 +287,9 @@ public class CatalogSupportBase { XMLReader reader = getXMLReader(setUseCatalog, useCatalog, catalog); reader.setContentHandler(handler); + reader.setEntityResolver(handler); reader.parse(xml); - assertEquals(expected, handler.getResult().trim(), ""); + Assert.assertEquals(handler.getResult().trim(), expected); } /* @@ -300,7 +301,7 @@ public class CatalogSupportBase { parser.parse(new InputSource(new StringReader(xml)), handler); debugPrint("handler.result:" + handler.getResult()); - assertEquals(expected, handler.getResult(), "Catalog support for XInclude"); + Assert.assertEquals(handler.getResult().trim(), expected); } /* @@ -314,8 +315,7 @@ public class CatalogSupportBase { Node node = doc.getElementsByTagName(elementInSystem).item(0); String result = node.getFirstChild().getTextContent(); - - assertEquals(expected, result.trim(), "Catalog support for DOM"); + Assert.assertEquals(result.trim(), expected); } /* @@ -327,7 +327,7 @@ public class CatalogSupportBase { XMLStreamReader streamReader = getStreamReader( setUseCatalog, useCatalog, catalog, xml, resolver); String text = getText(streamReader, XMLStreamConstants.CHARACTERS); - assertEquals(expected, text.trim(), "Catalog support for StAX"); + Assert.assertEquals(text.trim(), expected); } /* @@ -340,7 +340,7 @@ public class CatalogSupportBase { XMLStreamReader streamReader = getStreamReader( setUseCatalog, useCatalog, catalog, xml, resolver); String text = getText(streamReader, XMLStreamConstants.ENTITY_REFERENCE); - assertEquals(expected, text.trim(), "Catalog support for StAX"); + Assert.assertEquals(text.trim(), expected); } /* @@ -601,9 +601,11 @@ public class CatalogSupportBase { } /** - * Returns the text of the first element found by the reader. + * Returns the accumulated text of an event type. + * * @param streamReader the XMLStreamReader - * @return the text of the first element + * @param type the type of event requested + * @return the text of the accumulated text for the request type * @throws XMLStreamException */ String getText(XMLStreamReader streamReader, int type) throws XMLStreamException { @@ -662,24 +664,6 @@ public class CatalogSupportBase { return factory; } - void assertNotNull(Object obj, String msg) { - if (obj == null) { - debugPrint("Test failed: " + msg); - } else { - debugPrint("Test passed: " + obj + " is not null"); - } - } - - void assertEquals(String expected, String actual, String msg) { - if (!expected.equals(actual)) { - debugPrint("Test failed: " + msg); - } else { - debugPrint("Test passed: "); - } - debugPrint("Expected: " + expected); - debugPrint("Actual: " + actual); - } - void fail(String msg) { System.out.println("Test failed:"); System.out.println(msg); diff --git a/jaxp/test/javax/xml/jaxp/unittest/catalog/XI_simple4Catalog.xml b/jaxp/test/javax/xml/jaxp/unittest/catalog/XI_simple4Catalog.xml index af26081369d..dc199c5fad2 100644 --- a/jaxp/test/javax/xml/jaxp/unittest/catalog/XI_simple4Catalog.xml +++ b/jaxp/test/javax/xml/jaxp/unittest/catalog/XI_simple4Catalog.xml @@ -9,7 +9,7 @@ - + diff --git a/jaxp/test/javax/xml/jaxp/unittest/catalog/XI_test2Catalog.xml b/jaxp/test/javax/xml/jaxp/unittest/catalog/XI_test2Catalog.xml new file mode 100644 index 00000000000..62c4ed3d105 --- /dev/null +++ b/jaxp/test/javax/xml/jaxp/unittest/catalog/XI_test2Catalog.xml @@ -0,0 +1,10 @@ + + + + + + + + + +