Project

Profile

Help

Bug #4445

closed

Problem with validation [ArrayIndexOutOfBoundsException in TinyTree]

Added by Mathieu Bergonzini over 4 years ago. Updated about 4 years ago.

Status:
Closed
Priority:
Normal
Assignee:
Category:
Schema conformance
Sprint/Milestone:
-
Start date:
2020-01-29
Due date:
% Done:

100%

Estimated time:
Legacy ID:
Applies to branch:
9.8, 9.9, trunk
Fix Committed on Branch:
9.8, 9.9, trunk
Fixed in Maintenance Release:
Platforms:

Description

Hello, I have a problem with xml validation by xsd schema. Some files crash validation and I get this error message:

java.lang.ArrayIndexOutOfBoundsException: 32008
	at net.sf.saxon.tree.tiny.TinyParentNodeImpl.getStringValueCS(TinyParentNodeImpl.java:75)
	at net.sf.saxon.tree.tiny.TinyParentNodeImpl.getStringValueCS(TinyParentNodeImpl.java:49)
	at com.saxonica.ee.schema.UserSimpleType.atomize(UserSimpleType.java:490)
	at net.sf.saxon.tree.tiny.TinyTree.getTypedValueOfElement(TinyTree.java:548)
	at net.sf.saxon.tree.tiny.TinyElementImpl.atomize(TinyElementImpl.java:91)
	at net.sf.saxon.tree.wrapper.VirtualCopy.atomize(VirtualCopy.java:644)
	at net.sf.saxon.tree.iter.AtomizingIterator.next(AtomizingIterator.java:56)
	at net.sf.saxon.tree.iter.AtomizingIterator.next(AtomizingIterator.java:27)
	at com.saxonica.ee.optim.GeneralComparisonEE.effectiveBooleanValue(GeneralComparisonEE.java:101)
	at net.sf.saxon.expr.OrExpression.effectiveBooleanValue(OrExpression.java:134)
	at net.sf.saxon.expr.instruct.Choose.choose(Choose.java:901)
	at net.sf.saxon.expr.instruct.Choose.iterate(Choose.java:952)
	at net.sf.saxon.expr.Expression.effectiveBooleanValue(Expression.java:886)
	at net.sf.saxon.functions.NotFn$1.effectiveBooleanValue(NotFn.java:70)
	at net.sf.saxon.expr.FilterIterator$NonNumeric.matches(FilterIterator.java:186)
	at net.sf.saxon.expr.FilterIterator.getNextMatchingItem(FilterIterator.java:78)
	at net.sf.saxon.expr.FilterIterator.next(FilterIterator.java:64)
	at com.saxonica.ee.schema.Assertion.testComplex(Assertion.java:239)
	at com.saxonica.ee.validate.ValidationStack.testAssertions(ValidationStack.java:491)
	at com.saxonica.ee.validate.ValidationStack.endElement(ValidationStack.java:430)
	at net.sf.saxon.event.ProxyReceiver.endElement(ProxyReceiver.java:182)
	at net.sf.saxon.event.StartTagBuffer.endElement(StartTagBuffer.java:290)
	at com.saxonica.ee.validate.StartTagBufferEE.endElement(StartTagBufferEE.java:58)
	at net.sf.saxon.event.PathMaintainer.endElement(PathMaintainer.java:62)
	at net.sf.saxon.event.DocumentValidator.endElement(DocumentValidator.java:68)
	at net.sf.saxon.event.ReceivingContentHandler.endElement(ReceivingContentHandler.java:459)
	at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.endElement(AbstractSAXParser.java:609)
	at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanEndElement(XMLDocumentFragmentScannerImpl.java:1782)
	at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDriver.next(XMLDocumentFragmentScannerImpl.java:2967)
	at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:602)
	at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.next(XMLNSDocumentScannerImpl.java:112)
	at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:505)
	at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:842)
	at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:771)
	at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:141)
	at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1213)
	at com.sun.org.apache.xerces.internal.jaxp.SAXParserImpl$JAXPSAXParser.parse(SAXParserImpl.java:643)
	at net.sf.saxon.event.Sender.sendSAXSource(Sender.java:427)
	at net.sf.saxon.event.Sender.send(Sender.java:164)
	at com.saxonica.ee.s9api.SchemaValidatorImpl.validate(SchemaValidatorImpl.java:587)
	at fr.insee.test.saxonee.util.SaxonUtilTest.validateTestBug(SaxonUtilTest.java:71)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
	at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
	at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
	at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
	at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
	at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
	at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
	at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
	at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
	at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
	at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
	at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
	at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:89)
	at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:41)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:542)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:770)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:464)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:210)

Here is the code I use for validation:

        File schema = new File("./src/test/resources/shema.xsd");
	File file = new File("./src/test/resources/file-bug.xml");
	Processor proc = new Processor(true);
	proc.setConfigurationProperty(FeatureKeys.LICENSE_FILE_LOCATION, "./src/test/resources/saxon-license.lic");
	SchemaManager sm = proc.getSchemaManager();
	sm.setXsdVersion("1.1");
	sm.load(new StreamSource(schema));
	SchemaValidator sv = sm.newSchemaValidator();
	sv.setErrorListener(getErrorListener());
	sv.validate(new StreamSource(new FileInputStream(file)));

and the test files attached


Files

file-bug.xml (1.07 MB) file-bug.xml file test Mathieu Bergonzini, 2020-01-29 10:02
schema.xsd (65 KB) schema.xsd schema xsd Mathieu Bergonzini, 2020-01-29 10:02
xhtml.xsd (63.9 KB) xhtml.xsd Mathieu Bergonzini, 2020-01-29 10:02
xml.xsd (5.57 KB) xml.xsd Mathieu Bergonzini, 2020-01-29 10:02

Please register to edit this issue

Also available in: Atom PDF