scala - akka:如何测试 Actor 是否被停止

标签 scala unit-testing akka

我想知道测试 Actor 是否在 akka 中停止的规范方法是什么。这是我目前正在做的一个例子;我担心我把它复杂化了。

import akka.actor.{Terminated, Actor, Props, ActorSystem}
import akka.testkit.TestProbe

class MyActor extends Actor {
  import MyActor._
  override def receive: Receive = {
    case Stop => context.stop(self)
  }
}

object MyActor {
  def props = Props(new MyActor)
  case object Stop
}


object MyActorSpec {

  val system = ActorSystem()
  val myActor = system.actorOf(MyActor.props)
  val testProbe = TestProbe()

  case object MyActorStopped

  val watcher = system.actorOf(Props(new Actor {
    context.watch(myActor)
    override def receive: Actor.Receive = {
      case Terminated(`myActor`) => testProbe.ref ! MyActorStopped
    }
  }))

  myActor ! MyActor.Stop
  testProbe.expectMsg(MyActorStopped)
}

最佳答案

您可以摆脱单独的观察者 Actor ,而直接从 testProbe 观看目标 Actor 。 Actor :

val testProbe = TestProbe()
testProbe watch myActor
myActor ! MyActor.Stop
testProbe.expectTerminated(myActor)

here对于 Akka 测试文档的相关部分。

关于scala - akka:如何测试 Actor 是否被停止,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34084903/

相关文章:

java - 使用 Maven 分发 akka 微内核应用程序

scala - 关闭 Scala 中的循环变量

scala - scalatest 中的 java.lang.NoClassDefFoundError

java - 如何对实现 Runnable 的类进行单元测试

windows - 尝试在 Windows 命令行中运行 lcov 时不断出现 gcov 错误

java - akka.persistence.typed.internal.JournalFailureException : Exception during recovery. 如何解决?

sql - 如何在ScalaQuery中回滚 session ?

scala - Scala 中硬币找零的 StackOverflowError?

c# - 如何在单元测试中比较两个对象?

scala - Akka Stream + Akka Http - 获取错误请求