X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=opendaylight%2Fmd-sal%2Fsal-akka-raft%2Fsrc%2Ftest%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fcluster%2Fraft%2Futils%2FMessageCollectorActor.java;h=f7caf0f4a57ad683dbea5559ce4775136e865e2d;hb=bad1f8b8f3c1780cd37ec8a817ef4b0f23901654;hp=79c90cf051cc928ac50e563a136c62030809bbc2;hpb=c64ef5f44f131976c20fcf8ced56627f81091838;p=controller.git diff --git a/opendaylight/md-sal/sal-akka-raft/src/test/java/org/opendaylight/controller/cluster/raft/utils/MessageCollectorActor.java b/opendaylight/md-sal/sal-akka-raft/src/test/java/org/opendaylight/controller/cluster/raft/utils/MessageCollectorActor.java index 79c90cf051..f7caf0f4a5 100644 --- a/opendaylight/md-sal/sal-akka-raft/src/test/java/org/opendaylight/controller/cluster/raft/utils/MessageCollectorActor.java +++ b/opendaylight/md-sal/sal-akka-raft/src/test/java/org/opendaylight/controller/cluster/raft/utils/MessageCollectorActor.java @@ -9,15 +9,19 @@ package org.opendaylight.controller.cluster.raft.utils; import akka.actor.ActorRef; +import akka.actor.Props; import akka.actor.UntypedActor; import akka.pattern.Patterns; import akka.util.Timeout; +import com.google.common.base.Predicate; import com.google.common.collect.Lists; import com.google.common.util.concurrent.Uninterruptibles; import java.util.ArrayList; +import java.util.Collections; import java.util.List; import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeoutException; +import org.junit.Assert; import scala.concurrent.Await; import scala.concurrent.Future; import scala.concurrent.duration.Duration; @@ -26,6 +30,8 @@ import scala.concurrent.duration.FiniteDuration; public class MessageCollectorActor extends UntypedActor { private static final String ARE_YOU_READY = "ARE_YOU_READY"; + public static final String GET_ALL_MESSAGES = "messages"; + private static final String CLEAR_MESSAGES = "clear-messages"; private final List messages = new ArrayList<>(); @@ -35,10 +41,10 @@ public class MessageCollectorActor extends UntypedActor { return; } - if(message instanceof String){ - if("get-all-messages".equals(message)){ - getSender().tell(new ArrayList<>(messages), getSelf()); - } + if(GET_ALL_MESSAGES.equals(message)) { + getSender().tell(new ArrayList<>(messages), getSelf()); + } else if(CLEAR_MESSAGES.equals(message)) { + clear(); } else if(message != null) { messages.add(message); } @@ -48,14 +54,18 @@ public class MessageCollectorActor extends UntypedActor { messages.clear(); } - public static List getAllMessages(ActorRef actor) throws Exception { + private static List getAllMessages(ActorRef actor) throws Exception { FiniteDuration operationDuration = Duration.create(5, TimeUnit.SECONDS); Timeout operationTimeout = new Timeout(operationDuration); - Future future = Patterns.ask(actor, "get-all-messages", operationTimeout); + Future future = Patterns.ask(actor, GET_ALL_MESSAGES, operationTimeout); return (List) Await.result(future, operationDuration); } + public static void clearMessages(ActorRef actor) { + actor.tell(CLEAR_MESSAGES, ActorRef.noSender()); + } + /** * Get the first message that matches the specified class * @param actor @@ -63,29 +73,110 @@ public class MessageCollectorActor extends UntypedActor { * @return */ public static T getFirstMatching(ActorRef actor, Class clazz) throws Exception { - for(int i = 0; i < 50; i++) { - List allMessages = getAllMessages(actor); + List allMessages = getAllMessages(actor); - for(Object message : allMessages){ - if(message.getClass().equals(clazz)){ - return (T) message; - } + for(Object message : allMessages){ + if(message.getClass().equals(clazz)){ + return clazz.cast(message); } + } + + return null; + } + + public static List expectMatching(ActorRef actor, Class clazz, int count) { + int timeout = 5000; + List messages = Collections.emptyList(); + for(int i = 0; i < timeout / 50; i++) { + try { + messages = getAllMatching(actor, clazz); + if(messages.size() >= count) { + return messages; + } + } catch (Exception e) {} + + Uninterruptibles.sleepUninterruptibly(50, TimeUnit.MILLISECONDS); + } + + Assert.fail(String.format("Expected %d messages of type %s. Actual received was %d: %s", count, clazz, + messages.size(), messages)); + return null; + } + + public static T expectFirstMatching(ActorRef actor, Class clazz) { + return expectFirstMatching(actor, clazz, 5000); + } + + + public static T expectFirstMatching(ActorRef actor, Class clazz, long timeout) { + int count = (int) (timeout / 50); + for(int i = 0; i < count; i++) { + try { + T message = getFirstMatching(actor, clazz); + if(message != null) { + return message; + } + } catch (Exception e) {} + + Uninterruptibles.sleepUninterruptibly(50, TimeUnit.MILLISECONDS); + } + + Assert.fail("Did not receive message of type " + clazz); + return null; + } + + public static T expectFirstMatching(ActorRef actor, Class clazz, Predicate matcher) { + int timeout = 5000; + T lastMessage = null; + for(int i = 0; i < timeout / 50; i++) { + try { + List messages = getAllMatching(actor, clazz); + for(T msg: messages) { + if(matcher.apply(msg)) { + return msg; + } - Uninterruptibles.sleepUninterruptibly(100, TimeUnit.MILLISECONDS); + lastMessage = msg; + } + } catch (Exception e) {} + + Uninterruptibles.sleepUninterruptibly(50, TimeUnit.MILLISECONDS); } + Assert.fail(String.format("Expected specific message of type %s. Last message received was: %s", clazz, lastMessage)); return null; } - public static List getAllMatching(ActorRef actor, Class clazz) throws Exception { + public static void assertNoneMatching(ActorRef actor, Class clazz) { + assertNoneMatching(actor, clazz, 5000); + } + + public static void assertNoneMatching(ActorRef actor, Class clazz, long timeout) { + int count = (int) (timeout / 50); + for(int i = 0; i < count; i++) { + try { + T message = getFirstMatching(actor, clazz); + if(message != null) { + Assert.fail("Unexpected message received" + message.toString()); + return; + } + } catch (Exception e) {} + + Uninterruptibles.sleepUninterruptibly(50, TimeUnit.MILLISECONDS); + } + + return; + } + + + public static List getAllMatching(ActorRef actor, Class clazz) throws Exception { List allMessages = getAllMessages(actor); - List output = Lists.newArrayList(); + List output = Lists.newArrayList(); for(Object message : allMessages){ if(message.getClass().equals(clazz)){ - output.add(message); + output.add(clazz.cast(message)); } } @@ -105,4 +196,8 @@ public class MessageCollectorActor extends UntypedActor { throw new TimeoutException("Actor not ready in time."); } + + public static Props props() { + return Props.create(MessageCollectorActor.class); + } }