module Data.GenValidity.Tree where
#if !MIN_VERSION_base(4,8,0)
import Control.Applicative ((<*>))
import Data.Functor ((<$>))
#endif
import Data.GenValidity
import Data.Validity.Tree ()
import Test.QuickCheck
import Data.Tree
instance GenUnchecked a =>
GenUnchecked (Tree a) where
genUnchecked = genTreeOf genUnchecked
instance GenValid a =>
GenValid (Tree a) where
genValid = genTreeOf genValid
instance (GenUnchecked a, GenInvalid a) =>
GenInvalid (Tree a) where
genInvalid =
sized $ \n -> do
size <- upTo n
(a, b) <- genSplit size
oneof
[ Node <$> resize a genInvalid <*> resize b genUnchecked
, Node <$> resize a genUnchecked <*> resize b genInvalid
]
genTreeOf :: Gen a -> Gen (Tree a)
genTreeOf func =
sized $ \n -> do
size <- upTo n
(a, b) <- genSplit size
value <- resize a func
forest <- resize b $ genListOf $ genTreeOf func
return $ Node value forest