Merge pull request #989 from afs/jena2097-iri

 JENA-2097: Bad URIs are parser warnings
diff --git a/jena-base/src/main/java/org/apache/jena/atlas/lib/EscapeStr.java b/jena-base/src/main/java/org/apache/jena/atlas/lib/EscapeStr.java
index 2733442..a6c3455 100644
--- a/jena-base/src/main/java/org/apache/jena/atlas/lib/EscapeStr.java
+++ b/jena-base/src/main/java/org/apache/jena/atlas/lib/EscapeStr.java
@@ -215,7 +215,6 @@
             {
                 sb.append('\\') ;
                 sb.append(ch2) ;
-                i = i + 1 ;
                 continue ;
             }
 
diff --git a/jena-base/src/test/java/org/apache/jena/atlas/lib/TestEscapeStr.java b/jena-base/src/test/java/org/apache/jena/atlas/lib/TestEscapeStr.java
index 74e407a..84d8e83 100644
--- a/jena-base/src/test/java/org/apache/jena/atlas/lib/TestEscapeStr.java
+++ b/jena-base/src/test/java/org/apache/jena/atlas/lib/TestEscapeStr.java
@@ -21,18 +21,17 @@
 import org.junit.Assert ;
 import org.junit.Test ;
 
-// Testing is a bit light here but the RDF term output and 
+// Testing is a bit light here but the RDF term output and
 // the language level output covers the ground as well.
-// See TestQuotedString in ARQ.
 
 public class TestEscapeStr {
-    
+
     @Test public void escape_str_01()   { test_esc("", "") ; }
     @Test public void escape_str_02()   { test_esc("A", "A") ; }
     @Test public void escape_str_03()   { test_esc("\n", "\\n") ; }
     @Test public void escape_str_04()   { test_esc("A\tB", "A\\tB") ; }
     @Test public void escape_str_05()   { test_esc("\"", "\\\"") ; }
-    
+
     @Test public void unescape_str_10()   { test_unesc("\\u0041", "A") ; }
     @Test public void unescape_str_11()   { test_unesc("\\U00000041", "A") ; }
     @Test public void unescape_str_12()   { test_unesc("12\\u004134", "12A34") ; }
@@ -42,10 +41,26 @@
         String output = EscapeStr.stringEsc(input) ;
         Assert.assertEquals(expected, output);
     }
-    
+
     private void test_unesc(String input, String expected) {
         String output = EscapeStr.unescapeStr(input) ;
         Assert.assertEquals(expected, output);
     }
-    
+
+    @Test public void unescape_unicode_1()   { test_unesc_unicode("", "") ; }
+    @Test public void unescape_unicode_2()   { test_unesc_unicode("abc\\u0020def", "abc def") ; }
+    @Test public void unescape_unicode_3()   { test_unesc_unicode("\\u0020", " ") ; }
+    @Test public void unescape_unicode_4()   { test_unesc_unicode("abc\\U00000020def", "abc def") ; }
+    @Test public void unescape_unicode_5()   { test_unesc_unicode("\\U00000020", " ") ; }
+
+    // Leaves non-unicode untouched.
+    @Test public void unescape_unicode_10()   { test_unesc_unicode("\\1\\2", "\\1\\2") ; }
+    @Test public void unescape_unicode_11()   { test_unesc_unicode("\\n\\t", "\\n\\t") ; }
+    @Test public void unescape_unicode_12()   { test_unesc_unicode("\\(\\)", "\\(\\)") ; }
+    @Test public void unescape_unicode_13()   { test_unesc_unicode("\\\\", "\\\\") ; }
+
+    private void test_unesc_unicode(String input, String expected) {
+        String output = EscapeStr.unescapeUnicode(input) ;
+        Assert.assertEquals(expected, output);
+    }
 }
diff --git a/pom.xml b/pom.xml
index 224f742..2506c0c 100644
--- a/pom.xml
+++ b/pom.xml
@@ -57,7 +57,7 @@
     <ver.log4j2>2.14.1</ver.log4j2>
     <ver.shade-plugin>3.2.4</ver.shade-plugin>
 
-    <ver.jetty>9.4.39.v20210325</ver.jetty>
+    <ver.jetty>9.4.40.v20210413</ver.jetty>
     <ver.shiro>1.7.1</ver.shiro>
 
     <ver.libthrift>0.14.1</ver.libthrift>
@@ -70,8 +70,8 @@
          POM for the correct dependency versions
          and use that or later.
     -->
-    <ver.jsonldjava>0.13.2</ver.jsonldjava>
-    <ver.jackson>2.12.2</ver.jackson>
+    <ver.jsonldjava>0.13.3</ver.jsonldjava>
+    <ver.jackson>2.12.3</ver.jackson>
 
     <ver.commonsio>2.8.0</ver.commonsio>
     <ver.commonscli>1.4</ver.commonscli>
@@ -82,7 +82,7 @@
     <ver.commons-compress>1.20</ver.commons-compress>
 
     <ver.dexxcollection>0.7</ver.dexxcollection>
-    <ver.micrometer>1.6.5</ver.micrometer>
+    <ver.micrometer>1.6.6</ver.micrometer>
 
     <ver.httpclient>4.5.13</ver.httpclient>
     <ver.httpcore>4.4.14</ver.httpcore>
@@ -93,10 +93,10 @@
     <ver.httpclient-osgi>${ver.httpclient}</ver.httpclient-osgi>
     
     <ver.lucene>8.8.0</ver.lucene>
-    <ver.graalvm>21.0.0.2</ver.graalvm>
+    <ver.graalvm>21.1.0</ver.graalvm>
     <ver.jython>2.7.2</ver.jython>
     <ver.jcommander>1.81</ver.jcommander>
-    <ver.mockito>3.8.0</ver.mockito>
+    <ver.mockito>3.9.0</ver.mockito>
     <ver.awaitility>4.0.3</ver.awaitility>
     <ver.contract.tests>0.2.0</ver.contract.tests>