Я нашел следующий вопрос/ответ:
Тест MultipartFormData в Play 2.0 FakeRequest
Но в Play 2.1 все изменилось. Я пробовал адаптировать пример следующим образом:
"Application" should {
"Upload Photo" in {
running(FakeApplication()) {
val data = new MultipartFormData(Map(), List(
FilePart("qqfile", "message", Some("Content-Type: multipart/form-data"),
TemporaryFile(getClass().getResource("/test/photos/DSC03024.JPG").getFile()))
), List())
val Some(result) = routeAndCall(FakeRequest(POST, "/admin/photo/upload", FakeHeaders(), data))
status(result) must equalTo(CREATED)
headers(result) must contain(LOCATION)
contentType(result) must beSome("application/json")
Однако всякий раз, когда я пытаюсь запустить запрос, я получаю исключение с нулевым указателем:
[error] ! Upload Photo
[error] NullPointerException: null (PhotoManagementSpec.scala:25)
[error] test.PhotoManagementSpec$$anonfun$1$$anonfun$apply$3$$anonfun$apply$4.apply(PhotoManagementSpec.scala:28)
[error] test.PhotoManagementSpec$$anonfun$1$$anonfun$apply$3$$anonfun$apply$4.apply(PhotoManagementSpec.scala:25)
[error] play.api.test.Helpers$.running(Helpers.scala:40)
[error] test.PhotoManagementSpec$$anonfun$1$$anonfun$apply$3.apply(PhotoManagementSpec.scala:25)
[error] test.PhotoManagementSpec$$anonfun$1$$anonfun$apply$3.apply(PhotoManagementSpec.scala:25)
Если я попытаюсь заменить устаревший routeAndCall только маршрутом (и удалить параметр вокруг результата), я получаю ошибку компиляции, заявляя, что не может написать экземпляр MultipartFormData [TemporaryFile] для ответа HTTP.
Какой правильный способ создать этот тест в Play 2.1 с помощью Scala?
Изменить: пробовал модифицировать код для проверки только контроллера:
"Application" should {
"Upload Photo" in {
val data = new MultipartFormData(Map(), List(
FilePart("qqfile", "message", Some("Content-Type: multipart/form-data"),
TemporaryFile(getClass().getResource("/test/photos/DSC03024.JPG").getFile()))
), List())
val result = controllers.Photo.upload()(FakeRequest(POST, "/admin/photo/upload",FakeHeaders(),data))
status(result) must equalTo(OK)
contentType(result) must beSome("text/html")
charset(result) must beSome("utf-8")
contentAsString(result) must contain("Hello Bob")
}
Но теперь я получаю ошибку типа во всех тестовых условиях вокруг таких результатов:
[error] found : play.api.libs.iteratee.Iteratee[Array[Byte],play.api.mvc.Result]
[error] required: play.api.mvc.Result
Я не понимаю, почему я получаю Interator для байт-массивов, сопоставленных с результатами. Может ли это иметь какое-то отношение к тому, как я использую собственный парсер для тела? Мое определение контроллера выглядит следующим образом:
def upload = Action(CustomParsers.multipartFormDataAsBytes) { request =>
request.body.file("qqfile").map { upload =>
Используя синтаксический анализатор формы из этого сообщения: Вытягивание файлов из MultipartFormData в память в Play2/ Scala