2013-06-25 16:17:13 +02:00
|
|
|
/**
|
2016-02-23 12:58:39 +01:00
|
|
|
* Copyright (C) 2009-2016 Lightbend Inc. <http://www.lightbend.com>
|
2013-06-25 16:17:13 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
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
|
2015-01-16 11:09:59 +01:00
|
|
|
p.expectMsgType[Status.Failure].cause.getMessage should ===("failed")
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
2014-01-16 15:16:35 +01:00
|
|
|
"pick up an implicit sender()" in {
|
2013-06-25 16:17:13 +02:00
|
|
|
val p = TestProbe()
|
|
|
|
|
implicit val s = testActor
|
|
|
|
|
Future(42) pipeTo p.ref
|
|
|
|
|
p.expectMsg(42)
|
2015-01-16 11:09:59 +01:00
|
|
|
p.lastSender should ===(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)
|
|
|
|
|
}
|
|
|
|
|
|
2014-01-16 15:16:35 +01:00
|
|
|
"work in Java form with sender()" in {
|
2013-06-25 16:17:13 +02:00
|
|
|
val p = TestProbe()
|
|
|
|
|
pipe(Future(42)) to (p.ref, testActor)
|
|
|
|
|
p.expectMsg(42)
|
2015-01-16 11:09:59 +01:00
|
|
|
p.lastSender should ===(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
|
2015-01-16 11:09:59 +01:00
|
|
|
p.expectMsgType[Status.Failure].cause.getMessage should ===("failed")
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
2014-01-16 15:16:35 +01:00
|
|
|
"pick up an implicit sender()" in {
|
2013-06-25 16:17:13 +02:00
|
|
|
val p = TestProbe()
|
|
|
|
|
val sel = system.actorSelection(p.ref.path)
|
|
|
|
|
implicit val s = testActor
|
|
|
|
|
Future(42) pipeToSelection sel
|
|
|
|
|
p.expectMsg(42)
|
2015-01-16 11:09:59 +01:00
|
|
|
p.lastSender should ===(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)
|
|
|
|
|
}
|
|
|
|
|
|
2014-01-16 15:16:35 +01:00
|
|
|
"work in Java form with sender()" in {
|
2013-06-25 16:17:13 +02:00
|
|
|
val p = TestProbe()
|
|
|
|
|
val sel = system.actorSelection(p.ref.path)
|
|
|
|
|
pipe(Future(42)) to (sel, testActor)
|
|
|
|
|
p.expectMsg(42)
|
2015-01-16 11:09:59 +01:00
|
|
|
p.lastSender should ===(testActor)
|
2013-06-25 16:17:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|