Author: angela
Date: Wed Apr 10 12:29:29 2019
New Revision: 1857242

URL: http://svn.apache.org/viewvc?rev=1857242&view=rev
Log:
OAK-8212 : ImporterImpl.importProperties prone to NPE

Modified:
    
jackrabbit/oak/trunk/oak-jcr/src/main/java/org/apache/jackrabbit/oak/jcr/xml/ImporterImpl.java
    
jackrabbit/oak/trunk/oak-jcr/src/test/java/org/apache/jackrabbit/oak/jcr/xml/ImportTest.java

Modified: 
jackrabbit/oak/trunk/oak-jcr/src/main/java/org/apache/jackrabbit/oak/jcr/xml/ImporterImpl.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-jcr/src/main/java/org/apache/jackrabbit/oak/jcr/xml/ImporterImpl.java?rev=1857242&r1=1857241&r2=1857242&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-jcr/src/main/java/org/apache/jackrabbit/oak/jcr/xml/ImporterImpl.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-jcr/src/main/java/org/apache/jackrabbit/oak/jcr/xml/ImporterImpl.java
 Wed Apr 10 12:29:29 2019
@@ -272,6 +272,9 @@ public class ImporterImpl implements Imp
             //TODO find better heuristics?
             EffectiveNodeType ent = 
effectiveNodeTypeProvider.getEffectiveNodeType(tree);
             PropertyDefinition def = ent.getPropertyDefinition(pi.getName(), 
pi.getType(), pi.isUnknownMultiple());
+            if (def == null) {
+                throw new ConstraintViolationException("No matching property 
definition found for " + pi.getName());
+            }
             if (def.isProtected()) {
                 // skip protected property
                 log.debug("Protected property {}", pi.getName());

Modified: 
jackrabbit/oak/trunk/oak-jcr/src/test/java/org/apache/jackrabbit/oak/jcr/xml/ImportTest.java
URL: 
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-jcr/src/test/java/org/apache/jackrabbit/oak/jcr/xml/ImportTest.java?rev=1857242&r1=1857241&r2=1857242&view=diff
==============================================================================
--- 
jackrabbit/oak/trunk/oak-jcr/src/test/java/org/apache/jackrabbit/oak/jcr/xml/ImportTest.java
 (original)
+++ 
jackrabbit/oak/trunk/oak-jcr/src/test/java/org/apache/jackrabbit/oak/jcr/xml/ImportTest.java
 Wed Apr 10 12:29:29 2019
@@ -29,6 +29,9 @@ import javax.jcr.nodetype.ConstraintViol
 
 import org.apache.jackrabbit.test.AbstractJCRTest;
 
+import static org.apache.jackrabbit.JcrConstants.JCR_DATA;
+import static org.apache.jackrabbit.JcrConstants.JCR_PRIMARYTYPE;
+
 public class ImportTest extends AbstractJCRTest {
 
     private String uuid;
@@ -226,4 +229,23 @@ public class ImportTest extends Abstract
             // success
         }
     }
+
+    /**
+     * @see <a 
href="https://issues.apache.org/jira/browse/OAK-8212";>OAK-8212</a>
+     */
+    public void testNoMatchingPropertyDefinition() throws Exception {
+        // jcr:data must be BINARY not BOOLEAN -> should fail
+        String xml = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" +
+                "<sv:node sv:name=\"resourceName\" 
xmlns:mix=\"http://www.jcp.org/jcr/mix/1.0\"; 
xmlns:nt=\"http://www.jcp.org/jcr/nt/1.0\"; 
xmlns:fn_old=\"http://www.w3.org/2004/10/xpath-functions\"; 
xmlns:fn=\"http://www.w3.org/2005/xpath-functions\"; 
xmlns:xs=\"http://www.w3.org/2001/XMLSchema\"; 
xmlns:sv=\"http://www.jcp.org/jcr/sv/1.0\"; xmlns:rep=\"internal\" 
xmlns:jcr=\"http://www.jcp.org/jcr/1.0\";>" +
+                    "<sv:property sv:name=\"jcr:primaryType\" 
sv:type=\"Name\"><sv:value>oak:Resource</sv:value></sv:property>" +
+                    "<sv:property sv:name=\"jcr:data\" 
sv:type=\"Boolean\"><sv:value>true</sv:value></sv:property>" +
+                "</sv:node>";
+        try {
+            superuser.importXML(path, new 
ByteArrayInputStream(xml.getBytes()), 
ImportUUIDBehavior.IMPORT_UUID_CREATE_NEW);
+            fail("ConstraintViolationException expected");
+        } catch (ConstraintViolationException e) {
+            // success
+            assertEquals("No matching property definition found for jcr:data", 
e.getMessage());
+        }
+    }
 }
\ No newline at end of file


Reply via email to