/* * Copyright (c) 2014, 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 javax.xml.parsers.ptests; import static jaxp.library.JAXPTestUtilities.failUnexpected; import static org.testng.Assert.assertFalse; import static org.testng.Assert.assertTrue; import java.io.File; import java.io.FilePermission; import java.io.IOException; import javax.xml.parsers.ParserConfigurationException; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; import static javax.xml.parsers.ptests.TestUtils.XML_DIR; import jaxp.library.JAXPBaseTest; import org.testng.annotations.AfterGroups; import org.testng.annotations.BeforeGroups; import org.testng.annotations.DataProvider; import org.testng.annotations.Test; import org.xml.sax.SAXException; /** * Class contains the test cases for SAXParser API */ public class SAXParserTest03 extends JAXPBaseTest { /** * Provide SAXParserFactory. * * @return a dimensional contains. */ @DataProvider(name = "input-provider") public Object[][] getFactory() { SAXParserFactory spf = SAXParserFactory.newInstance(); spf.setValidating(true); return new Object[][] { { spf, MyErrorHandler.newInstance() } }; } /** * Save system property for restoring. */ @BeforeGroups (groups = {"readLocalFiles"}) public void setFilePermissions() { setPermissions(new FilePermission(XML_DIR + "/-", "read")); } /** * Restore the system property. */ @AfterGroups (groups = {"readLocalFiles"}) public void restoreFilePermissions() { setPermissions(); } /** * parsertest.xml holds a valid document. This method tests the validating * parser. * * @param spf a Parser factory. * @param handler an error handler for capturing events. * @throws SAXException If any parse errors occur. * @throws ParserConfigurationException in case of ServiceConfigurationError * service configuration error or if the implementation is not available or * cannot be instantiated. * @throws IOException if any I/O operation error. */ @Test(groups = {"readLocalFiles"}, dataProvider = "input-provider") public void testParseValidate01(SAXParserFactory spf, MyErrorHandler handler) throws ParserConfigurationException, SAXException, IOException { spf.newSAXParser().parse(new File(XML_DIR, "parsertest.xml"), handler); assertFalse(handler.isErrorOccured()); } /** * validns.xml holds a valid document with XML namespaces in it. This method * tests the Validating parser with namespace processing on. * * @param spf a Parser factory. * @param handler an error handler for capturing events. * @throws SAXException If any parse errors occur. * @throws ParserConfigurationException in case of ServiceConfigurationError * service configuration error or if the implementation is not available or * cannot be instantiated. * @throws IOException if any I/O operation error. */ @Test(groups = {"readLocalFiles"}, dataProvider = "input-provider") public void testParseValidate02(SAXParserFactory spf, MyErrorHandler handler) throws ParserConfigurationException, SAXException, IOException { spf.setNamespaceAware(true); spf.newSAXParser().parse(new File(XML_DIR, "validns.xml"), handler); assertFalse(handler.isErrorOccured()); } /** * invalidns.xml holds an invalid document with XML namespaces in it. This * method tests the validating parser with namespace processing on. It * should throw validation error. * * @param spf a Parser factory. * @param handler an error handler for capturing events. */ @Test(groups = {"readLocalFiles"}, dataProvider = "input-provider") public void testParseValidate03(SAXParserFactory spf, MyErrorHandler handler) { try { spf.setNamespaceAware(true); SAXParser saxparser = spf.newSAXParser(); saxparser.parse(new File(XML_DIR, "invalidns.xml"), handler); failUnexpected(new RuntimeException()); } catch (ParserConfigurationException | SAXException | IOException e) { if (e instanceof SAXException) { assertTrue(handler.isErrorOccured()); } } } }