[ 
https://issues.apache.org/jira/browse/HBASE-23892?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17047934#comment-17047934
 ] 

Hudson commented on HBASE-23892:
--------------------------------

Results for branch branch-2
        [build #2516 on 
builds.a.o|https://builds.apache.org/job/HBase%20Nightly/job/branch-2/2516/]: 
(x) *{color:red}-1 overall{color}*
----
details (if available):

(x) {color:red}-1 general checks{color}
-- Something went wrong running this stage, please [check relevant console 
output|https://builds.apache.org/job/HBase%20Nightly/job/branch-2/2516//console].




(x) {color:red}-1 jdk8 hadoop2 checks{color}
-- Something went wrong running this stage, please [check relevant console 
output|https://builds.apache.org/job/HBase%20Nightly/job/branch-2/2516//console].


(x) {color:red}-1 jdk8 hadoop3 checks{color}
-- Something went wrong running this stage, please [check relevant console 
output|https://builds.apache.org/job/HBase%20Nightly/job/branch-2/2516//console].


(/) {color:green}+1 source release artifact{color}
-- See build output for details.


(/) {color:green}+1 client integration test{color}


> SecureTestCluster should allow its subclasses to pass their Class reference 
> on HBaseKerberosUtils.setSSLConfiguration
> ---------------------------------------------------------------------------------------------------------------------
>
>                 Key: HBASE-23892
>                 URL: https://issues.apache.org/jira/browse/HBASE-23892
>             Project: HBase
>          Issue Type: Bug
>    Affects Versions: 3.0.0, 2.3.0, 2.2.3
>            Reporter: Wellington Chevreuil
>            Assignee: Wellington Chevreuil
>            Priority: Major
>             Fix For: 3.0.0, 2.3.0, 2.2.4
>
>
> Was working on a third party project that relies on hbase-server as a 
> dependency and defines a UT class that extends *SecureTestCluster*. In this 
> project, hbase-server jar is added on the test classpath, and it relies on 
> *KeyStoreTestUtil* to decide where to place related ssl files. Current 
> *KeyStoreTestUtil* code assumes related class files would be under an 
> existing local FS path, but when those are loaded from a jar, related class 
> URI path returns null and causes an NPE that errors out the test execution. 
>  
> The test code in this case extends *SecureTestCluster*, so when 
> *SecureTestCluster.setup* runs, it calls 
> *HBaseKerberosUtils.setSSLConfiguration* passing its own class reference 
> [here|https://github.com/apache/hbase/blob/master/hbase-server/src/test/java/org/apache/hadoop/hbase/security/token/SecureTestCluster.java#L72].
> **
> *HBaseKerberosUtils.setSSLConfiguration*, in turn, calls 
> *KeyStoreTestUtil.getClasspathDir* 
> [here|https://github.com/apache/hbase/blob/master/hbase-server/src/test/java/org/apache/hadoop/hbase/security/HBaseKerberosUtils.java#L173].
>  *KeyStoreTestUtil.getClasspathDir* uses the passed class reference name to 
> look for its related resource in the class loader. [This 
> line|https://github.com/apache/hbase/blob/master/hbase-http/src/test/java/org/apache/hadoop/hbase/http/ssl/KeyStoreTestUtil.java#L58]
>  returns an URL value as follows, when the passed class reference resource 
> resides on jar file in the class loader (instead of being in a valid local FS 
> path):
> {{jar:file:/Users/wellingtonchevreuil/.m2/repository/org/apache/hbase/hbase-server/2.2.3./hbase-server-2.2.3-tests.jar!/org/apache/hadoop/hbase/security/token/SecureTestCluster.class}}
> This causes [subsequent 
> line|https://github.com/apache/hbase/blob/master/hbase-http/src/test/java/org/apache/hadoop/hbase/http/ssl/KeyStoreTestUtil.java#L59]
>  calling {{url.toURI().getPath()}} to return null, then we get the NPE thrown 
> in the following line, and the test errors out:
> {{java.lang.NullPointerException at 
> org.apache.hadoop.hbase.http.ssl.KeyStoreTestUtil.getClasspathDir(KeyStoreTestUtil.java:59)
>  at 
> org.apache.hadoop.hbase.security.HBaseKerberosUtils.setSSLConfiguration(HBaseKerberosUtils.java:173)
>  at 
> org.apache.hadoop.hbase.security.token.SecureTestCluster.setUp(SecureTestCluster.java:74)
>  at 
> com.cloudera.hbase.security.token.TestCldrManualDelegationToken.setUp(TestCldrManualDelegationToken.java:168)
>  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.RunBefores.evaluate(RunBefores.java:24) 
> at 
> org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) 
> at 
> org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:298)
>  at 
> org.junit.internal.runners.statements.FailOnTimeout$CallableStatement.call(FailOnTimeout.java:292)
>  at java.util.concurrent.FutureTask.run$$$capture(FutureTask.java:266) at 
> java.util.concurrent.FutureTask.run(FutureTask.java) at 
> java.lang.Thread.run(Thread.java:748}}



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

Reply via email to