Как протестировать пользовательские объекты Json с помощью Spray Routing
Я создаю Rest API с распылительной маршрутизацией поверх mongodb для некоторых операций CRUD, все это работает нормально, ожидайте, когда я пытаюсь протестировать его с помощью specs2 следующей спецификации
class RestServiceSpec extends Specification with Specs2RouteTest with RoutingRestService
// database initialization removed for clarity
"The rest service" should
"have a player called 'Theo TestPlayer' in the db" in {
Get("/api/1.0/player/" + player1._id) ~> restRoute ~> check {
entityAs[Player] must be equalTo(player1)
}
}
}
// some more specs removed for clarity
}
произойдет сбой со следующей ошибкой:
MalformedContent(invalid ObjectId ["51308c134820cf957c4c51ca"],Some(java.lang.IllegalArgumentException: invalid ObjectId ["51308c134820cf957c4c51ca"])) (Specs2Interface.scala:25)
Я понятия не имею, где искать, поскольку ссылка на исходный файл и номер строки указывают на общий метод failTest(msg:String)
немного больше информации:
У меня есть кейс-класс, который я сохраняю в Монго, используя SalatDAO
case class Player(@Key("_id") _id:ObjectId = new ObjectId(), name:String, email:String, age:Int) {}
где ObjectId() - класс, который оборачивает генерацию идентификатора mongodb, чтобы получить (не) маршалинг через spray_json. Я создал несколько jsonFormats.
object MyJsonProtocol {
implicit val objectIdFormat = new JsonFormat[ObjectId] {
def write(o:ObjectId) = JsString(o.toString)
def read(value:JsValue) = new ObjectId(value.toString())
}
implicit val PlayerFormat = jsonFormat(Player, "_id", "name", "email", "age")
и соответствующая часть моего маршрута (устранена обработка ошибок и ведение журнала):
path("player" / "\\w+".r) {id:String =>
get {
respondWithMediaType(`application/json`) {
complete {
PlayerCRUD.getById(id)
}
}
} ~
2 ответа
Как никто, кажется, не знает, я изменил _id с ObjectId() на просто строку, и имел вспомогательный метод для его создания из нового ObjectId(). ToString, где это необходимо.
implicit object ObjectIdJsonFormat extends JsonFormat[ObjectId] {
def write(obj: ObjectId): JsValue = JsString(obj.toString)
def read(json: JsValue): ObjectId = json match {
case JsString(str) => new ObjectId(str)
case _ => throw new DeserializationException(" string expected")
}
}