Tom*_*ski 2 json scala playframework-2.1
我正在尝试在解组Play2.1中的对象时验证JSON.我定义的Format对象仅在JSON中缺少字段时验证,但我想验证字段是否为nonEmpty字符串.这可能吗?我已经试过指定的minLength()约束(如看到这里的读取()调用),但我得到一个编译错误说的minLength无法找到.这只是为了元组方法吗?
请参阅以下Specs2 Junit测试,该测试现在失败,但应在正确定义约束时通过:
import org.specs2.mutable._
import play.api.libs.json._
class SimpleValidation extends SpecificationWithJUnit{
private val badPayload: JsValue = Json.obj(
"simpleValue1" -> "mySimpleValue", // Comment this line out to pass test
"simpleValue2" -> ""
)
"An IssueFormat" should {
"validate when unmarshalling" in {
badPayload.validate[SimpleObj].fold(
valid = (res => {
// Fail if valid
failure("Payload should have been invalid")
}),
invalid = (e => {
// Should be one error
e.length mustBeEqualTo(1)
}))
}
}
}
import play.api.libs.functional.syntax._
case class SimpleObj(simpleValue1: String, simpleValue2: String)
object SimpleObj {
val simpleReads = (
(__ \ "simpleValue1").read[String] and
(__ \ "simpleValue2").read[String])(SimpleObj.apply _) // read[String](minLength(0)) yields compiler error
val simpleWrites = (
(__ \ "simpleValue1").write[String] and
(__ \ "simpleValue2").write[String])(unlift(SimpleObj.unapply))
implicit val simpleFormat: Format[SimpleObj] = Format(simpleReads, simpleWrites)
}
Run Code Online (Sandbox Code Playgroud)
您可以在Reads中使用minLength:
import play.api.libs.json.Reads._
Run Code Online (Sandbox Code Playgroud)
然后minLength应该可用,但是,请尝试这种格式:
implicit val simpleReads = (
(__ \ "simpleValue1").read(minLength[String](1)) and
(__ \ "simpleValue2").read(minLength[String](1))(SimpleObj.apply _)
Run Code Online (Sandbox Code Playgroud)