Blame tests/GCoArbitraryExample.hs
|
Packit |
1d8052 |
{-# LANGUAGE DeriveGeneric, ScopedTypeVariables #-}
|
|
Packit |
1d8052 |
|
|
Packit |
1d8052 |
module Main where
|
|
Packit |
1d8052 |
|
|
Packit |
1d8052 |
import GHC.Generics (Generic)
|
|
Packit |
1d8052 |
import Test.QuickCheck
|
|
Packit |
1d8052 |
import Test.QuickCheck.Function
|
|
Packit |
1d8052 |
|
|
Packit |
1d8052 |
data D a = C1 a | C2 deriving (Eq, Show, Read, Generic)
|
|
Packit |
1d8052 |
|
|
Packit |
1d8052 |
|
|
Packit |
1d8052 |
instance Arbitrary a => Arbitrary (D a)
|
|
Packit |
1d8052 |
instance CoArbitrary a => CoArbitrary (D a)
|
|
Packit |
1d8052 |
|
|
Packit |
1d8052 |
instance (Show a, Read a) => Function (D a) where
|
|
Packit |
1d8052 |
function = functionShow
|
|
Packit |
1d8052 |
|
|
Packit |
1d8052 |
main :: IO ()
|
|
Packit |
1d8052 |
main = quickCheck $ \(Fun _ f) ->
|
|
Packit |
1d8052 |
f (C1 (2::Int)) `elem` [0, 1 :: Int]
|