{-# LANGUAGE MultiParamTypeClasses #-} {-# LANGUAGE ScopedTypeVariables #-} module Test.Validity.Relations.Symmetry ( symmetricOnElems , symmetryOnGens , symmetryOnValid , symmetry , symmetryOnArbitrary ) where import Data.GenValidity import Test.QuickCheck import Test.Validity.Utils -- | -- -- \[ -- Symmetric(\prec) -- \quad\equiv\quad -- \forall a, b: (a \prec b) \Leftrightarrow (b \prec a) -- \] symmetricOnElems :: (a -> a -> Bool) -- ^ A relation -> a -> a -- ^ Two elements -> Bool symmetricOnElems func a b = func a b <==> func b a symmetryOnGens :: Show a => (a -> a -> Bool) -> Gen (a, a) -> Property symmetryOnGens func gen = forAll gen $ uncurry $ symmetricOnElems func symmetryOnValid :: (Show a, GenValidity a) => (a -> a -> Bool) -> Property symmetryOnValid func = symmetryOnGens func genValid symmetry :: (Show a, GenValidity a) => (a -> a -> Bool) -> Property symmetry func = symmetryOnGens func genUnchecked -- | -- -- prop> symmetryOnArbitrary ((==) :: Int -> Int -> Bool) symmetryOnArbitrary :: (Show a, Arbitrary a) => (a -> a -> Bool) -> Property symmetryOnArbitrary func = symmetryOnGens func arbitrary