diff --git a/hbase-common/src/test/java/org/apache/hadoop/hbase/TestHBaseConfiguration.java b/hbase-common/src/test/java/org/apache/hadoop/hbase/TestHBaseConfiguration.java index cb422c0..a7afa33 100644 --- a/hbase-common/src/test/java/org/apache/hadoop/hbase/TestHBaseConfiguration.java +++ b/hbase-common/src/test/java/org/apache/hadoop/hbase/TestHBaseConfiguration.java @@ -110,9 +110,21 @@ public class TestHBaseConfiguration { @Test public void testGetPassword() throws Exception { Configuration conf = HBaseConfiguration.create(); - conf.set(ReflectiveCredentialProviderClient.CREDENTIAL_PROVIDER_PATH, "jceks://file" - + new File(UTIL.getDataTestDir().toUri().getPath(), "foo.jks").getCanonicalPath()); + + StringBuilder jceksPath = new StringBuilder("jceks://file"); + String localPath = new File(UTIL.getDataTestDir().toUri().getPath(), + "foo.jks").getCanonicalPath(); + localPath = localPath.replace('\\', '/'); + if(!localPath.startsWith("/")) { + //For windows path such as D:\dir\dir1 + jceksPath.append("/"); + } + jceksPath.append(localPath); + conf.set(ReflectiveCredentialProviderClient.CREDENTIAL_PROVIDER_PATH, + jceksPath.toString()); + ReflectiveCredentialProviderClient client = new ReflectiveCredentialProviderClient(); + if (client.isHadoopCredentialProviderAvailable()) { char[] keyPass = { 'k', 'e', 'y', 'p', 'a', 's', 's' }; char[] storePass = { 's', 't', 'o', 'r', 'e', 'p', 'a', 's', 's' };