diff options
author | Mathias <mathias@spray.cc> | 2011-05-09 10:11:53 +0200 |
---|---|---|
committer | Mathias <mathias@spray.cc> | 2011-05-09 10:11:53 +0200 |
commit | 5f6afe658a47bc7c8cce6f47357ead086495f6d3 (patch) | |
tree | aa8c26afd75d9ab309ac5b5af61776e3379032ba /src/test/scala/cc/spray/json/CollectionFormatsSpec.scala | |
parent | b6562036f9f0ba8f85c53bfd9f8671e2d2975e1a (diff) | |
download | spray-json-5f6afe658a47bc7c8cce6f47357ead086495f6d3.tar.gz spray-json-5f6afe658a47bc7c8cce6f47357ead086495f6d3.tar.bz2 spray-json-5f6afe658a47bc7c8cce6f47357ead086495f6d3.zip |
Squash obsolete 'formats' package also in test sources
Diffstat (limited to 'src/test/scala/cc/spray/json/CollectionFormatsSpec.scala')
-rw-r--r-- | src/test/scala/cc/spray/json/CollectionFormatsSpec.scala | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/src/test/scala/cc/spray/json/CollectionFormatsSpec.scala b/src/test/scala/cc/spray/json/CollectionFormatsSpec.scala new file mode 100644 index 0000000..58175ac --- /dev/null +++ b/src/test/scala/cc/spray/json/CollectionFormatsSpec.scala @@ -0,0 +1,66 @@ +package cc.spray.json + +import org.specs.Specification +import java.util.Arrays + +class CollectionFormatsSpec extends Specification with CollectionFormats with BasicFormats { + + "The listFormat" should { + val list = List(1, 2, 3) + val json = JsArray(JsNumber(1), JsNumber(2), JsNumber(3)) + "convert a List[Int] to a JsArray of JsNumbers" in { + list.toJson mustEqual json + } + "convert a JsArray of JsNumbers to a List[Int]" in { + json.fromJson[List[Int]] mustEqual list + } + } + + "The arrayFormat" should { + val array = Array(1, 2, 3) + val json = JsArray(JsNumber(1), JsNumber(2), JsNumber(3)) + "convert an Array[Int] to a JsArray of JsNumbers" in { + array.toJson mustEqual json + } + "convert a JsArray of JsNumbers to an Array[Int]" in { + Arrays.equals(json.fromJson[Array[Int]], array) must beTrue + } + } + + "The mapFormat" should { + val map = Map("a" -> 1, "b" -> 2, "c" -> 3) + val json = JsObject(JsField("a", 1), JsField("b", 2), JsField("c", 3)) + "convert a Map[String, Long] to a JsObject" in { + map.toJson mustEqual json + } + "be able to convert a JsObject to a Map[String, Long]" in { + json.fromJson[Map[String, Long]] mustEqual map + } + "throw an Exception when trying to serialize a map whose key are not serialized to JsStrings" in { + Map(1 -> "a").toJson must throwA(new SerializationException("Map key must be formatted as JsString, not '1'")) + } + } + + "The immutableSetFormat" should { + val set = Set(1, 2, 3) + val json = JsArray(JsNumber(1), JsNumber(2), JsNumber(3)) + "convert a Set[Int] to a JsArray of JsNumbers" in { + set.toJson mustEqual json + } + "convert a JsArray of JsNumbers to a Set[Int]" in { + json.fromJson[Set[Int]] mustEqual set + } + } + + "The mutableSetFormat" should { + val set = collection.mutable.Set(1, 2, 3) + val json = JsArray(JsNumber(3), JsNumber(1), JsNumber(2)) + "convert a collection.mutable.Set[Int] to a JsArray of JsNumbers" in { + set.toJson mustEqual json + } + "convert a JsArray of JsNumbers to a collection.mutable.Set[Int]" in { + json.fromJson[collection.mutable.Set[Int]] mustEqual set + } + } + +}
\ No newline at end of file |