You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@jena.apache.org by "Matthew Jarvis (JIRA)" <ji...@apache.org> on 2014/11/06 19:24:34 UTC

[jira] [Created] (JENA-811) org.apache.jena.riot.system.IRIResolver doesn't allow for any control over violation error/warning settings

Matthew Jarvis created JENA-811:
-----------------------------------

             Summary: org.apache.jena.riot.system.IRIResolver doesn't allow for any control over violation error/warning settings
                 Key: JENA-811
                 URL: https://issues.apache.org/jira/browse/JENA-811
             Project: Apache Jena
          Issue Type: Bug
          Components: IRI
    Affects Versions: Jena 2.11.2
            Reporter: Matthew Jarvis


The IRIResolver class has a public static iriFactory that is used for creating IRIs, but consumers never have a chance to call IRIResolver.iriFactory#setIsError or IRIResolver.iriFactory#setIsWarning because the iriFactory is used in a static block when the class is loaded.  Any attempts to call either the setIsError or setIsWarning method throw the following exception:

java.lang.IllegalStateException: Cannot reinitialize IRIFactory after first use.
	at org.apache.jena.iri.impl.IRIFactoryImpl.initializing(IRIFactoryImpl.java:255)
	at org.apache.jena.iri.IRIFactory.setIsError(IRIFactory.java:579)
...

A simple test case that illustrates the problem is:

@Test
public void testIgnoreLowercaseViolation() {
  IRIResolver.iriFactory.setIsError(ViolationCodes.LOWERCASE_PREFERRED, false);
  IRIResolver.resolveIRI("http://EXAMPLE.com");
}



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)