3

私はScalaTestフォローのために最初に書き込もうとしていますActor

object Runner {
  def props(race: Race) = Props(classOf[Runner], race)
}

class Runner(race: Race) extends Actor with ActorLogging {

  import context.dispatcher

  @throws[Exception](classOf[Exception])
  override def postRestart(reason: Throwable): Unit = context.parent ! RestartRunner

  override def receive: Receive = LoggingReceive {
    case Start => {
      log.debug("running...")
      for (i <- 1 to 3) {
        Thread.sleep(200)
      }
      throw new RuntimeException("MarathonRunner is tired")
    }

    case StartWithFuture =>
      log.debug("I am starting to run")
      race.start pipeTo self

    case Failure(throwable) => throw throwable

    case Stop =>
      log.debug("stopping runner")
      context.stop(self)
  }
}

私もです

import akka.actor.{Props, ActorSystem}
import akka.testkit.{TestActorRef, TestKit}
import org.scalatest._

class RunnerSpec extends TestKit(ActorSystem("test"))
with WordSpecLike
with MustMatchers {
  "A Runner Actor" must {
    val runner = TestActorRef(Props(new Runner(new Marathon)))
    "receive messages" in {
      runner ! Start
      runner.under <== says Nothing (see attachment)
    }
  }
}

しかし、私が見ているのは

ここに画像の説明を入力

なぜ私は戻ってこないのRunner Actorですか?

4

1 に答える 1

3

Propsは型指定されていないため、ビルドするアクターのタイプ (あなたの場合) はわかりませんRunner。したがって、TestActorRefも型を推測できません。TestActorRefこれが、使用して構築するときに、基礎となるアクターのタイプを明示的に述べる必要がある理由です。

val runner = TestActorRef[Runner](Props(new Runner(new Marathon)))

アクターがパラメーターを必要としなかった場合、これは次のように短縮することもできます。

val runner = TestActorRef[Runner]

ただし、Nothing実際にはすべての scala 型の基本クラスであるため、基になるアクターはどちらの場合も同じです。したがって、TestActorRef定義を変更できない場合は、キャストして を生成することもできますRunner

runner.underlyingActor.asInstanceOf[Runner]
于 2015-06-02T08:02:47.533 に答える