1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
|
{-# LANGUAGE AllowAmbiguousTypes #-}
module Spec.Functor ( laws )
where
import Clothes (F, H, FG(..), GH(..), NatTransf(..))
import Data.Functor.Barbie (FunctorB(..))
import Data.Typeable (Typeable, typeRep, Proxy(..))
import Test.Tasty(testGroup, TestTree)
import Test.Tasty.QuickCheck(Arbitrary(..), testProperty, (===))
laws
:: forall b
. ( FunctorB b
, Eq (b F), Eq (b H)
, Show (b F), Show (b H)
, Arbitrary (b F)
, Typeable b
)
=> TestTree
laws
= testGroup (show (typeRep (Proxy :: Proxy b)))
[ testProperty "bmap id = id" $ \b ->
bmap id b === (b :: b F)
, testProperty "bmap (f . g) = bmap f . bmap g)" $
\b (GH (NatTransf f)) (FG (NatTransf g)) ->
bmap (f . g) b === (bmap f . bmap g) (b :: b F)
]
|