Permalink
Find file
Fetching contributors…
Cannot retrieve contributors at this time
39 lines (32 sloc) 1.29 KB
/*
* Copyright 2009-2010 WorldWide Conferencing, LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.liftweb
package json
import org.scalacheck._
import org.scalacheck.Prop.forAll
import org.specs.Specification
import org.specs.runner.{Runner, JUnit}
import org.specs.ScalaCheck
class PrintingTest extends Runner(PrintingSpec) with JUnit
object PrintingSpec extends Specification with JValueGen with ScalaCheck {
import scala.text.Document
"rendering does not change semantics" in {
val rendering = (json: Document) => parse(Printer.pretty(json)) == parse(Printer.compact(json))
forAll(rendering) must pass
}
private def parse(json: String) = scala.util.parsing.json.JSON.parse(json)
implicit def arbDoc: Arbitrary[Document] = Arbitrary(genJValue.map(render(_)))
}