pekko/akka-docs-dev/rst/scala/code/docs/stream/cookbook/RecipeManualTrigger.scala

94 lines
2.3 KiB
Scala
Raw Normal View History

2014-12-08 17:29:40 +01:00
package docs.stream.cookbook
import akka.stream.ClosedShape
2014-12-08 17:29:40 +01:00
import akka.stream.scaladsl._
2015-04-24 11:45:03 +03:00
import akka.stream.testkit._
2014-12-08 17:29:40 +01:00
import scala.concurrent.duration._
class RecipeManualTrigger extends RecipeSpec {
"Recipe for triggering a stream manually" must {
"work" in {
val elements = Source(List("1", "2", "3", "4"))
2015-04-24 11:45:03 +03:00
val pub = TestPublisher.probe[Trigger]()
val sub = TestSubscriber.manualProbe[Message]()
2014-12-08 17:29:40 +01:00
val triggerSource = Source(pub)
val sink = Sink(sub)
//#manually-triggered-stream
val graph = RunnableGraph.fromGraph(FlowGraph.create() { implicit builder =>
import FlowGraph.Implicits._
val zip = builder.add(Zip[Message, Trigger]())
elements ~> zip.in0
triggerSource ~> zip.in1
2014-12-08 17:29:40 +01:00
zip.out ~> Flow[(Message, Trigger)].map { case (msg, trigger) => msg } ~> sink
ClosedShape
})
2014-12-08 17:29:40 +01:00
//#manually-triggered-stream
graph.run()
sub.expectSubscription().request(1000)
sub.expectNoMsg(100.millis)
2015-04-24 11:45:03 +03:00
pub.sendNext(())
2014-12-08 17:29:40 +01:00
sub.expectNext("1")
sub.expectNoMsg(100.millis)
2015-04-24 11:45:03 +03:00
pub.sendNext(())
pub.sendNext(())
2014-12-08 17:29:40 +01:00
sub.expectNext("2")
sub.expectNext("3")
sub.expectNoMsg(100.millis)
2015-04-24 11:45:03 +03:00
pub.sendNext(())
2014-12-08 17:29:40 +01:00
sub.expectNext("4")
sub.expectComplete()
}
"work with ZipWith" in {
val elements = Source(List("1", "2", "3", "4"))
2015-04-24 11:45:03 +03:00
val pub = TestPublisher.probe[Trigger]()
val sub = TestSubscriber.manualProbe[Message]()
2014-12-08 17:29:40 +01:00
val triggerSource = Source(pub)
val sink = Sink(sub)
//#manually-triggered-stream-zipwith
val graph = RunnableGraph.fromGraph(FlowGraph.create() { implicit builder =>
import FlowGraph.Implicits._
val zip = builder.add(ZipWith((msg: Message, trigger: Trigger) => msg))
2014-12-08 17:29:40 +01:00
elements ~> zip.in0
triggerSource ~> zip.in1
2014-12-08 17:29:40 +01:00
zip.out ~> sink
ClosedShape
})
2014-12-08 17:29:40 +01:00
//#manually-triggered-stream-zipwith
graph.run()
sub.expectSubscription().request(1000)
sub.expectNoMsg(100.millis)
2015-04-24 11:45:03 +03:00
pub.sendNext(())
2014-12-08 17:29:40 +01:00
sub.expectNext("1")
sub.expectNoMsg(100.millis)
2015-04-24 11:45:03 +03:00
pub.sendNext(())
pub.sendNext(())
2014-12-08 17:29:40 +01:00
sub.expectNext("2")
sub.expectNext("3")
sub.expectNoMsg(100.millis)
2015-04-24 11:45:03 +03:00
pub.sendNext(())
2014-12-08 17:29:40 +01:00
sub.expectNext("4")
sub.expectComplete()
}
}
}