は、私は次のSubscriber
抽象基底クラスがあります。Akkaクラスターで加入者の受信方法をテストするにはどうすればよいですか?
abstract class Subscriber(topics: Seq[String]) extends Actor with ActorLogging {
import DistributedPubSubMediator.{ Subscribe, SubscribeAck }
val mediator = DistributedPubSub(context.system).mediator
// subscribe to each topic
topics.foreach{mediator ! Subscribe(_, self)}
def receive = {
case SubscribeAck(Subscribe(name, None, `self`)) ⇒
log.info(s"Subscribing to $name")
}
}
を、私はそれがサブクラスが購読しているトピックに公開されたメッセージを受け取ることをテストしたいと思います。それは次のようである証明するいくつかの簡単な擬似コード:
val topic = "foo"
class FooSubscriber extends Subscriber(Seq(topic))
val fooSubActor = system.actorOf(Props[FooSubscriber])
val mediator = DistributedPubSub(system).mediator
val msg = "This is a string"
// Publish the msg to the "foo" topic.
mediator ! Publish(topic, msg)
fooSubActor.expectMsg(msg)
特定の俳優が受け取るメッセージについての主張を作るために私が知っている唯一の方法はTestProbe
によるものであるが、私は、私はTestProbe
が拡張作ることができるのか分かりません私のクラス。
通常、Akka docsには関連するテストスイートのサンプルコードがありますが、receive
メソッドのテストに関するAkka Clusterドキュメントには何も見つかりませんでした。
誰にでも提案がありますか?
アクターが何かを受け取り、メンバー変数が私のテストで設定されているというアサーションを行うと、kludgeは 'receive'をオーバーライドしてメンバー変数を変更します...しかしこれは悪いです。より慣用的なテストアプローチを探しています。 – erip