YARN-6970. Add PoolInitializationException as retriable exception in FederationFacade. (Giovanni Matteo Fumarola via Subru).
(cherry picked from commit ad2a350662
)
This commit is contained in:
parent
d11be2dcac
commit
a1ee4ad77f
|
@ -70,6 +70,7 @@ import org.slf4j.Logger;
|
|||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import com.google.common.annotations.VisibleForTesting;
|
||||
import com.zaxxer.hikari.pool.HikariPool.PoolInitializationException;
|
||||
|
||||
/**
|
||||
*
|
||||
|
@ -162,6 +163,7 @@ public final class FederationStateStoreFacade {
|
|||
exceptionToPolicyMap.put(FederationStateStoreRetriableException.class,
|
||||
basePolicy);
|
||||
exceptionToPolicyMap.put(CacheLoaderException.class, basePolicy);
|
||||
exceptionToPolicyMap.put(PoolInitializationException.class, basePolicy);
|
||||
|
||||
RetryPolicy retryPolicy = RetryPolicies.retryByException(
|
||||
RetryPolicies.TRY_ONCE_THEN_FAIL, exceptionToPolicyMap);
|
||||
|
|
|
@ -30,6 +30,8 @@ import org.apache.hadoop.yarn.server.federation.store.exception.FederationStateS
|
|||
import org.junit.Assert;
|
||||
import org.junit.Test;
|
||||
|
||||
import com.zaxxer.hikari.pool.HikariPool.PoolInitializationException;
|
||||
|
||||
/**
|
||||
* Test class to validate FederationStateStoreFacade retry policy.
|
||||
*/
|
||||
|
@ -119,4 +121,26 @@ public class TestFederationStateStoreFacadeRetry {
|
|||
policy.shouldRetry(new CacheLoaderException(""), maxRetries, 0, false);
|
||||
Assert.assertEquals(RetryAction.FAIL.action, action.action);
|
||||
}
|
||||
|
||||
/*
|
||||
* Test to validate that PoolInitializationException is a retriable exception.
|
||||
*/
|
||||
@Test
|
||||
public void testFacadePoolInitRetriableException() throws Exception {
|
||||
// PoolInitializationException is a retriable exception
|
||||
conf = new Configuration();
|
||||
conf.setInt(YarnConfiguration.CLIENT_FAILOVER_RETRIES, maxRetries);
|
||||
RetryPolicy policy = FederationStateStoreFacade.createRetryPolicy(conf);
|
||||
RetryAction action = policy.shouldRetry(
|
||||
new PoolInitializationException(new YarnException()), 0, 0, false);
|
||||
// We compare only the action, delay and the reason are random value
|
||||
// during this test
|
||||
Assert.assertEquals(RetryAction.RETRY.action, action.action);
|
||||
|
||||
// After maxRetries we stop to retry
|
||||
action =
|
||||
policy.shouldRetry(new PoolInitializationException(new YarnException()),
|
||||
maxRetries, 0, false);
|
||||
Assert.assertEquals(RetryAction.FAIL.action, action.action);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue