HDFS-12974. Exception message is not printed when creating an encryption zone fails with AuthorizationException. Contributed by fang zhenyi.
(cherry picked from commitb63dcd583f
) (cherry picked from commit75be15cf02
) Conflicts: hadoop-hdfs-project/hadoop-hdfs/src/main/java/org/apache/hadoop/hdfs/server/namenode/EncryptionFaultInjector.java
This commit is contained in:
parent
0497e09339
commit
0922ea0aaf
|
@ -64,17 +64,19 @@ public class AuthorizationException extends AccessControlException {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void printStackTrace() {
|
public void printStackTrace() {
|
||||||
// Do not provide the stack-trace
|
printStackTrace(System.err);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void printStackTrace(PrintStream s) {
|
public void printStackTrace(PrintStream s) {
|
||||||
// Do not provide the stack-trace
|
// Do not provide the stack-trace
|
||||||
|
s.println(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void printStackTrace(PrintWriter s) {
|
public void printStackTrace(PrintWriter s) {
|
||||||
// Do not provide the stack-trace
|
// Do not provide the stack-trace
|
||||||
|
s.println(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,4 +42,7 @@ public class EncryptionFaultInjector {
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
public void startFileAfterGenerateKey() throws IOException {}
|
public void startFileAfterGenerateKey() throws IOException {}
|
||||||
|
|
||||||
|
@VisibleForTesting
|
||||||
|
public void ensureKeyIsInitialized() throws IOException {}
|
||||||
}
|
}
|
||||||
|
|
|
@ -114,6 +114,7 @@ final class FSDirEncryptionZoneOp {
|
||||||
throw new IOException("Must specify a key name when creating an "
|
throw new IOException("Must specify a key name when creating an "
|
||||||
+ "encryption zone");
|
+ "encryption zone");
|
||||||
}
|
}
|
||||||
|
EncryptionFaultInjector.getInstance().ensureKeyIsInitialized();
|
||||||
KeyProvider.Metadata metadata = provider.getMetadata(keyName);
|
KeyProvider.Metadata metadata = provider.getMetadata(keyName);
|
||||||
if (metadata == null) {
|
if (metadata == null) {
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -82,9 +82,11 @@ import org.apache.hadoop.hdfs.web.WebHdfsConstants;
|
||||||
import org.apache.hadoop.hdfs.web.WebHdfsFileSystem;
|
import org.apache.hadoop.hdfs.web.WebHdfsFileSystem;
|
||||||
import org.apache.hadoop.hdfs.web.WebHdfsTestUtil;
|
import org.apache.hadoop.hdfs.web.WebHdfsTestUtil;
|
||||||
import org.apache.hadoop.io.EnumSetWritable;
|
import org.apache.hadoop.io.EnumSetWritable;
|
||||||
|
import org.apache.hadoop.ipc.RemoteException;
|
||||||
import org.apache.hadoop.security.AccessControlException;
|
import org.apache.hadoop.security.AccessControlException;
|
||||||
import org.apache.hadoop.security.Credentials;
|
import org.apache.hadoop.security.Credentials;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
|
import org.apache.hadoop.security.authorize.AuthorizationException;
|
||||||
import org.apache.hadoop.security.token.Token;
|
import org.apache.hadoop.security.token.Token;
|
||||||
import org.apache.hadoop.util.DataChecksum;
|
import org.apache.hadoop.util.DataChecksum;
|
||||||
import org.apache.hadoop.util.ToolRunner;
|
import org.apache.hadoop.util.ToolRunner;
|
||||||
|
@ -151,6 +153,9 @@ public class TestEncryptionZones {
|
||||||
private File testRootDir;
|
private File testRootDir;
|
||||||
protected final String TEST_KEY = "test_key";
|
protected final String TEST_KEY = "test_key";
|
||||||
private static final String NS_METRICS = "FSNamesystem";
|
private static final String NS_METRICS = "FSNamesystem";
|
||||||
|
private static final String AUTHORIZATION_EXCEPTION_MESSAGE =
|
||||||
|
"User [root] is not authorized to perform [READ] on key " +
|
||||||
|
"with ACL name [key2]!!";
|
||||||
|
|
||||||
protected FileSystemTestWrapper fsWrapper;
|
protected FileSystemTestWrapper fsWrapper;
|
||||||
protected FileContextTestWrapper fcWrapper;
|
protected FileContextTestWrapper fcWrapper;
|
||||||
|
@ -449,7 +454,6 @@ public class TestEncryptionZones {
|
||||||
dfsAdmin.createEncryptionZone(zone2, myKeyName, NO_TRASH);
|
dfsAdmin.createEncryptionZone(zone2, myKeyName, NO_TRASH);
|
||||||
assertNumZones(++numZones);
|
assertNumZones(++numZones);
|
||||||
assertZonePresent(myKeyName, zone2.toString());
|
assertZonePresent(myKeyName, zone2.toString());
|
||||||
|
|
||||||
/* Test failure of create encryption zones as a non super user. */
|
/* Test failure of create encryption zones as a non super user. */
|
||||||
final UserGroupInformation user = UserGroupInformation.
|
final UserGroupInformation user = UserGroupInformation.
|
||||||
createUserForTesting("user", new String[] { "mygroup" });
|
createUserForTesting("user", new String[] { "mygroup" });
|
||||||
|
@ -1070,6 +1074,31 @@ public class TestEncryptionZones {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class AuthorizationExceptionInjector extends EncryptionFaultInjector {
|
||||||
|
@Override
|
||||||
|
public void ensureKeyIsInitialized() throws IOException {
|
||||||
|
throw new AuthorizationException(AUTHORIZATION_EXCEPTION_MESSAGE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testExceptionInformationReturn() {
|
||||||
|
/* Test exception information can be returned when
|
||||||
|
creating transparent encryption zone.*/
|
||||||
|
final Path zone1 = new Path("/zone1");
|
||||||
|
EncryptionFaultInjector.instance = new AuthorizationExceptionInjector();
|
||||||
|
try {
|
||||||
|
dfsAdmin.createEncryptionZone(zone1, TEST_KEY, NO_TRASH);
|
||||||
|
fail("exception information can be returned when creating " +
|
||||||
|
"transparent encryption zone");
|
||||||
|
} catch (IOException e) {
|
||||||
|
assertTrue(e instanceof RemoteException);
|
||||||
|
assertTrue(((RemoteException) e).unwrapRemoteException()
|
||||||
|
instanceof AuthorizationException);
|
||||||
|
assertExceptionContains(AUTHORIZATION_EXCEPTION_MESSAGE, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private class MyInjector extends EncryptionFaultInjector {
|
private class MyInjector extends EncryptionFaultInjector {
|
||||||
volatile int generateCount;
|
volatile int generateCount;
|
||||||
CountDownLatch ready;
|
CountDownLatch ready;
|
||||||
|
|
Loading…
Reference in New Issue