Scala 如何在play 2.5中测试使用自定义解析器的控制器方法?
我的控制器方法:Scala 如何在play 2.5中测试使用自定义解析器的控制器方法?,scala,unit-testing,playframework,Scala,Unit Testing,Playframework,我的控制器方法: def postCategory = Action(parse.tolerantText) { request => Ok("") } 这是我的测试: val result = categoryController.postCategory.apply(FakeRequest()) status(result) mustEqual OK //error this line 我有一个错误: 错误:(63,14)类型不匹配;发现: play.api
def postCategory = Action(parse.tolerantText) { request =>
Ok("")
}
这是我的测试:
val result = categoryController.postCategory.apply(FakeRequest())
status(result) mustEqual OK //error this line
我有一个错误:
错误:(63,14)类型不匹配;发现:
play.api.libs.streams.acculator[akka.util.ByteString,play.api.mvc.Result]
必需:scala.concurrent.Future[play.api.mvc.Result]
状态(结果)必须等于OK
^
似乎使用自定义解析器parse.*
会使它返回累加器
,而不是Future[Result]
我正在使用play 2.5-RC2您可以尝试以下内容:
val result = categoryController.postCategory.apply(FakeRequest())
status(result.run) must equalTo(OK)
基本上看,累加器有一个很好的
run()
方法,它返回一个未来的,您应该使用result.run使用Guice获取Materializer的实例
看起来像:
import akka.stream.Materializer
//...
def mockApp = new GuiceApplicationBuilder().build()
val mtrlzr = mockApp.injector.instanceOf[Materializer]
val result: Accumulator[ByteString, Result] = controller.accessToken()(FakeRequest())
val runResult: Future[Result] = result.run()(mtrlzr)
关于累加器
,您是对的。检查一下run()
方法需要隐式物化器:物化器
输入。这对我来说很奇怪,因为在游戏2.3中不必这样做。你有什么想法吗?我猜Play 2.5已经向Akka Streams迈出了一大步,因为任何必须异步完成的事情。Akka Streams在这里说[“物化器是流执行引擎的工厂…”我在这里遇到了同样的问题: