All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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