* Added JavaActorContext, UntypedActor.getContext * implicit val context in Actor needs to be implicit to support forward, it would be nice if it wasn't implicit because now I can't override context in UntypedActor * Removed implicit def system in Actor * Removed implicit def defaultTimeout in Actor * Removed receiveTimeout, children, dispatcher, become, unbecome, watch, unwatch in Actor * Removed corresponding as above from UntypedActor * Removed implicit from dispatcher in ActorSystem * Removed implicit def timeout in TypedActor * Changed receiveTimeout to use Duration (in api) * Changed many tests and samples to match new api
44 lines
1.2 KiB
Scala
44 lines
1.2 KiB
Scala
package akka.testkit
|
|
|
|
import org.scalatest.WordSpec
|
|
import org.scalatest.matchers.MustMatchers
|
|
import org.scalatest.{ BeforeAndAfterEach, WordSpec }
|
|
import akka.actor._
|
|
import akka.dispatch.Future
|
|
import akka.util.duration._
|
|
|
|
@org.junit.runner.RunWith(classOf[org.scalatest.junit.JUnitRunner])
|
|
class TestProbeSpec extends AkkaSpec with DefaultTimeout {
|
|
|
|
"A TestProbe" must {
|
|
|
|
"reply to futures" in {
|
|
val tk = TestProbe()
|
|
val future = tk.ref ? "hello"
|
|
tk.expectMsg(0 millis, "hello") // TestActor runs on CallingThreadDispatcher
|
|
tk.lastMessage.sender ! "world"
|
|
future must be('completed)
|
|
future.get must equal("world")
|
|
}
|
|
|
|
"reply to messages" in {
|
|
val tk1 = TestProbe()
|
|
val tk2 = TestProbe()
|
|
tk1.ref.!("hello")(tk2.ref)
|
|
tk1.expectMsg(0 millis, "hello")
|
|
tk1.lastMessage.sender ! "world"
|
|
tk2.expectMsg(0 millis, "world")
|
|
}
|
|
|
|
"properly send and reply to messages" in {
|
|
val probe1 = TestProbe()
|
|
val probe2 = TestProbe()
|
|
probe1.send(probe2.ref, "hello")
|
|
probe2.expectMsg(0 millis, "hello")
|
|
probe2.lastMessage.sender ! "world"
|
|
probe1.expectMsg(0 millis, "world")
|
|
}
|
|
|
|
}
|
|
|
|
}
|