com.rojoma.json.v3.testsupport.GenJValue.scala Maven / Gradle / Ivy
package com.rojoma.json.v3
package testsupport
import ast._
import org.scalacheck.Arbitrary
import org.scalacheck.Gen
object GenJValue {
import Arbitrary.arbitrary
import ArbitraryValidString._
val genJBoolean = for {
x <- arbitrary[Boolean]
} yield JBoolean(x)
private def genFloat = for {
a <- arbitrary[BigInt]
e <- arbitrary[Short]
} yield BigDecimal(a) * BigDecimal(10).pow(e)
val genJNumber: Gen[JNumber] = {
val genJInteger = arbitrary[BigInt].map(JNumber.apply)
val genJFloatingPoint = genFloat.map(JNumber.apply)
Gen.oneOf(genJInteger, genJFloatingPoint)
}
def genJString = for {
x <- ArbitraryValidString.arbitrary
} yield JString(x)
val genJNull: Gen[JNull] = Gen.const(JNull) // Just for completeness' sake
def genJAtom: Gen[JAtom] =
Gen.oneOf(genJNull, genJBoolean, genJNumber, genJString)
def genJArray(elementGen: Gen[JValue] = genJValue, sizeFactor: Double = 0.5): Gen[JArray] = Gen.sized { sz =>
for {
x <- Gen.containerOf[List, JValue](Gen.resize((sz * sizeFactor).toInt, elementGen))
} yield JArray(x)
}
def genJObject(elementGen: Gen[JValue] = genJValue, sizeFactor: Double = 0.5): Gen[JObject] = Gen.sized { sz =>
def pairGen = for {
x <- ArbitraryValidString.arbitrary
y <- elementGen
} yield (x, y)
for {
x <- Gen.containerOf[List, (String, JValue)](Gen.resize((sz * sizeFactor).toInt, pairGen))
} yield JObject(x.toMap)
}
def genJCompound(elementGen: Gen[JValue] = genJValue, sizeFactor: Double = 0.5): Gen[JCompound] =
Gen.oneOf(genJArray(elementGen, sizeFactor), genJObject(elementGen, sizeFactor))
def genJValue: Gen[JValue] =
Gen.oneOf(genJAtom, genJCompound(Gen.lzy(genJValue)))
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy