X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fmd-sal%2Fsal-distributed-datastore%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fdatastore%2FShardTestKit.java;h=4e08f4a7f12e4bcd8b2c0996228ea00e70f61c11;hb=5464f50be733df1bbbe31cf05665d542d3b7c5e7;hp=9df933b5bac75e84f13cbfbe3ec46e9bd9b0b3b8;hpb=d617f1570fb165d02e18785b8b1704df7f830087;p=controller.git diff --git a/opendaylight/md-sal/sal-distributed-datastore/src/test/java/org/opendaylight/controller/cluster/datastore/ShardTestKit.java b/opendaylight/md-sal/sal-distributed-datastore/src/test/java/org/opendaylight/controller/cluster/datastore/ShardTestKit.java index 9df933b5ba..4e08f4a7f1 100644 --- a/opendaylight/md-sal/sal-distributed-datastore/src/test/java/org/opendaylight/controller/cluster/datastore/ShardTestKit.java +++ b/opendaylight/md-sal/sal-distributed-datastore/src/test/java/org/opendaylight/controller/cluster/datastore/ShardTestKit.java @@ -13,23 +13,27 @@ import akka.pattern.Patterns; import akka.testkit.JavaTestKit; import akka.util.Timeout; import com.google.common.util.concurrent.Uninterruptibles; +import java.util.Optional; import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeoutException; import org.junit.Assert; import org.opendaylight.controller.cluster.raft.client.messages.FindLeader; import org.opendaylight.controller.cluster.raft.client.messages.FindLeaderReply; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import scala.concurrent.Await; import scala.concurrent.Future; import scala.concurrent.duration.Duration; import scala.concurrent.duration.FiniteDuration; public class ShardTestKit extends JavaTestKit { + private static final Logger LOG = LoggerFactory.getLogger(ShardTestKit.class); public ShardTestKit(ActorSystem actorSystem) { super(actorSystem); } - public void waitForLogMessage(final Class logLevel, ActorRef subject, String logMessage){ + public void waitForLogMessage(final Class logLevel, ActorRef subject, String logMessage) { // Wait for a specific log message to show up final boolean result = new JavaTestKit.EventFilter(logLevel @@ -46,22 +50,23 @@ public class ShardTestKit extends JavaTestKit { } + @SuppressWarnings("checkstyle:IllegalCatch") public static String waitUntilLeader(ActorRef shard) { FiniteDuration duration = Duration.create(100, TimeUnit.MILLISECONDS); - for(int i = 0; i < 20 * 5; i++) { + for (int i = 0; i < 20 * 5; i++) { Future future = Patterns.ask(shard, FindLeader.INSTANCE, new Timeout(duration)); try { - FindLeaderReply resp = (FindLeaderReply)Await.result(future, duration); - if(resp.getLeaderActor() != null) { - return resp.getLeaderActor(); + final Optional maybeLeader = ((FindLeaderReply) Await.result(future, duration)) + .getLeaderActor(); + if (maybeLeader.isPresent()) { + return maybeLeader.get(); } - } catch(TimeoutException e) { - } catch(Exception e) { - System.err.println("FindLeader threw ex"); - e.printStackTrace(); + } catch (TimeoutException e) { + LOG.trace("FindLeader timed out", e); + } catch (Exception e) { + LOG.error("FindLeader failed", e); } - Uninterruptibles.sleepUninterruptibly(50, TimeUnit.MILLISECONDS); } @@ -69,35 +74,36 @@ public class ShardTestKit extends JavaTestKit { return null; } + @SuppressWarnings("checkstyle:IllegalCatch") public void waitUntilNoLeader(ActorRef shard) { FiniteDuration duration = Duration.create(100, TimeUnit.MILLISECONDS); Object lastResponse = null; - for(int i = 0; i < 20 * 5; i++) { + for (int i = 0; i < 20 * 5; i++) { Future future = Patterns.ask(shard, FindLeader.INSTANCE, new Timeout(duration)); try { - FindLeaderReply resp = (FindLeaderReply)Await.result(future, duration); - if(resp.getLeaderActor() == null) { + final Optional maybeLeader = ((FindLeaderReply) Await.result(future, duration)) + .getLeaderActor(); + if (!maybeLeader.isPresent()) { return; } - lastResponse = resp.getLeaderActor(); - } catch(TimeoutException e) { + lastResponse = maybeLeader.get(); + } catch (TimeoutException e) { lastResponse = e; - } catch(Exception e) { - System.err.println("FindLeader threw ex"); - e.printStackTrace(); + } catch (Exception e) { + LOG.error("FindLeader failed", e); lastResponse = e; } Uninterruptibles.sleepUninterruptibly(50, TimeUnit.MILLISECONDS); } - if(lastResponse instanceof Throwable) { + if (lastResponse instanceof Throwable) { throw (AssertionError)new AssertionError( - String.format("Unexpected error occurred from FindLeader for shard %s", shard.path())). - initCause((Throwable)lastResponse); + String.format("Unexpected error occurred from FindLeader for shard %s", shard.path())) + .initCause((Throwable)lastResponse); } Assert.fail(String.format("Unexpected leader %s found for shard %s", lastResponse, shard.path())); } -} \ No newline at end of file +}