2013-06-25 16:17:13 +02:00
|
|
|
/**
|
|
|
|
|
* Copyright (C) 2009-2013 Typesafe Inc. <http://www.typesafe.com>
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
package akka.pattern
|
|
|
|
|
|
|
|
|
|
import akka.testkit.AkkaSpec
|
|
|
|
|
import akka.testkit.TestProbe
|
|
|
|
|
import scala.concurrent.Future
|
|
|
|
|
import akka.actor.Status
|
|
|
|
|
|
|
|
|
|
class PipeToSpec extends AkkaSpec {
|
|
|
|
|
|
|
|
|
|
import system.dispatcher
|
|
|
|
|
|
|
|
|
|
"PipeTo" must {
|
|
|
|
|
|
|
|
|
|
"work" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
Future(42) pipeTo p.ref
|
|
|
|
|
p.expectMsg(42)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"signal failure" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
Future.failed(new Exception("failed")) pipeTo p.ref
|
2013-12-17 14:25:56 +01:00
|
|
|
p.expectMsgType[Status.Failure].cause.getMessage should be("failed")
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"pick up an implicit sender" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
implicit val s = testActor
|
|
|
|
|
Future(42) pipeTo p.ref
|
|
|
|
|
p.expectMsg(42)
|
2013-12-17 14:25:56 +01:00
|
|
|
p.lastSender should be(s)
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"work in Java form" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
pipe(Future(42)) to p.ref
|
|
|
|
|
p.expectMsg(42)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"work in Java form with sender" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
pipe(Future(42)) to (p.ref, testActor)
|
|
|
|
|
p.expectMsg(42)
|
2013-12-17 14:25:56 +01:00
|
|
|
p.lastSender should be(testActor)
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"PipeToSelection" must {
|
|
|
|
|
|
|
|
|
|
"work" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
val sel = system.actorSelection(p.ref.path)
|
|
|
|
|
Future(42) pipeToSelection sel
|
|
|
|
|
p.expectMsg(42)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"signal failure" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
val sel = system.actorSelection(p.ref.path)
|
|
|
|
|
Future.failed(new Exception("failed")) pipeToSelection sel
|
2013-12-17 14:25:56 +01:00
|
|
|
p.expectMsgType[Status.Failure].cause.getMessage should be("failed")
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"pick up an implicit sender" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
val sel = system.actorSelection(p.ref.path)
|
|
|
|
|
implicit val s = testActor
|
|
|
|
|
Future(42) pipeToSelection sel
|
|
|
|
|
p.expectMsg(42)
|
2013-12-17 14:25:56 +01:00
|
|
|
p.lastSender should be(s)
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"work in Java form" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
val sel = system.actorSelection(p.ref.path)
|
|
|
|
|
pipe(Future(42)) to sel
|
|
|
|
|
p.expectMsg(42)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
"work in Java form with sender" in {
|
|
|
|
|
val p = TestProbe()
|
|
|
|
|
val sel = system.actorSelection(p.ref.path)
|
|
|
|
|
pipe(Future(42)) to (sel, testActor)
|
|
|
|
|
p.expectMsg(42)
|
2013-12-17 14:25:56 +01:00
|
|
|
p.lastSender should be(testActor)
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|