8016914: CoreDocumentImpl.setXmlVersion NPE
Reviewed-by: lancea
This commit is contained in:
parent
c5ca4409e0
commit
a664c9cf99
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2009, 2018, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2009, 2019, Oracle and/or its affiliates. All rights reserved.
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
@ -83,7 +83,7 @@ import org.w3c.dom.ls.LSSerializer;
|
|||||||
* @author Andy Clark, IBM
|
* @author Andy Clark, IBM
|
||||||
* @author Ralf Pfeiffer, IBM
|
* @author Ralf Pfeiffer, IBM
|
||||||
* @since PR-DOM-Level-1-19980818.
|
* @since PR-DOM-Level-1-19980818.
|
||||||
* @LastModified: Nov 2018
|
* @LastModified: Sept 2019
|
||||||
*/
|
*/
|
||||||
public class CoreDocumentImpl
|
public class CoreDocumentImpl
|
||||||
extends ParentNode implements Document {
|
extends ParentNode implements Document {
|
||||||
@ -862,6 +862,9 @@ public class CoreDocumentImpl
|
|||||||
* the version number of this document.
|
* the version number of this document.
|
||||||
*/
|
*/
|
||||||
public void setXmlVersion(String value) {
|
public void setXmlVersion(String value) {
|
||||||
|
if (value == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if(value.equals("1.0") || value.equals("1.1")){
|
if(value.equals("1.0") || value.equals("1.1")){
|
||||||
//we need to change the flag value only --
|
//we need to change the flag value only --
|
||||||
// when the version set is different than already set.
|
// when the version set is different than already set.
|
||||||
|
@ -0,0 +1,82 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2019, 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 transform;
|
||||||
|
|
||||||
|
import javax.xml.stream.XMLInputFactory;
|
||||||
|
import javax.xml.stream.XMLStreamConstants;
|
||||||
|
import javax.xml.stream.XMLStreamReader;
|
||||||
|
import javax.xml.transform.Transformer;
|
||||||
|
import javax.xml.transform.TransformerFactory;
|
||||||
|
import javax.xml.transform.dom.DOMResult;
|
||||||
|
import javax.xml.transform.stax.StAXSource;
|
||||||
|
import org.testng.annotations.DataProvider;
|
||||||
|
import org.testng.annotations.Test;
|
||||||
|
import org.w3c.dom.Node;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8016914
|
||||||
|
* @library /javax/xml/jaxp/libs /javax/xml/jaxp/unittest
|
||||||
|
* @run testng transform.StAX2DOMTest
|
||||||
|
* @summary Verifies transforming a StAXSource to a DOMResult.
|
||||||
|
*/
|
||||||
|
public class StAX2DOMTest {
|
||||||
|
/**
|
||||||
|
* Data files for test.
|
||||||
|
* Column(s): xml file
|
||||||
|
*
|
||||||
|
* @return data for test
|
||||||
|
*/
|
||||||
|
@DataProvider(name = "datafiles")
|
||||||
|
public Object[][] getData() {
|
||||||
|
return new Object[][] {
|
||||||
|
{ "StAX2DOMTest.xml"}, //without declaration
|
||||||
|
{ "StAX2DOMTest1.xml"}, //with declaration
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Verifies that transforming a StAX source to a DOM result passes with
|
||||||
|
* or without the XML declaration.
|
||||||
|
*
|
||||||
|
* @param file the XML file
|
||||||
|
* @throws Exception if the test fails
|
||||||
|
*/
|
||||||
|
@Test(dataProvider = "datafiles")
|
||||||
|
public void test(String file) throws Exception {
|
||||||
|
final XMLInputFactory xif = XMLInputFactory.newInstance();
|
||||||
|
final XMLStreamReader xsr = xif.createXMLStreamReader(
|
||||||
|
this.getClass().getResourceAsStream(file));
|
||||||
|
xsr.nextTag(); // Advance to statements element
|
||||||
|
|
||||||
|
final TransformerFactory tf = TransformerFactory.newInstance();
|
||||||
|
final Transformer t = tf.newTransformer();
|
||||||
|
while(xsr.nextTag() == XMLStreamConstants.START_ELEMENT) {
|
||||||
|
final DOMResult result = new DOMResult();
|
||||||
|
t.transform(new StAXSource(xsr), result);
|
||||||
|
final Node domNode = result.getNode();
|
||||||
|
System.out.println(domNode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
119
test/jaxp/javax/xml/jaxp/unittest/transform/StAX2DOMTest.xml
Normal file
119
test/jaxp/javax/xml/jaxp/unittest/transform/StAX2DOMTest.xml
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
<catalog>
|
||||||
|
<book id= " bk101 " >
|
||||||
|
<author>Gambardella, Matthew</author>
|
||||||
|
<title>XML Developer's Guide</title>
|
||||||
|
<genre>Computer</genre>
|
||||||
|
<price>44.95</price>
|
||||||
|
<publish_date>2000-10-01</publish_date>
|
||||||
|
<description>An in-depth look at creating applications
|
||||||
|
with XML.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk102 " >
|
||||||
|
<author>Ralls, Kim</author>
|
||||||
|
<title>Midnight Rain</title>
|
||||||
|
<genre>Fantasy</genre>
|
||||||
|
<price>5.95</price>
|
||||||
|
<publish_date>2000-12-16</publish_date>
|
||||||
|
<description>A former architect battles corporate zombies,
|
||||||
|
an evil sorceress, and her own childhood to become queen
|
||||||
|
of the world.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk103 " >
|
||||||
|
<author>Corets, Eva</author>
|
||||||
|
<title>Maeve Ascendant</title>
|
||||||
|
<genre>Fantasy</genre>
|
||||||
|
<price>5.95</price>
|
||||||
|
<publish_date>2000-11-17</publish_date>
|
||||||
|
<description>After the collapse of a nanotechnology
|
||||||
|
society in England, the young survivors lay the
|
||||||
|
foundation for a new society.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk104 " >
|
||||||
|
<author>Corets, Eva</author>
|
||||||
|
<title>Oberon's Legacy</title>
|
||||||
|
<genre>Fantasy</genre>
|
||||||
|
<price>5.95</price>
|
||||||
|
<publish_date>2001-03-10</publish_date>
|
||||||
|
<description>In post-apocalypse England, the mysterious
|
||||||
|
agent known only as Oberon helps to create a new life
|
||||||
|
for the inhabitants of London. Sequel to Maeve
|
||||||
|
Ascendant.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk105 " >
|
||||||
|
<author>Corets, Eva</author>
|
||||||
|
<title>The Sundered Grail</title>
|
||||||
|
<genre>Fantasy</genre>
|
||||||
|
<price>5.95</price>
|
||||||
|
<publish_date>2001-09-10</publish_date>
|
||||||
|
<description>The two daughters of Maeve, half-sisters,
|
||||||
|
battle one another for control of England. Sequel to
|
||||||
|
Oberon's Legacy.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk106 " >
|
||||||
|
<author>Randall, Cynthia</author>
|
||||||
|
<title>Lover Birds</title>
|
||||||
|
<genre>Romance</genre>
|
||||||
|
<price>4.95</price>
|
||||||
|
<publish_date>2000-09-02</publish_date>
|
||||||
|
<description>When Carla meets Paul at an ornithology
|
||||||
|
conference, tempers fly as feathers get ruffled.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk107 " >
|
||||||
|
<author>Thurman, Paula</author>
|
||||||
|
<title>Splish Splash</title>
|
||||||
|
<genre>Romance</genre>
|
||||||
|
<price>4.95</price>
|
||||||
|
<publish_date>2000-11-02</publish_date>
|
||||||
|
<description>A deep sea diver finds true love twenty
|
||||||
|
thousand leagues beneath the sea.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk108 " >
|
||||||
|
<author>Knorr, Stefan</author>
|
||||||
|
<title>Creepy Crawlies</title>
|
||||||
|
<genre>Horror</genre>
|
||||||
|
<price>4.95</price>
|
||||||
|
<publish_date>2000-12-06</publish_date>
|
||||||
|
<description>An anthology of horror stories about roaches,
|
||||||
|
centipedes, scorpions and other insects.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk109 " >
|
||||||
|
<author>Kress, Peter</author>
|
||||||
|
<title>Paradox Lost</title>
|
||||||
|
<genre>Science Fiction</genre>
|
||||||
|
<price>6.95</price>
|
||||||
|
<publish_date>2000-11-02</publish_date>
|
||||||
|
<description>After an inadvertant trip through a Heisenberg
|
||||||
|
Uncertainty Device, James Salway discovers the problems
|
||||||
|
of being quantum.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk110 " >
|
||||||
|
<author>O'Brien, Tim</author>
|
||||||
|
<title>Microsoft .NET: The Programming Bible</title>
|
||||||
|
<genre>Computer</genre>
|
||||||
|
<price>36.95</price>
|
||||||
|
<publish_date>2000-12-09</publish_date>
|
||||||
|
<description>Microsoft's .NET initiative is explored in
|
||||||
|
detail in this deep programmer's reference.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk111 " >
|
||||||
|
<author>O'Brien, Tim</author>
|
||||||
|
<title>MSXML3: A Comprehensive Guide</title>
|
||||||
|
<genre>Computer</genre>
|
||||||
|
<price>36.95</price>
|
||||||
|
<publish_date>2000-12-01</publish_date>
|
||||||
|
<description>The Microsoft MSXML3 parser is covered in
|
||||||
|
detail, with attention to XML DOM interfaces, XSLT processing,
|
||||||
|
SAX and more.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk112 " >
|
||||||
|
<author>Galos, Mike</author>
|
||||||
|
<title>Visual Studio 7: A Comprehensive Guide</title>
|
||||||
|
<genre>Computer</genre>
|
||||||
|
<price>49.95</price>
|
||||||
|
<publish_date>2001-04-16</publish_date>
|
||||||
|
<description>Microsoft Visual Studio 7 is explored in depth,
|
||||||
|
looking at how Visual Basic, Visual C++, C#, and ASP+ are
|
||||||
|
integrated into a comprehensive development
|
||||||
|
environment.</description>
|
||||||
|
</book>
|
||||||
|
</catalog>
|
120
test/jaxp/javax/xml/jaxp/unittest/transform/StAX2DOMTest1.xml
Normal file
120
test/jaxp/javax/xml/jaxp/unittest/transform/StAX2DOMTest1.xml
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<catalog>
|
||||||
|
<book id= " bk101 " >
|
||||||
|
<author>Gambardella, Matthew</author>
|
||||||
|
<title>XML Developer's Guide</title>
|
||||||
|
<genre>Computer</genre>
|
||||||
|
<price>44.95</price>
|
||||||
|
<publish_date>2000-10-01</publish_date>
|
||||||
|
<description>An in-depth look at creating applications
|
||||||
|
with XML.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk102 " >
|
||||||
|
<author>Ralls, Kim</author>
|
||||||
|
<title>Midnight Rain</title>
|
||||||
|
<genre>Fantasy</genre>
|
||||||
|
<price>5.95</price>
|
||||||
|
<publish_date>2000-12-16</publish_date>
|
||||||
|
<description>A former architect battles corporate zombies,
|
||||||
|
an evil sorceress, and her own childhood to become queen
|
||||||
|
of the world.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk103 " >
|
||||||
|
<author>Corets, Eva</author>
|
||||||
|
<title>Maeve Ascendant</title>
|
||||||
|
<genre>Fantasy</genre>
|
||||||
|
<price>5.95</price>
|
||||||
|
<publish_date>2000-11-17</publish_date>
|
||||||
|
<description>After the collapse of a nanotechnology
|
||||||
|
society in England, the young survivors lay the
|
||||||
|
foundation for a new society.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk104 " >
|
||||||
|
<author>Corets, Eva</author>
|
||||||
|
<title>Oberon's Legacy</title>
|
||||||
|
<genre>Fantasy</genre>
|
||||||
|
<price>5.95</price>
|
||||||
|
<publish_date>2001-03-10</publish_date>
|
||||||
|
<description>In post-apocalypse England, the mysterious
|
||||||
|
agent known only as Oberon helps to create a new life
|
||||||
|
for the inhabitants of London. Sequel to Maeve
|
||||||
|
Ascendant.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk105 " >
|
||||||
|
<author>Corets, Eva</author>
|
||||||
|
<title>The Sundered Grail</title>
|
||||||
|
<genre>Fantasy</genre>
|
||||||
|
<price>5.95</price>
|
||||||
|
<publish_date>2001-09-10</publish_date>
|
||||||
|
<description>The two daughters of Maeve, half-sisters,
|
||||||
|
battle one another for control of England. Sequel to
|
||||||
|
Oberon's Legacy.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk106 " >
|
||||||
|
<author>Randall, Cynthia</author>
|
||||||
|
<title>Lover Birds</title>
|
||||||
|
<genre>Romance</genre>
|
||||||
|
<price>4.95</price>
|
||||||
|
<publish_date>2000-09-02</publish_date>
|
||||||
|
<description>When Carla meets Paul at an ornithology
|
||||||
|
conference, tempers fly as feathers get ruffled.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk107 " >
|
||||||
|
<author>Thurman, Paula</author>
|
||||||
|
<title>Splish Splash</title>
|
||||||
|
<genre>Romance</genre>
|
||||||
|
<price>4.95</price>
|
||||||
|
<publish_date>2000-11-02</publish_date>
|
||||||
|
<description>A deep sea diver finds true love twenty
|
||||||
|
thousand leagues beneath the sea.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk108 " >
|
||||||
|
<author>Knorr, Stefan</author>
|
||||||
|
<title>Creepy Crawlies</title>
|
||||||
|
<genre>Horror</genre>
|
||||||
|
<price>4.95</price>
|
||||||
|
<publish_date>2000-12-06</publish_date>
|
||||||
|
<description>An anthology of horror stories about roaches,
|
||||||
|
centipedes, scorpions and other insects.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk109 " >
|
||||||
|
<author>Kress, Peter</author>
|
||||||
|
<title>Paradox Lost</title>
|
||||||
|
<genre>Science Fiction</genre>
|
||||||
|
<price>6.95</price>
|
||||||
|
<publish_date>2000-11-02</publish_date>
|
||||||
|
<description>After an inadvertant trip through a Heisenberg
|
||||||
|
Uncertainty Device, James Salway discovers the problems
|
||||||
|
of being quantum.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk110 " >
|
||||||
|
<author>O'Brien, Tim</author>
|
||||||
|
<title>Microsoft .NET: The Programming Bible</title>
|
||||||
|
<genre>Computer</genre>
|
||||||
|
<price>36.95</price>
|
||||||
|
<publish_date>2000-12-09</publish_date>
|
||||||
|
<description>Microsoft's .NET initiative is explored in
|
||||||
|
detail in this deep programmer's reference.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk111 " >
|
||||||
|
<author>O'Brien, Tim</author>
|
||||||
|
<title>MSXML3: A Comprehensive Guide</title>
|
||||||
|
<genre>Computer</genre>
|
||||||
|
<price>36.95</price>
|
||||||
|
<publish_date>2000-12-01</publish_date>
|
||||||
|
<description>The Microsoft MSXML3 parser is covered in
|
||||||
|
detail, with attention to XML DOM interfaces, XSLT processing,
|
||||||
|
SAX and more.</description>
|
||||||
|
</book>
|
||||||
|
<book id= " bk112 " >
|
||||||
|
<author>Galos, Mike</author>
|
||||||
|
<title>Visual Studio 7: A Comprehensive Guide</title>
|
||||||
|
<genre>Computer</genre>
|
||||||
|
<price>49.95</price>
|
||||||
|
<publish_date>2001-04-16</publish_date>
|
||||||
|
<description>Microsoft Visual Studio 7 is explored in depth,
|
||||||
|
looking at how Visual Basic, Visual C++, C#, and ASP+ are
|
||||||
|
integrated into a comprehensive development
|
||||||
|
environment.</description>
|
||||||
|
</book>
|
||||||
|
</catalog>
|
Loading…
Reference in New Issue
Block a user