From 5dcfefbae05b25d0c24d469ae5a10d5d112df1a9 Mon Sep 17 00:00:00 2001 From: Joe Wang Date: Tue, 16 Jul 2019 21:12:14 +0000 Subject: [PATCH] 8176447: javax.xml.validation.Validator validates incorrectly on uniqueness constraint Reviewed-by: lancea --- .../impl/xs/identity/XPathMatcher.java | 68 +++++++++++-------- .../unittest/validation/ValidationTest.java | 28 +++++++- .../unittest/validation/files/JDK8176447a.xml | 8 +++ .../unittest/validation/files/JDK8176447a.xsd | 24 +++++++ .../unittest/validation/files/JDK8176447b.xml | 14 ++++ .../unittest/validation/files/JDK8176447b.xsd | 34 ++++++++++ 6 files changed, 148 insertions(+), 28 deletions(-) create mode 100644 test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447a.xml create mode 100644 test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447a.xsd create mode 100644 test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447b.xml create mode 100644 test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447b.xsd diff --git a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/identity/XPathMatcher.java b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/identity/XPathMatcher.java index c357d0be657..2b05aaa9f02 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/identity/XPathMatcher.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/identity/XPathMatcher.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -37,6 +37,7 @@ import org.xml.sax.SAXException; * @xerces.internal * * @author Andy Clark, IBM + * @LastModified: July 2019 * */ public class XPathMatcher { @@ -88,25 +89,25 @@ public class XPathMatcher { // /** XPath location path. */ - private XPath.LocationPath[] fLocationPaths; + private final XPath.LocationPath[] fLocationPaths; /** True if XPath has been matched. */ - private int[] fMatched; + private final int[] fMatched; /** The matching string. */ protected Object fMatchedString; /** Integer stack of step indexes. */ - private IntStack[] fStepIndexes; + private final IntStack[] fStepIndexes; /** Current step. */ - private int[] fCurrentStep; + private final int[] fCurrentStep; /** * No match depth. The value of this field will be zero while * matching is successful for the given xpath expression. */ - private int [] fNoMatchDepth; + private final int [] fNoMatchDepth; final QName fQName = new QName(); @@ -207,7 +208,7 @@ public class XPathMatcher { * * @throws SAXException Thrown by handler to signal an error. */ - public void startElement(QName element, XMLAttributes attributes){ + public void startElement(QName element, XMLAttributes attributes) { if (DEBUG_METHODS2) { System.out.println(toString()+"#startElement("+ "element={"+element+"},"+ @@ -215,7 +216,7 @@ public class XPathMatcher { ")"); } - for(int i = 0; i < fLocationPaths.length; i++) { + for (int i = 0; i < fLocationPaths.length; i++) { // push context int startStep = fCurrentStep[i]; fStepIndexes[i].push(startStep); @@ -284,18 +285,16 @@ public class XPathMatcher { if (DEBUG_MATCH) { System.out.println(toString()+" [CHILD] before"); } - if (nodeTest.type == XPath.NodeTest.QNAME) { - if (!nodeTest.name.equals(element)) { - if(fCurrentStep[i] > descendantStep) { - fCurrentStep[i] = descendantStep; - continue; - } - fNoMatchDepth[i]++; - if (DEBUG_MATCH) { - System.out.println(toString()+" [CHILD] after NO MATCH"); - } + if (!matches(nodeTest, element)) { + if (fCurrentStep[i] > descendantStep) { + fCurrentStep[i] = descendantStep; continue; } + fNoMatchDepth[i]++; + if (DEBUG_MATCH) { + System.out.println(toString()+" [CHILD] after NO MATCH"); + } + continue; } fCurrentStep[i]++; if (DEBUG_MATCH) { @@ -303,10 +302,11 @@ public class XPathMatcher { } } if (fCurrentStep[i] == steps.length) { - if(sawDescendant) { + if (sawDescendant) { fCurrentStep[i] = descendantStep; fMatched[i] = MATCHED_DESCENDANT; - } else { + } + else { fMatched[i] = MATCHED; } continue; @@ -324,8 +324,7 @@ public class XPathMatcher { for (int aIndex = 0; aIndex < attrCount; aIndex++) { attributes.getName(aIndex, fQName); - if (nodeTest.type != XPath.NodeTest.QNAME || - nodeTest.name.equals(fQName)) { + if (matches(nodeTest, fQName)) { fCurrentStep[i]++; if (fCurrentStep[i] == steps.length) { fMatched[i] = MATCHED_ATTRIBUTE; @@ -384,7 +383,7 @@ public class XPathMatcher { "element={"+element+"},"+ ")"); } - for(int i = 0; i + + + + + diff --git a/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447a.xsd b/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447a.xsd new file mode 100644 index 00000000000..f418db9dc73 --- /dev/null +++ b/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447a.xsd @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + + + + + + + + diff --git a/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447b.xml b/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447b.xml new file mode 100644 index 00000000000..8c2b08e8aa8 --- /dev/null +++ b/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447b.xml @@ -0,0 +1,14 @@ + + + + + + + + + + + + + diff --git a/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447b.xsd b/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447b.xsd new file mode 100644 index 00000000000..2bf71fdb1fb --- /dev/null +++ b/test/jaxp/javax/xml/jaxp/unittest/validation/files/JDK8176447b.xsd @@ -0,0 +1,34 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +