diff --git a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java index 87d9acabe5..56249960c7 100644 --- a/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java +++ b/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/security/token/delegation/AbstractDelegationTokenSecretManager.java @@ -505,9 +505,9 @@ protected DelegationTokenInformation checkToken(TokenIdent identifier) } long now = Time.now(); if (info.getRenewDate() < now) { - err = - "Token has" + identifier.getRealUser() + "expired, current time: " + Time.formatTime(now) - + " expected renewal time: " + Time.formatTime(info.getRenewDate()); + err = "Token " + identifier.getRealUser() + " has expired, current time: " + + Time.formatTime(now) + " expected renewal time: " + Time + .formatTime(info.getRenewDate()); LOG.info("{}, Token={}", err, formatTokenId(identifier)); throw new InvalidToken(err); } diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/test/java/org/apache/hadoop/yarn/server/resourcemanager/TestClientRMTokens.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/test/java/org/apache/hadoop/yarn/server/resourcemanager/TestClientRMTokens.java index e700bfd1e8..c53e4eaea1 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/test/java/org/apache/hadoop/yarn/server/resourcemanager/TestClientRMTokens.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/test/java/org/apache/hadoop/yarn/server/resourcemanager/TestClientRMTokens.java @@ -18,7 +18,6 @@ package org.apache.hadoop.yarn.server.resourcemanager; import static org.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; import static org.mockito.ArgumentMatchers.any; import static org.mockito.ArgumentMatchers.anyString; @@ -36,6 +35,7 @@ import java.security.PrivilegedAction; import java.security.PrivilegedExceptionAction; +import org.apache.hadoop.test.LambdaTestUtils; import org.apache.hadoop.thirdparty.protobuf.InvalidProtocolBufferException; import org.apache.hadoop.io.DataOutputBuffer; import org.apache.hadoop.net.NetUtils; @@ -112,7 +112,7 @@ public void resetSecretManager() { } @Test - public void testDelegationToken() throws IOException, InterruptedException { + public void testDelegationToken() throws Exception { final YarnConfiguration conf = new YarnConfiguration(); conf.set(YarnConfiguration.RM_PRINCIPAL, "testuser/localhost@apache.org"); @@ -199,14 +199,11 @@ public void testDelegationToken() throws IOException, InterruptedException { } Thread.sleep(50l); LOG.info("At time: " + System.currentTimeMillis() + ", token should be invalid"); - // Token should have expired. - try { - clientRMWithDT.getNewApplication(request); - fail("Should not have succeeded with an expired token"); - } catch (Exception e) { - assertEquals(InvalidToken.class.getName(), e.getClass().getName()); - assertTrue(e.getMessage().contains("is expired")); - } + // Token should have expired. + final ApplicationClientProtocol finalClientRMWithDT = clientRMWithDT; + final GetNewApplicationRequest finalRequest = request; + LambdaTestUtils.intercept(InvalidToken.class, "Token has expired", + () -> finalClientRMWithDT.getNewApplication(finalRequest)); // Test cancellation // Stop the existing proxy, start another.