diff --git a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6350682.java b/test/jaxp/javax/xml/jaxp/unittest/common/Bug6350682.java index aca1dcfe11a..c1706bf80dc 100644 --- a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6350682.java +++ b/test/jaxp/javax/xml/jaxp/unittest/common/Bug6350682.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,12 +23,10 @@ package common; -import static jaxp.library.JAXPTestUtilities.runWithAllPerm; - import javax.xml.parsers.SAXParserFactory; import javax.xml.transform.TransformerFactory; -import javax.xml.transform.TransformerFactoryConfigurationError; +import static jaxp.library.JAXPTestUtilities.runWithAllPerm; import org.testng.Assert; import org.testng.annotations.Listeners; import org.testng.annotations.Test; @@ -46,32 +44,22 @@ public class Bug6350682 { @Test public void testSAXParserFactory() { - try { - runWithAllPerm(() -> Thread.currentThread().setContextClassLoader(null)); - if (Bug6350682.class.getClassLoader() == null) - System.out.println("this class loader is NULL"); - else - System.out.println("this class loader is NOT NULL"); - SAXParserFactory factory = SAXParserFactory.newInstance(); - Assert.assertTrue(factory != null, "Failed to get an instance of a SAXParserFactory"); - } catch (Exception e) { - e.printStackTrace(); - Assert.fail("Exception occured: " + e.getMessage()); + // This test run in othervm so change in environment need not to be recovered at the end of test. + runWithAllPerm(() -> Thread.currentThread().setContextClassLoader(null)); + if (Bug6350682.class.getClassLoader() == null) { + System.out.println("this class loader is NULL"); + } else { + System.out.println("this class loader is NOT NULL"); } + SAXParserFactory factory = SAXParserFactory.newInstance(); + Assert.assertNotNull(factory, "Failed to get an instance of a SAXParserFactory"); } @Test public void testTransformerFactory() { - try { - runWithAllPerm(() -> Thread.currentThread().setContextClassLoader(null)); - TransformerFactory factory = TransformerFactory.newInstance(); - Assert.assertTrue(factory != null, "Failed to get an instance of a TransformerFactory"); - } catch (Exception e) { - e.printStackTrace(); - Assert.fail("Exception occured: " + e.getMessage()); - } catch (TransformerFactoryConfigurationError error) { - error.printStackTrace(); - Assert.fail(error.toString()); - } + // This test run in othervm so change in environment need not to be recovered at the end of test. + runWithAllPerm(() -> Thread.currentThread().setContextClassLoader(null)); + TransformerFactory factory = TransformerFactory.newInstance(); + Assert.assertNotNull(factory, "Failed to get an instance of a TransformerFactory"); } } diff --git a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6723276Test.java b/test/jaxp/javax/xml/jaxp/unittest/common/Bug6723276Test.java index f254c28ee49..721e25a11c1 100644 --- a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6723276Test.java +++ b/test/jaxp/javax/xml/jaxp/unittest/common/Bug6723276Test.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,14 +23,15 @@ package common; -import org.testng.annotations.Listeners; -import org.testng.annotations.Test; -import org.testng.Assert; import java.net.URL; import java.net.URLClassLoader; import javax.xml.parsers.SAXParserFactory; +import org.testng.Assert; +import org.testng.annotations.Listeners; +import org.testng.annotations.Test; + /* * @test * @bug 6723276 @@ -41,27 +42,28 @@ import javax.xml.parsers.SAXParserFactory; */ @Listeners({jaxp.library.BasePolicy.class}) public class Bug6723276Test { + private static final String ERR_MSG = "org.apache.xerces.jaxp.SAXParserFactoryImpl not found"; @Test - public void test1() { + public void testWithDefaultContextClassLoader() { try { SAXParserFactory.newInstance(); } catch (Exception e) { - if (e.getMessage().indexOf("org.apache.xerces.jaxp.SAXParserFactoryImpl not found") > 0) { + if (e.getMessage().contains(ERR_MSG)) { Assert.fail(e.getMessage()); } } } @Test - public void test2() { + public void testWithGivenURLContextClassLoader() { try { System.out.println(Thread.currentThread().getContextClassLoader()); System.out.println(ClassLoader.getSystemClassLoader().getParent()); Thread.currentThread().setContextClassLoader(new URLClassLoader(new URL[0], ClassLoader.getSystemClassLoader().getParent())); SAXParserFactory.newInstance(); } catch (Exception e) { - if (e.getMessage().indexOf("org.apache.xerces.jaxp.SAXParserFactoryImpl not found") > 0) { + if (e.getMessage().contains(ERR_MSG)) { Assert.fail(e.getMessage()); } } diff --git a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169.xml b/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169.xml deleted file mode 100644 index eca850a354f..00000000000 --- a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169.xml +++ /dev/null @@ -1,10 +0,0 @@ - - - - test - - - - information - - diff --git a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169.xsd b/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169.xsd deleted file mode 100644 index 27282f4da15..00000000000 --- a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169.xsd +++ /dev/null @@ -1,11 +0,0 @@ - - - - - - - - - - - diff --git a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169Test.java b/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169Test.java deleted file mode 100644 index 3cbddb4aaad..00000000000 --- a/test/jaxp/javax/xml/jaxp/unittest/common/Bug6941169Test.java +++ /dev/null @@ -1,496 +0,0 @@ -/* - * Copyright (c) 2014, 2017, Oracle and/or its affiliates. All rights reserved. - * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. - * - * This code is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License version 2 only, as - * published by the Free Software Foundation. - * - * This code is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License - * version 2 for more details (a copy is included in the LICENSE file that - * accompanied this code). - * - * You should have received a copy of the GNU General Public License version - * 2 along with this work; if not, write to the Free Software Foundation, - * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. - * - * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA - * or visit www.oracle.com if you need additional information or have any - * questions. - */ - -package common; - -import static jaxp.library.JAXPTestUtilities.clearSystemProperty; -import static jaxp.library.JAXPTestUtilities.getSystemProperty; -import static jaxp.library.JAXPTestUtilities.setSystemProperty; - -import java.io.FilePermission; -import java.io.InputStream; -import java.io.StringWriter; - -import javax.xml.XMLConstants; -import javax.xml.parsers.DocumentBuilder; -import javax.xml.parsers.DocumentBuilderFactory; -import javax.xml.transform.Transformer; -import javax.xml.transform.TransformerFactory; -import javax.xml.transform.dom.DOMSource; -import javax.xml.transform.sax.SAXSource; -import javax.xml.transform.stream.StreamResult; -import javax.xml.transform.stream.StreamSource; -import javax.xml.validation.Schema; -import javax.xml.validation.SchemaFactory; -import javax.xml.validation.Validator; -import javax.xml.xpath.XPath; -import javax.xml.xpath.XPathFactory; - -import jaxp.library.JAXPTestUtilities; - -import org.testng.Assert; -import org.testng.annotations.Listeners; -import org.testng.annotations.Test; -import org.w3c.dom.Document; -import org.xml.sax.InputSource; - -/* - * @test - * @bug 6941169 - * @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest - * @run testng/othervm -DrunSecMngr=true common.Bug6941169Test - * @run testng/othervm common.Bug6941169Test - * @summary Test use-service-mechanism feature. - */ -@Test(singleThreaded = true) -@Listeners({ jaxp.library.FilePolicy.class }) -public class Bug6941169Test { - static final String SCHEMA_LANGUAGE = "http://java.sun.com/xml/jaxp/properties/schemaLanguage"; - static final String SCHEMA_SOURCE = "http://java.sun.com/xml/jaxp/properties/schemaSource"; - - private static final String DOM_FACTORY_ID = "javax.xml.parsers.DocumentBuilderFactory"; - private static final String SAX_FACTORY_ID = "javax.xml.parsers.SAXParserFactory"; - - // impl specific feature - final String ORACLE_FEATURE_SERVICE_MECHANISM = "http://www.oracle.com/feature/use-service-mechanism"; - - static String _xml = Bug6941169Test.class.getResource("Bug6941169.xml").getPath(); - static String _xsd = Bug6941169Test.class.getResource("Bug6941169.xsd").getPath(); - - @Test - public void testValidation_SAX_withoutServiceMech() { - System.out.println("Validation using SAX Source; Service mechnism is turned off; SAX Impl should be the default:"); - InputSource is = new InputSource(Bug6941169Test.class.getResourceAsStream("Bug6941169.xml")); - SAXSource ss = new SAXSource(is); - setSystemProperty(SAX_FACTORY_ID, "MySAXFactoryImpl"); - long start = System.currentTimeMillis(); - try { - SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI); - factory.setFeature(ORACLE_FEATURE_SERVICE_MECHANISM, false); - Schema schema = factory.newSchema(new StreamSource(_xsd)); - Validator validator = schema.newValidator(); - validator.validate(ss, null); - } catch (Exception e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("javax.xml.parsers.FactoryConfigurationError: Provider MySAXFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl is used"); - } - - // System.out.println(e.getMessage()); - - } - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - clearSystemProperty(SAX_FACTORY_ID); - } - - @Test - public void testValidation_SAX_withServiceMech() { - System.out.println("Validation using SAX Source. Using service mechnism (by default) to find SAX Impl:"); - InputSource is = new InputSource(Bug6941169Test.class.getResourceAsStream("Bug6941169.xml")); - SAXSource ss = new SAXSource(is); - setSystemProperty(SAX_FACTORY_ID, "MySAXFactoryImpl"); - long start = System.currentTimeMillis(); - try { - SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI); - Schema schema = factory.newSchema(new StreamSource(_xsd)); - Validator validator = schema.newValidator(); - validator.validate(ss, null); - Assert.fail("User impl MySAXFactoryImpl should be used."); - } catch (Exception e) { - String error = e.getMessage(); - if (error.indexOf("javax.xml.parsers.FactoryConfigurationError: Provider MySAXFactoryImpl not found") > 0) { - // expected - } - // System.out.println(e.getMessage()); - - } - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - clearSystemProperty(SAX_FACTORY_ID); - } - - @Test - public void testValidation_SAX_withSM() throws Exception { - if(System.getSecurityManager() == null) - return; - - System.out.println("Validation using SAX Source with security manager:"); - InputSource is = new InputSource(Bug6941169Test.class.getResourceAsStream("Bug6941169.xml")); - SAXSource ss = new SAXSource(is); - setSystemProperty(SAX_FACTORY_ID, "MySAXFactoryImpl"); - - long start = System.currentTimeMillis(); - try { - SchemaFactory factory = SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI); - factory.setFeature(ORACLE_FEATURE_SERVICE_MECHANISM, false); - Schema schema = factory.newSchema(new StreamSource(_xsd)); - Validator validator = schema.newValidator(); - validator.validate(ss, null); - } catch (Exception e) { - String error = e.getMessage(); - if (error.indexOf("javax.xml.parsers.FactoryConfigurationError: Provider MySAXFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl is used"); - } - - // System.out.println(e.getMessage()); - - } finally { - clearSystemProperty(SAX_FACTORY_ID); - } - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - - } - - @Test - public void testTransform_DOM_withoutServiceMech() { - System.out.println("Transform using DOM Source; Service mechnism is turned off; Default DOM Impl should be the default:"); - DOMSource domSource = new DOMSource(); - domSource.setSystemId(_xml); - - // DOMSource domSource = new - // DOMSource(getDocument(Bug6941169Test.class.getResourceAsStream("Bug6941169.xml"))); - setSystemProperty(DOM_FACTORY_ID, "MyDOMFactoryImpl"); - long start = System.currentTimeMillis(); - try { - TransformerFactory factory = TransformerFactory.newInstance(); - factory.setFeature(ORACLE_FEATURE_SERVICE_MECHANISM, false); - - Transformer t = factory.newTransformer(); - - StringWriter result = new StringWriter(); - StreamResult streamResult = new StreamResult(result); - t.transform(domSource, streamResult); - System.out.println("Writing to " + result.toString()); - - } catch (Exception e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("Provider MyDOMFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl is used"); - } - - // System.out.println(e.getMessage()); - - } catch (Error e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("Provider MyDOMFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl is used"); - } - - // System.out.println(e.getMessage()); - - } - - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - clearSystemProperty(DOM_FACTORY_ID); - } - - /** this is by default */ - @Test - public void testTransform_DOM_withServiceMech() { - System.out.println("Transform using DOM Source; By default, the factory uses services mechanism to look up impl:"); - DOMSource domSource = new DOMSource(); - domSource.setSystemId(_xml); - - // DOMSource domSource = new - // DOMSource(getDocument(Bug6941169Test.class.getResourceAsStream("Bug6941169.xml"))); - setSystemProperty(DOM_FACTORY_ID, "MyDOMFactoryImpl"); - long start = System.currentTimeMillis(); - try { - TransformerFactory factory = TransformerFactory.newInstance(); - Transformer t = factory.newTransformer(); - - StringWriter result = new StringWriter(); - StreamResult streamResult = new StreamResult(result); - t.transform(domSource, streamResult); - System.out.println("Writing to " + result.toString()); - - Assert.fail("User impl MyDOMFactoryImpl should be used."); - - } catch (Exception e) { - String error = e.getMessage(); - if (error.indexOf("Provider MyDOMFactoryImpl not found") > 0) { - // expected - } - System.out.println(error); - - } catch (Error e) { - String error = e.getMessage(); - if (error.indexOf("Provider MyDOMFactoryImpl not found") > 0) { - // expected - } - System.out.println(error); - - } - - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - clearSystemProperty(DOM_FACTORY_ID); - } - - @Test - public void testTransform_DOM_withSM() throws Exception { - if(System.getSecurityManager() == null) - return; - System.out.println("Transform using DOM Source; Security Manager is set:"); - DOMSource domSource = new DOMSource(); - domSource.setSystemId(_xml); - - // DOMSource domSource = new - // DOMSource(getDocument(Bug6941169Test.class.getResourceAsStream("Bug6941169.xml"))); - setSystemProperty(DOM_FACTORY_ID, "MyDOMFactoryImpl"); - long start = System.currentTimeMillis(); - try { - TransformerFactory factory = TransformerFactory.newInstance("com.sun.org.apache.xalan.internal.xsltc.trax.TransformerFactoryImpl", - TransformerFactory.class.getClassLoader()); - Transformer t = factory.newTransformer(); - - StringWriter result = new StringWriter(); - StreamResult streamResult = new StreamResult(result); - t.transform(domSource, streamResult); - System.out.println("Writing to " + result.toString()); - - } catch (Exception e) { - String error = e.getMessage(); - if (error.indexOf("Provider MyDOMFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl is used"); - } - - // System.out.println(e.getMessage()); - - } catch (Error e) { - String error = e.getMessage(); - if (error.indexOf("Provider MyDOMFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl is used"); - } - - // System.out.println(e.getMessage()); - - } finally { - clearSystemProperty(DOM_FACTORY_ID); - } - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - - } - - @Test - public void testXPath_DOM_withoutServiceMech() { - final String XPATH_EXPRESSION = "/fooTest"; - System.out.println("Evaluate DOM Source; Service mechnism is turned off; Default DOM Impl should be used:"); - Document doc = getDocument(Bug6941169Test.class.getResourceAsStream("Bug6941169.xml")); - setSystemProperty(DOM_FACTORY_ID, "MyDOMFactoryImpl"); - long start = System.currentTimeMillis(); - try { - XPathFactory xPathFactory = XPathFactory.newInstance(); - xPathFactory.setFeature(ORACLE_FEATURE_SERVICE_MECHANISM, false); - - XPath xPath = xPathFactory.newXPath(); - - String xPathResult = xPath.evaluate(XPATH_EXPRESSION, doc); - - } catch (Exception e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("MyDOMFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl is used"); - } - - // System.out.println(e.getMessage()); - - } catch (Error e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("MyDOMFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl is used"); - } - - // System.out.println(e.getMessage()); - - } - - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - clearSystemProperty(DOM_FACTORY_ID); - } - - @Test - public void testXPath_DOM_withServiceMech() { - /** - * This is in conflict with the test testXPath_DOM_withSM where the system - * default parser is used when the security manager is present. The test - * is therefore skipped when the security manager is present. - */ - if (System.getSecurityManager() != null) { - return; - } - final String XPATH_EXPRESSION = "/fooTest"; - System.out.println("Evaluate DOM Source; Service mechnism is on by default; It would try to use MyDOMFactoryImpl:"); - InputStream input = getClass().getResourceAsStream("Bug6941169.xml"); - InputSource source = new InputSource(input); - setSystemProperty(DOM_FACTORY_ID, "MyDOMFactoryImpl"); - long start = System.currentTimeMillis(); - try { - XPathFactory xPathFactory = XPathFactory.newInstance(); - - XPath xPath = xPathFactory.newXPath(); - - String xPathResult = xPath.evaluate(XPATH_EXPRESSION, source); - Assert.fail("User impl MyDOMFactoryImpl should be used."); - - } catch (Exception e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("MyDOMFactoryImpl not found") > 0) { - System.out.println("Tried to locate MyDOMFactoryImpl"); - } else { - Assert.fail(e.getMessage()); - - } - - // System.out.println(e.getMessage()); - - } catch (Error e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("MyDOMFactoryImpl not found") > 0) { - System.out.println("Tried to locate MyDOMFactoryImpl"); - } else { - Assert.fail(e.getMessage()); - - } - - // System.out.println(e.getMessage()); - - } - - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - clearSystemProperty(DOM_FACTORY_ID); - } - - @Test - public void testXPath_DOM_withSM() throws Exception { - if(System.getSecurityManager() == null) - return; - final String XPATH_EXPRESSION = "/fooTest"; - System.out.println("Evaluate DOM Source; Security Manager is set:"); - InputStream input = getClass().getResourceAsStream("Bug6941169.xml"); - InputSource source = new InputSource(input); - setSystemProperty(DOM_FACTORY_ID, "MyDOMFactoryImpl"); - long start = System.currentTimeMillis(); - try { - XPathFactory xPathFactory = XPathFactory.newInstance("http://java.sun.com/jaxp/xpath/dom", - "com.sun.org.apache.xpath.internal.jaxp.XPathFactoryImpl", null); - - XPath xPath = xPathFactory.newXPath(); - - String xPathResult = xPath.evaluate(XPATH_EXPRESSION, source); - System.out.println("Use default impl"); - } catch (Exception e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("MyDOMFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl should be used"); - } - - // System.out.println(e.getMessage()); - - } catch (Error e) { - // e.printStackTrace(); - String error = e.getMessage(); - if (error.indexOf("MyDOMFactoryImpl not found") > 0) { - Assert.fail(e.getMessage()); - } else { - System.out.println("Default impl should be used"); - } - - // System.out.println(e.getMessage()); - - } finally { - clearSystemProperty(DOM_FACTORY_ID); - } - long end = System.currentTimeMillis(); - double elapsedTime = ((end - start)); - System.out.println("Time elapsed: " + elapsedTime); - - } - - @Test - public void testSM() { - SecurityManager sm = System.getSecurityManager(); - if (System.getSecurityManager() != null) { - System.out.println("Security manager not cleared: " + sm.toString()); - } else { - System.out.println("Security manager cleared: "); - } - } - - private static Document getDocument(InputStream in) { - - Document document = null; - - try { - DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); - dbf.setNamespaceAware(true); - DocumentBuilder db = dbf.newDocumentBuilder(); - document = db.parse(in); - } catch (Exception e) { - e.printStackTrace(); - Assert.fail(e.toString()); - } - - return document; - } -} diff --git a/test/jaxp/javax/xml/jaxp/unittest/common/Bug7143711Test.java b/test/jaxp/javax/xml/jaxp/unittest/common/Bug7143711Test.java index 771d26a4677..33e81c1ea5d 100644 --- a/test/jaxp/javax/xml/jaxp/unittest/common/Bug7143711Test.java +++ b/test/jaxp/javax/xml/jaxp/unittest/common/Bug7143711Test.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,14 +23,13 @@ package common; -import static jaxp.library.JAXPTestUtilities.clearSystemProperty; -import static jaxp.library.JAXPTestUtilities.setSystemProperty; - import javax.xml.XMLConstants; import javax.xml.transform.TransformerFactory; import javax.xml.validation.SchemaFactory; import javax.xml.xpath.XPathFactory; +import static jaxp.library.JAXPTestUtilities.clearSystemProperty; +import static jaxp.library.JAXPTestUtilities.setSystemProperty; import org.testng.Assert; import org.testng.annotations.Listeners; import org.testng.annotations.Test; @@ -45,14 +44,14 @@ import org.testng.annotations.Test; @Listeners({ jaxp.library.BasePolicy.class }) @Test(singleThreaded = true) public class Bug7143711Test { - static final String SCHEMA_LANGUAGE = "http://java.sun.com/xml/jaxp/properties/schemaLanguage"; - static final String SCHEMA_SOURCE = "http://java.sun.com/xml/jaxp/properties/schemaSource"; + private static final String SCHEMA_LANGUAGE = "http://java.sun.com/xml/jaxp/properties/schemaLanguage"; + private static final String SCHEMA_SOURCE = "http://java.sun.com/xml/jaxp/properties/schemaSource"; private static final String DOM_FACTORY_ID = "javax.xml.parsers.DocumentBuilderFactory"; private static final String SAX_FACTORY_ID = "javax.xml.parsers.SAXParserFactory"; // impl specific feature - final String ORACLE_FEATURE_SERVICE_MECHANISM = "http://www.oracle.com/feature/use-service-mechanism"; + private static final String ORACLE_FEATURE_SERVICE_MECHANISM = "http://www.oracle.com/feature/use-service-mechanism"; @Test public void testValidation_SAX_withSM() { diff --git a/test/jaxp/javax/xml/jaxp/unittest/datatype/Bug6320118.java b/test/jaxp/javax/xml/jaxp/unittest/datatype/Bug6320118.java index e9609155807..2d1c25967e8 100644 --- a/test/jaxp/javax/xml/jaxp/unittest/datatype/Bug6320118.java +++ b/test/jaxp/javax/xml/jaxp/unittest/datatype/Bug6320118.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,6 +28,7 @@ import javax.xml.datatype.DatatypeFactory; import javax.xml.datatype.XMLGregorianCalendar; import org.testng.Assert; +import org.testng.annotations.BeforeClass; import org.testng.annotations.Listeners; import org.testng.annotations.Test; @@ -44,67 +45,38 @@ public class Bug6320118 { DatatypeFactory df; + @BeforeClass + public void createDataTypeFactory() throws DatatypeConfigurationException { + df = DatatypeFactory.newInstance(); + } + @Test public void test1() { - try { - df = DatatypeFactory.newInstance(); - } catch (DatatypeConfigurationException e) { - Assert.fail(e.getMessage()); - } - - try { - XMLGregorianCalendar calendar = df.newXMLGregorianCalendar(1970, 1, 1, 24, 0, 0, 0, 0); - } catch (IllegalArgumentException e) { - Assert.fail(e.getMessage()); - } + XMLGregorianCalendar calendar = df.newXMLGregorianCalendar(1970, 1, 1, 24, 0, 0, 0, 0); + Assert.assertEquals(calendar.getYear(), 1970); + Assert.assertEquals(calendar.getMonth(), 1); + Assert.assertEquals(calendar.getDay(), 2); + Assert.assertEquals(calendar.getHour(), 0, "hour 24 needs to be treated as hour 0 of next day"); } @Test public void test2() { - try { - df = DatatypeFactory.newInstance(); - } catch (DatatypeConfigurationException e) { - Assert.fail(e.getMessage()); - } - - try { - XMLGregorianCalendar calendar = df.newXMLGregorianCalendarTime(24, 0, 0, 0); - } catch (IllegalArgumentException e) { - Assert.fail(e.getMessage()); - } + XMLGregorianCalendar calendar = df.newXMLGregorianCalendarTime(24, 0, 0, 0); + Assert.assertEquals(calendar.getHour(), 0, "hour 24 needs to be treated as hour 0 of next day"); } - @Test + @Test(expectedExceptions = IllegalArgumentException.class) public void test3() { - try { - df = DatatypeFactory.newInstance(); - } catch (DatatypeConfigurationException e) { - Assert.fail(e.getMessage()); - } - try { - XMLGregorianCalendar calendar = df.newXMLGregorianCalendar(); - // Must fail as other params are not 0 but undefined - calendar.setHour(24); - Assert.fail("test3() - Expected IllegalArgumentException not thrown"); - } catch (IllegalArgumentException e) { - // falls through - } + XMLGregorianCalendar calendar = df.newXMLGregorianCalendar(); + // Must fail as other params are not 0 but undefined + calendar.setHour(24); } @Test public void test4() { - try { - df = DatatypeFactory.newInstance(); - } catch (DatatypeConfigurationException e) { - Assert.fail(e.getMessage()); - } - - try { - XMLGregorianCalendar calendar = df.newXMLGregorianCalendar(); - calendar.setTime(24, 0, 0, 0); - } catch (IllegalArgumentException e) { - Assert.fail(e.getMessage()); - } + XMLGregorianCalendar calendar = df.newXMLGregorianCalendar(); + calendar.setTime(24, 0, 0, 0); + Assert.assertEquals(calendar.getHour(), 0, "hour 24 needs to be treated as hour 0 of next day"); } } diff --git a/test/jaxp/javax/xml/jaxp/unittest/datatype/Bug6937964Test.java b/test/jaxp/javax/xml/jaxp/unittest/datatype/Bug6937964Test.java index 3e1129d2acc..c4184844c04 100644 --- a/test/jaxp/javax/xml/jaxp/unittest/datatype/Bug6937964Test.java +++ b/test/jaxp/javax/xml/jaxp/unittest/datatype/Bug6937964Test.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -33,6 +33,7 @@ import javax.xml.datatype.Duration; import javax.xml.namespace.QName; import org.testng.Assert; +import org.testng.annotations.DataProvider; import org.testng.annotations.Listeners; import org.testng.annotations.Test; @@ -55,15 +56,10 @@ public class Bug6937964Test { */ private static final String TEST_VALUE_FAIL = "*FAIL*"; - private static final String FIELD_UNDEFINED = "FIELD_UNDEFINED"; - static final DatatypeConstants.Field[] fields = { DatatypeConstants.YEARS, DatatypeConstants.MONTHS, DatatypeConstants.DAYS, DatatypeConstants.HOURS, - DatatypeConstants.MINUTES, DatatypeConstants.SECONDS }; - @Test public void test() throws DatatypeConfigurationException { DatatypeFactory dtf = DatatypeFactory.newInstance(); Duration d = dtf.newDurationYearMonth("P20Y15M"); - int years = d.getYears(); System.out.println(d.getYears() == 21 ? "pass" : "fail"); } @@ -72,7 +68,7 @@ public class Bug6937964Test { DatatypeFactory dtf = DatatypeFactory.newInstance(); Duration d = dtf.newDurationYearMonth("P20Y15M"); int years = d.getYears(); - Assert.assertTrue(years == 21, "Return value should be normalized"); + Assert.assertEquals(years, 21, "Return value should be normalized"); } @Test @@ -81,7 +77,7 @@ public class Bug6937964Test { Duration d = dtf.newDurationYearMonth(671976000000L); int years = d.getYears(); System.out.println("Years: " + years); - Assert.assertTrue(years == 21, "Return value should be normalized"); + Assert.assertEquals(years, 21, "Return value should be normalized"); } @Test @@ -91,7 +87,7 @@ public class Bug6937964Test { BigInteger mon = new BigInteger("15"); Duration d = dtf.newDurationYearMonth(true, year, mon); int years = d.getYears(); - Assert.assertTrue(years == 21, "Return value should be normalized"); + Assert.assertEquals(years, 21, "Return value should be normalized"); } @Test @@ -99,7 +95,7 @@ public class Bug6937964Test { DatatypeFactory dtf = DatatypeFactory.newInstance(); Duration d = dtf.newDurationYearMonth(true, 20, 15); int years = d.getYears(); - Assert.assertTrue(years == 21, "Return value should be normalized"); + Assert.assertEquals(years, 21, "Return value should be normalized"); } @Test @@ -107,7 +103,7 @@ public class Bug6937964Test { DatatypeFactory dtf = DatatypeFactory.newInstance(); Duration d = dtf.newDurationDayTime("P1DT23H59M65S"); int days = d.getDays(); - Assert.assertTrue(days == 2, "Return value should be normalized"); + Assert.assertEquals(days, 2, "Return value should be normalized"); } @Test @@ -115,7 +111,7 @@ public class Bug6937964Test { DatatypeFactory dtf = DatatypeFactory.newInstance(); Duration d = dtf.newDurationDayTime(172805000L); int days = d.getDays(); - Assert.assertTrue(days == 2, "Return value should be normalized"); + Assert.assertEquals(days, 2, "Return value should be normalized"); } @Test @@ -128,7 +124,7 @@ public class Bug6937964Test { Duration d = dtf.newDurationDayTime(true, day, hour, min, sec); int days = d.getDays(); System.out.println("Days: " + days); - Assert.assertTrue(days == 2, "Return value should be normalized"); + Assert.assertEquals(days, 2, "Return value should be normalized"); } @Test @@ -137,16 +133,27 @@ public class Bug6937964Test { Duration d = dtf.newDurationDayTime(true, 1, 23, 59, 65); int days = d.getDays(); System.out.println("Days: " + days); - Assert.assertTrue(days == 2, "Return value should be normalized"); + Assert.assertEquals(days, 2, "Return value should be normalized"); } - @Test - public final void testNewDurationYearMonthLexicalRepresentation1() { + @DataProvider(name = "lexicalvalues") + public Object[][] actualAndExpectedLexicals() { + Object actualAndExpected [][] = { + {"P13M", "P1Y1M"}, + {"-P13M", "-P1Y1M"}, + {"P1Y", "P1Y"}, + {"-P1Y", "-P1Y"}, + {"P1Y25M", "P3Y1M"}, + {"-P1Y25M", "-P3Y1M"} + }; + return actualAndExpected; + } + @Test(dataProvider = "lexicalvalues") + public void testNewDurationYearMonthLexicalRepresentation1(String actualLex, String expectedLex) { /** * Lexical test values to test. */ - final String[] TEST_VALUES_LEXICAL = { "P13M", "P1Y1M", "-P13M", "-P1Y1M", "P1Y", "P1Y", "-P1Y", "-P1Y", "P1Y25M", "P3Y1M", "-P1Y25M", "-P3Y1M" }; DatatypeFactory datatypeFactory = null; try { @@ -158,78 +165,70 @@ public class Bug6937964Test { if (DEBUG) { System.err.println("DatatypeFactory created: " + datatypeFactory.toString()); } + if (DEBUG) { + System.err.println("testing value: \"" + actualLex + "\", expecting: \"" + expectedLex + "\""); + } - // test each value - for (int onTestValue = 0; onTestValue < TEST_VALUES_LEXICAL.length; onTestValue = onTestValue + 2) { + try { + Duration duration = datatypeFactory.newDurationYearMonth(actualLex); if (DEBUG) { - System.err.println("testing value: \"" + TEST_VALUES_LEXICAL[onTestValue] + "\", expecting: \"" + TEST_VALUES_LEXICAL[onTestValue + 1] + "\""); + System.err.println("Duration created: \"" + duration.toString() + "\""); } + // was this expected to fail? + Assert.assertNotEquals(expectedLex, TEST_VALUE_FAIL, "the value \"" + actualLex + "\" is invalid " + + "yet it created the Duration \"" + duration.toString() + "\"" ); + + // right XMLSchemaType? + // TODO: enable test, it should pass, it fails with Exception(s) + // for now due to a bug try { - Duration duration = datatypeFactory.newDurationYearMonth(TEST_VALUES_LEXICAL[onTestValue]); - - if (DEBUG) { - System.err.println("Duration created: \"" + duration.toString() + "\""); - } - - // was this expected to fail? - if (TEST_VALUES_LEXICAL[onTestValue + 1].equals(TEST_VALUE_FAIL)) { - Assert.fail("the value \"" + TEST_VALUES_LEXICAL[onTestValue] + "\" is invalid yet it created the Duration \"" + duration.toString() + "\""); - } - - // right XMLSchemaType? - // TODO: enable test, it should pass, it fails with Exception(s) - // for now due to a bug - try { - QName xmlSchemaType = duration.getXMLSchemaType(); - if (!xmlSchemaType.equals(DatatypeConstants.DURATION_YEARMONTH)) { - Assert.fail("Duration created with XMLSchemaType of\"" + xmlSchemaType + "\" was expected to be \"" - + DatatypeConstants.DURATION_YEARMONTH + "\" and has the value \"" + duration.toString() + "\""); - } + QName xmlSchemaType = duration.getXMLSchemaType(); + Assert.assertEquals(xmlSchemaType, DatatypeConstants.DURATION_YEARMONTH, "Duration created with " + + "XMLSchemaType of\"" + xmlSchemaType + "\" was expected to be \"" + + DatatypeConstants.DURATION_YEARMONTH + "\" and has the value \"" + duration.toString() + "\""); } catch (IllegalStateException illegalStateException) { // TODO; this test really should pass System.err.println("Please fix this bug that is being ignored, for now: " + illegalStateException.getMessage()); } // does it have the right value? - if (!TEST_VALUES_LEXICAL[onTestValue + 1].equals(duration.toString())) { - Assert.fail("Duration created with \"" + TEST_VALUES_LEXICAL[onTestValue] + "\" was expected to be \"" - + TEST_VALUES_LEXICAL[onTestValue + 1] + "\" and has the value \"" + duration.toString() + "\""); - } - + Assert.assertEquals(duration.toString(), expectedLex, "Duration created with \"" + actualLex + + "\" was expected to be \"" + expectedLex + "\" and has the value \"" + duration.toString() + "\""); // Duration created with correct value } catch (Exception exception) { - if (DEBUG) { System.err.println("Exception in creating duration: \"" + exception.toString() + "\""); } // was this expected to succed? - if (!TEST_VALUES_LEXICAL[onTestValue + 1].equals(TEST_VALUE_FAIL)) { - Assert.fail("the value \"" + TEST_VALUES_LEXICAL[onTestValue] + "\" is valid yet it failed with \"" + exception.toString() + "\""); - } + Assert.assertEquals(TEST_VALUE_FAIL, expectedLex, "the value \"" + actualLex + "\" is valid yet " + + "it failed with \"" + exception.toString() + "\""); // expected failure } - } } - /** - * TCK test failure - */ - @Test - public void testNewDurationDayTime005() { + @DataProvider(name = "lexDayTime") + public Object[][] lexDayTimeData() { BigInteger one = new BigInteger("1"); BigInteger zero = new BigInteger("0"); BigDecimal bdZero = new BigDecimal("0"); BigDecimal bdOne = new BigDecimal("1"); - Object[][] values = { // lex, isPositive, years, month, days, hours, minutes, seconds { "P1D", Boolean.TRUE, null, null, one, zero, zero, bdZero }, { "PT1H", Boolean.TRUE, null, null, zero, one, zero, bdZero }, { "PT1M", Boolean.TRUE, null, null, zero, zero, one, bdZero }, { "PT1.1S", Boolean.TRUE, null, null, zero, zero, zero, bdOne }, { "-PT1H1.1S", Boolean.FALSE, null, null, zero, one, zero, bdOne }, }; + return values; + } + /** + * TCK test failure + */ + @Test(dataProvider = "lexDayTime") + public void testNewDurationDayTime005(String lex, boolean isPositive, BigInteger year, BigInteger month, BigInteger days, + BigInteger hour, BigInteger minutes, BigDecimal seconds) { StringBuffer result = new StringBuffer(); DatatypeFactory df = null; @@ -239,34 +238,56 @@ public class Bug6937964Test { Assert.fail(e.toString()); } - for (int valueIndex = 0; valueIndex < values.length; ++valueIndex) { - Duration duration = null; - try { - duration = df.newDurationDayTime(values[valueIndex][1].equals(Boolean.TRUE), ((BigInteger) values[valueIndex][4]).intValue(), - ((BigInteger) values[valueIndex][5]).intValue(), ((BigInteger) values[valueIndex][6]).intValue(), - ((BigDecimal) values[valueIndex][7]).intValue()); - } catch (IllegalArgumentException e) { - result.append("; unexpected " + e + " trying to create duration \'" + values[valueIndex][0] + "\'"); + Duration duration = null; + try { + duration = df.newDurationDayTime(isPositive, days, hour, minutes, seconds.toBigInteger()); + } catch (IllegalArgumentException e) { + result.append("; unexpected " + e + " trying to create duration \'" + lex + "\'"); + } + if (duration != null) { + if ((duration.getSign() == 1) != isPositive) { + result.append("; " + lex + ": wrong sign " + duration.getSign() + ", expected " + isPositive); } - if (duration != null) { - if ((duration.getSign() == 1) != values[valueIndex][1].equals(Boolean.TRUE)) { - result.append("; " + values[valueIndex][0] + ": wrong sign " + duration.getSign() + ", expected " + values[valueIndex][1]); - } - for (int i = 0; i < fields.length; ++i) { - Number value = duration.getField(fields[i]); - if ((value != null && values[valueIndex][2 + i] == null) || (value == null && values[valueIndex][2 + i] != null) - || (value != null && !value.equals(values[valueIndex][2 + i]))) { - result.append("; " + values[valueIndex][0] + ": wrong value of the field " + fields[i] + ": \'" + value + "\'" + ", expected \'" - + values[valueIndex][2 + i] + "\'"); - } - } + + Number value = duration.getField(DatatypeConstants.YEARS); + if ((value != null && year == null) || (value == null && year != null) || (value != null && !value.equals(year))) { + result.append("; " + lex + ": wrong value of the field " + DatatypeConstants.YEARS + ": \'" + value + "\'" + ", expected \'" + + year + "\'"); + } + + value = duration.getField(DatatypeConstants.MONTHS); + if ((value != null && month == null) || (value == null && month != null) || (value != null && !value.equals(month))) { + result.append("; " + lex + ": wrong value of the field " + DatatypeConstants.MONTHS + ": \'" + value + "\'" + ", expected \'" + + month + "\'"); + } + + value = duration.getField(DatatypeConstants.DAYS); + if ((value != null && days == null) || (value == null && days != null) || (value != null && !value.equals(days))) { + result.append("; " + lex + ": wrong value of the field " + DatatypeConstants.DAYS + ": \'" + value + "\'" + ", expected \'" + + days + "\'"); + } + + value = duration.getField(DatatypeConstants.HOURS); + if ((value != null && hour == null) || (value == null && hour != null) || (value != null && !value.equals(hour))) { + result.append("; " + lex + ": wrong value of the field " + DatatypeConstants.HOURS + ": \'" + value + "\'" + ", expected \'" + + hour + "\'"); + } + + value = duration.getField(DatatypeConstants.MINUTES); + if ((value != null && minutes == null) || (value == null && minutes != null) || (value != null && !value.equals(minutes))) { + result.append("; " + lex + ": wrong value of the field " + DatatypeConstants.MINUTES + ": \'" + value + "\'" + ", expected \'" + + minutes + "\'"); + } + + value = duration.getField(DatatypeConstants.SECONDS); + if ((value != null && seconds == null) || (value == null && seconds != null) || (value != null && !value.equals(seconds))) { + result.append("; " + lex + ": wrong value of the field " + DatatypeConstants.SECONDS + ": \'" + value + "\'" + ", expected \'" + + seconds + "\'"); } } - - if (result.length() > 0) { + if(result.length() > 0) { Assert.fail(result.substring(2)); } System.out.println("OK"); - } }