pekko/akka-docs/scala/code/ActorDocSpec.scala

67 lines
1.7 KiB
Scala
Raw Normal View History

package akka.docs.stm
import org.scalatest.{ BeforeAndAfterAll, WordSpec }
import org.scalatest.matchers.MustMatchers
import akka.testkit._
import akka.util.duration._
//#imports
import akka.actor.Actor
import akka.event.EventHandler
//#imports
//#my-actor
class MyActor extends Actor {
def receive = {
case "test" app.eventHandler.info(this, "received test")
case _ app.eventHandler.info(this, "received unknown message")
}
}
//#my-actor
2011-10-12 15:24:22 +02:00
class ActorDocSpec extends AkkaSpec {
2011-10-18 17:56:23 +02:00
"creating actor with AkkaSpec.actorOf" in {
//#creating-actorOf
2011-10-18 17:56:23 +02:00
val myActor = actorOf[MyActor]
//#creating-actorOf
// testing the actor
// TODO: convert docs to AkkaSpec(Configuration(...))
app.eventHandler.notify(TestEvent.Mute(EventFilter.custom {
case e: EventHandler.Info true
case _ false
}))
app.eventHandler.addListener(testActor)
val eventLevel = app.eventHandler.level
app.eventHandler.level = EventHandler.InfoLevel
myActor ! "test"
expectMsgPF(1 second) { case EventHandler.Info(_, "received test") true }
myActor ! "unknown"
expectMsgPF(1 second) { case EventHandler.Info(_, "received unknown message") true }
app.eventHandler.level = eventLevel
app.eventHandler.removeListener(testActor)
app.eventHandler.notify(TestEvent.UnMuteAll)
myActor.stop()
}
"creating actor with constructor" in {
class MyActor(arg: String) extends Actor {
def receive = { case _ () }
}
//#creating-constructor
// allows passing in arguments to the MyActor constructor
2011-10-18 17:56:23 +02:00
val myActor = actorOf(new MyActor("..."))
//#creating-constructor
myActor.stop()
}
}