Dans le user guide de scalacheck il y a le paragraphe "Générer des classes de cas". Je modifié par exemple de celui-ci à utiliser des classes régulières au lieu des classes de cas:Générateurs pour les classes régulières dans scalacheck
import org.scalacheck._
import Gen._
import Arbitrary._
sealed abstract class Tree
object Leaf extends Tree
class Node(left:Tree, rigth:Tree, v:Int) extends Tree
object Main {
val genLeaf = value(Leaf)
val genNode = for{
v <- Arbitrary.arbitrary[Int]
left <- genTree
rigth <- genTree
} yield new Node(left, rigth, v)
val genTree:Gen[Tree] = oneOf(genLeaf, genNode)
def main(args:Array[String]){
println(genTree.sample)
}
}
Il tout semble fonctionner mais j'ai peur d'utiliser cette approche dans le code de production avant que je demande ici: est-il des pièges?