HADOOP-11117 UGI HadoopLoginModule doesn't catch & wrap all kerberos-related exceptions (stevel)
This commit is contained in:
parent
e2351e8512
commit
a19efe3b13
|
@ -565,6 +565,9 @@ Release 2.6.0 - UNRELEASED
|
|||
|
||||
HADOOP-11145. TestFairCallQueue fails. (Akira AJISAKA via cnauroth)
|
||||
|
||||
HADOOP-11117 UGI HadoopLoginModule doesn't catch & wrap all
|
||||
kerberos-related exceptions (stevel)
|
||||
|
||||
Release 2.5.1 - 2014-09-05
|
||||
|
||||
INCOMPATIBLE CHANGES
|
||||
|
|
|
@ -47,7 +47,8 @@ class User implements Principal {
|
|||
try {
|
||||
shortName = new HadoopKerberosName(name).getShortName();
|
||||
} catch (IOException ioe) {
|
||||
throw new IllegalArgumentException("Illegal principal name " + name, ioe);
|
||||
throw new IllegalArgumentException("Illegal principal name " + name
|
||||
+": " + ioe.toString(), ioe);
|
||||
}
|
||||
fullName = name;
|
||||
|
||||
|
|
|
@ -176,7 +176,21 @@ public class UserGroupInformation {
|
|||
}
|
||||
// if we found the user, add our principal
|
||||
if (user != null) {
|
||||
subject.getPrincipals().add(new User(user.getName()));
|
||||
if (LOG.isDebugEnabled()) {
|
||||
LOG.debug("Using user: \"" + user + "\" with name " + user.getName());
|
||||
}
|
||||
|
||||
User userEntry = null;
|
||||
try {
|
||||
userEntry = new User(user.getName());
|
||||
} catch (Exception e) {
|
||||
throw (LoginException)(new LoginException(e.toString()).initCause(e));
|
||||
}
|
||||
if (LOG.isDebugEnabled()) {
|
||||
LOG.debug("User entry: \"" + userEntry.toString() + "\"" );
|
||||
}
|
||||
|
||||
subject.getPrincipals().add(userEntry);
|
||||
return true;
|
||||
}
|
||||
LOG.error("Can't find user in " + subject);
|
||||
|
@ -919,7 +933,7 @@ public class UserGroupInformation {
|
|||
metrics.loginFailure.add(Time.now() - start);
|
||||
}
|
||||
throw new IOException("Login failure for " + user + " from keytab " +
|
||||
path, le);
|
||||
path+ ": " + le, le);
|
||||
}
|
||||
LOG.info("Login successful for user " + keytabPrincipal
|
||||
+ " using keytab file " + keytabFile);
|
||||
|
|
|
@ -339,7 +339,8 @@ public class TestUserGroupInformation {
|
|||
} catch (IllegalArgumentException e) {
|
||||
String expect = (userName == null || userName.isEmpty())
|
||||
? "Null user" : "Illegal principal name "+userName;
|
||||
assertEquals(expect, e.getMessage());
|
||||
assertTrue("Did not find "+ expect + " in " + e,
|
||||
e.toString().contains(expect));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue