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]