8

我花了太多时间尝试调试以下问题,但我不确定问题出在哪里。

问题:得到400 Bad Request, Invalid Json响应,但有以下例外:

com.fasterxml.jackson.databind.JsonMappingException: No content to map due to end-of-input
 at [Source: [B@6ee503c9; line: 1, column: 1]
    at com.fasterxml.jackson.databind.JsonMappingException.from(JsonMappingException.java:164) ~[jackson-databind.jar:2.2.2]
    at com.fasterxml.jackson.databind.ObjectMapper._initForReading(ObjectMapper.java:2931) ~[jackson-databind.jar:2.2.2]
    at com.fasterxml.jackson.databind.ObjectMapper._readValue(ObjectMapper.java:2846) ~[jackson-databind.jar:2.2.2]
    at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:1569) ~[jackson-databind.jar:2.2.2]
    at play.api.libs.json.JacksonJson$.parseJsValue(JsValue.scala:480) ~[play-json_2.10.jar:2.2.0]
    at play.api.libs.json.Json$.parse(Json.scala:27) ~[play-json_2.10.jar:2.2.0]

在我的控制器中测试的方法:

  def createArticle(id: String) =
      Action.async(parse.json) { implicit request =>
        (request.body \ "content").asOpt[String].map {
            ............
            ............
        }.getOrElse(BadRequest("Invalid request body"))
      }

对应的单元测试:

  "create article" in {
    running(FakeApplication()) {
      val postJson = Json.obj("content" -> "article content")

      val result = resource.createArticle(ARTICE_ID)(FakeRequest(POST, controllers.routes.ArticleResource.create(ARTICLE_ID).url).withJsonBody(postJson).withHeaders(CONTENT_TYPE -> "application/json").run

      status(result) must equalTo OK
    }
  }

我在这里阅读了讨论,但那里的建议都没有帮助。

4

3 回答 3

0

我有一个类似的问题,解决方案在这里指出。就我而言,这是因为我使用response.asJson()了两次,正如@jroper 所述

考虑到 HTTP 响应的主体是一个流,而不是您希望在内存中缓冲的内容,那么不支持两次访问主体(无论您以何种格式访问主体)是有道理的。

于 2014-03-06T10:18:43.807 回答
0

我有类似的问题,但到目前为止还没有解决(优雅地,无论如何..)。由于我的环境是 java 而不是 scala,所以我可以预感一下。我认为当您发送帖子时,它可能是异步完成的(在您的 create article 方法中使用 Action.async),因此您可能需要等待测试代码结果,然后再尝试查看它是否正常。

于 2013-10-31T21:59:16.367 回答
0

尝试在方法定义中实例化您的请求。

这就是它对我的工作方式(例如使用带有 JSON 正文和结果作为 JSON 的 POST):

"process" should {
    "should be valid" in {
 val request = FakeRequest(POST, "/").withJsonBody(Json.parse("""      {  
     "id":1,
     "name":"prod 1",
     "price":55.55
  }"""))

  val result: Future[Result] = controller.process.apply(request)      
  val json = contentAsJson(result)            

  status(result) must be(CREATED)
  (json \ "id").as[Int] mustBe 1

// .. more assertions and rest of code ...

这里的代码处理一个 JsValue 并查询它的节点以检查返回的值是否与所需的模拟数据输出匹配

于 2017-06-21T19:50:38.577 回答