我正在测试代码,该代码通过以下方式获得的传出流TCP连接上传输消息:
(IO(StreamTcp) ? StreamTcp.Connect(settings, address))
.mapTo[StreamTcp.OutgoingTcpConnection]
.map(_.outputStream)
在我的测试中,我将结果Subscriber[ByteString]
替换为虚拟订阅者,触发一些传出消息,并断言已按预期到达。我使用下面的方法来生成虚拟订阅者和流结果。 (到目前为止,这么好)
def testSubscriber[T](settings: FlowMaterializer)(implicit ec: ExecutionContext): (Subscriber[T], Future[Seq[T]]) = {
var sent = Seq.empty[T]
val (subscriber, streamComplete) =
Duct[T].foreach( bs => sent = sent :+ bs)(settings)
(subscriber, streamComplete.map( _ => sent ))
}
我的问题是:是否有一些规范的方法来测试流输出预期的值,类似于Akka的TestActorRef
?如果没有,是否有一些类似于上述函数的库函数?
答案 0 :(得分:3)
使用akka-streams-testkit可以测试流 在此处阅读:http://doc.akka.io/docs/akka/current/scala/stream/stream-testkit.html