喷雾试验箱不';t属性使用HTTPEntity解组UTF-8编码的json

喷雾试验箱不';t属性使用HTTPEntity解组UTF-8编码的json,json,scala,utf-8,spray,scalatest,Json,Scala,Utf 8,Spray,Scalatest,我有一个使用Spray框架编写的API的ScalateTest,如下所示: "correctly deserializes multi-lang title metadata" in { implicit def json4sFormats: org.json4s.Formats = ModelJsonHelper.jsonFormats val v2MultiLangTitle = getStringFromResource("/json_samples/cmp.asset.v2.A

我有一个使用Spray框架编写的API的ScalateTest,如下所示:

"correctly deserializes multi-lang title metadata" in {
  implicit def json4sFormats: org.json4s.Formats = ModelJsonHelper.jsonFormats

  val v2MultiLangTitle = getStringFromResource("/json_samples/cmp.asset.v2.AssetWriteMultiMetadata.json")

  //Deserialize
  val v2AssetEither = HttpEntity(`application/cmp.ela.assetWrite.v2+json`, v2MultiLangTitle).as[Asset]
  v2AssetEither.isRight shouldEqual true
  v2AssetEither.right.map(asset => {
    asset.assetMetadata.getOrElse(List()).size shouldEqual(3)
    asset.assetMetadata.getOrElse(List())(1).language shouldEqual("es")
    asset.assetMetadata.getOrElse(List())(1).data.title shouldEqual(Some("Encabezado prueba de AFP"))
    asset.assetMetadata.getOrElse(List())(2).language shouldEqual("tlh")
    asset.assetMetadata.getOrElse(List())(2).data.title shouldEqual(Some("Daj jaw AFP"))
    asset.assetMetadata.getOrElse(List())(0).language shouldEqual("de")
    asset.assetMetadata.getOrElse(List())(0).data.title shouldEqual(Some("Test AFP Überschrift"))
  })
}

def getStringFromResource(input: String): String = {
  Source.fromInputStream(this.getClass.getResourceAsStream(input))(Codec.UTF8).getLines.mkString("")
}
正在处理的json如下所示

{
  "assetMetadata" : [
    {
      "title": "Test AFP Überschrift",
      "language": "de"
    },
    {
      "title": "Encabezado prueba de AFP",
      "language": "es"
    },
    {
      "title": "Daj jaw AFP",
      "language": "tlh"
    }
  ]
}
故障发生在德国umlaut上:

[info] - correctly deserializes multi-lang title metadata *** FAILED ***
[info]   Some("Test AFP �berschrift") did not equal "Test AFP Überschrift" (V2AssetWriteMarshallerSpec.scala:367)
在表面下,有一些用于展开过程的JSON4。但是,如果我直接使用json4s解析器,德语字符的处理是正确的:

import scala.io.Source
import java.io.FileInputStream
val v = Source.fromInputStream(new FileInputStream("/path/to/project/src/test/resources/json_samples/cmp.asset.v2.AssetWriteMultiMetadata.json")).getLines.mkString("")
import org.json4s._
import org.json4s.native.JsonMethods._

val obj = parse(v)
(obj \ "assetMetadata")
给我一个结果:

res0: org.json4s.JValue = JArray(List(JObject(List((title,JString(Test AFP Überschrift)), ....
我使用的是Spray 1.3.3和json4s 3.2.10。
HttpEntity
中的类型是一个自定义类型,我尝试添加
(“charset”->“UTF-8”)
作为参数,如下所示:

val `application/cmp.ela.assetWrite.v2+json` = register(
    MediaType.custom(
      mainType = "application",
      subType = "cmp.ela.assetWrite.v2+json",
      compressible = true,
      binary = false,
      parameters = Map[String,String]( "charset" -> "UTF-8" )
    )
  )

..但测试仍然失败,字符无效。如何让Spray正确解组包含国际字符的字符串?

我帮助您在Scala IRC频道中找到了解决方案。我找到了这个链接,其余的都是你做的

固定测试:

  //Deserialize
  val v2AssetEither = HttpEntity(`application/vnd.dsa.assetWrite.v2+json` withCharset(HttpCharsets.`UTF-8`), v2MultiLangTitle).as[Asset]
  v2AssetEither.isRight shouldEqual true
关键是添加

withCharset(HttpCharsets.`UTF-8`)