-- Hoogle documentation, generated by Haddock -- See Hoogle, http://www.haskell.org/hoogle/ -- | A property-based testing library -- -- SmallCheck is a testing library that allows to verify properties for -- all test cases up to some depth. The test cases are generated -- automatically by SmallCheck. @package smallcheck @version 1.0.2 -- | You need this module if you want to generate test values of your own -- types. -- -- You'll typically need the following extensions: -- --
--   {-# LANGUAGE FlexibleInstances, MultiParamTypeClasses #-}
--   
-- -- SmallCheck itself defines data generators for all the data types used -- by the Prelude. -- -- In order to generate values and functions of your own types, you need -- to make them instances of Serial (for values) and -- CoSerial (for functions). There are two main ways to do so: -- using Generics or writing the instances by hand. module Test.SmallCheck.Series cons0 :: a -> Series m a cons1 :: Serial m a => (a -> b) -> Series m b cons2 :: (Serial m a, Serial m b) => (a -> b -> c) -> Series m c cons3 :: (Serial m a, Serial m b, Serial m c) => (a -> b -> c -> d) -> Series m d cons4 :: (Serial m a, Serial m b, Serial m c, Serial m d) => (a -> b -> c -> d -> e) -> Series m e -- | Same as cons1, but preserves the depth. newtypeCons :: Serial m a => (a -> b) -> Series m b alts0 :: Series m a -> Series m a alts1 :: CoSerial m a => Series m b -> Series m (a -> b) alts2 :: (CoSerial m a, CoSerial m b) => Series m c -> Series m (a -> b -> c) alts3 :: (CoSerial m a, CoSerial m b, CoSerial m c) => Series m d -> Series m (a -> b -> c -> d) alts4 :: (CoSerial m a, CoSerial m b, CoSerial m c, CoSerial m d) => Series m e -> Series m (a -> b -> c -> d -> e) -- | Same as alts1, but preserves the depth. newtypeAlts :: CoSerial m a => Series m b -> Series m (a -> b) -- | Maximum depth of generated test values. -- -- For data values, it is the depth of nested constructor applications. -- -- For functional values, it is both the depth of nested case analysis -- and the depth of results. type Depth = Int -- | Series is a MonadLogic action that enumerates values of -- a certain type, up to some depth. -- -- The depth bound is tracked in the SC monad and can be -- extracted using getDepth and changed using -- localDepth. -- -- To manipulate series at the lowest level you can use its Monad, -- MonadPlus and MonadLogic instances. This module provides -- some higher-level combinators which simplify creating series. -- -- A proper Series should be monotonic with respect to the depth — -- i.e. localDepth (+1) s should emit all the values that -- s emits (and possibly some more). -- -- It is also desirable that values of smaller depth come before the -- values of greater depth. data Series m a class Monad m => Serial m a where series = to <$> gSeries series :: Serial m a => Series m a class Monad m => CoSerial m a where coseries rs = (. from) <$> gCoseries rs coseries :: CoSerial m a => Series m b -> Series m (a -> b) -- | Positive x: guarantees that x > 0. newtype Positive a Positive :: a -> Positive a getPositive :: Positive a -> a -- | NonNegative x: guarantees that x >= 0. newtype NonNegative a NonNegative :: a -> NonNegative a getNonNegative :: NonNegative a -> a -- | Sum (union) of series (\/) :: Monad m => Series m a -> Series m a -> Series m a -- | Product of series (><) :: Monad m => Series m a -> Series m b -> Series m (a, b) -- | Fair version of ap and <*> (<~>) :: Monad m => Series m (a -> b) -> Series m a -> Series m b -- | Fair conjunction. Similarly to the previous function, consider the -- distributivity law for MonadPlus: -- --
--   (mplus a b) >>= k = (a >>= k) `mplus` (b >>= k)
--   
-- -- If 'a >>= k' can backtrack arbitrarily many tmes, (b >>= -- k) may never be considered. (>>-) takes similar care to consider -- both branches of a disjunctive computation. (>>-) :: MonadLogic m => forall a b. m a -> (a -> m b) -> m b -- | Run a series with a modified depth localDepth :: (Depth -> Depth) -> Series m a -> Series m a -- | Run a Series with the depth decreased by 1. -- -- If the current depth is less or equal to 0, the result is -- mzero. decDepth :: Series m a -> Series m a -- | Query the current depth getDepth :: Series m Depth -- | A simple series specified by a function from depth to the list of -- values up to that depth. generate :: (Depth -> [a]) -> Series m a -- | Return the list of values generated by a Series. Useful for -- debugging Serial instances. list :: Depth -> Series Identity a -> [a] instance [overlap ok] Eq a => Eq (N a) instance [overlap ok] Ord a => Ord (N a) instance [overlap ok] Real a => Real (N a) instance [overlap ok] Enum a => Enum (N a) instance [overlap ok] Num a => Num (N a) instance [overlap ok] Integral a => Integral (N a) instance [overlap ok] Eq a => Eq (Positive a) instance [overlap ok] Ord a => Ord (Positive a) instance [overlap ok] Num a => Num (Positive a) instance [overlap ok] Integral a => Integral (Positive a) instance [overlap ok] Real a => Real (Positive a) instance [overlap ok] Enum a => Enum (Positive a) instance [overlap ok] Eq a => Eq (NonNegative a) instance [overlap ok] Ord a => Ord (NonNegative a) instance [overlap ok] Num a => Num (NonNegative a) instance [overlap ok] Integral a => Integral (NonNegative a) instance [overlap ok] Real a => Real (NonNegative a) instance [overlap ok] Enum a => Enum (NonNegative a) instance [overlap ok] Show a => Show (NonNegative a) instance [overlap ok] (Num a, Ord a, Serial m a) => Serial m (NonNegative a) instance [overlap ok] Show a => Show (Positive a) instance [overlap ok] (Num a, Ord a, Serial m a) => Serial m (Positive a) instance [overlap ok] (Serial Identity a, Show a, Show b) => Show (a -> b) instance [overlap ok] (Serial m a, CoSerial m a, Serial m b, CoSerial m b) => CoSerial m (a -> b) instance [overlap ok] (CoSerial m a, Serial m b) => Serial m (a -> b) instance [overlap ok] CoSerial m a => CoSerial m [a] instance [overlap ok] Serial m a => Serial m [a] instance [overlap ok] (CoSerial m a, CoSerial m b) => CoSerial m (Either a b) instance [overlap ok] (Serial m a, Serial m b) => Serial m (Either a b) instance [overlap ok] CoSerial m a => CoSerial m (Maybe a) instance [overlap ok] Serial m a => Serial m (Maybe a) instance [overlap ok] Monad m => CoSerial m Bool instance [overlap ok] Monad m => Serial m Bool instance [overlap ok] (CoSerial m a, CoSerial m b, CoSerial m c, CoSerial m d) => CoSerial m (a, b, c, d) instance [overlap ok] (Serial m a, Serial m b, Serial m c, Serial m d) => Serial m (a, b, c, d) instance [overlap ok] (CoSerial m a, CoSerial m b, CoSerial m c) => CoSerial m (a, b, c) instance [overlap ok] (Serial m a, Serial m b, Serial m c) => Serial m (a, b, c) instance [overlap ok] (CoSerial m a, CoSerial m b) => CoSerial m (a, b) instance [overlap ok] (Serial m a, Serial m b) => Serial m (a, b) instance [overlap ok] Monad m => CoSerial m Char instance [overlap ok] Monad m => Serial m Char instance [overlap ok] Monad m => CoSerial m Double instance [overlap ok] Monad m => Serial m Double instance [overlap ok] Monad m => CoSerial m Float instance [overlap ok] Monad m => Serial m Float instance [overlap ok] (Integral a, Serial m a) => CoSerial m (N a) instance [overlap ok] (Integral a, Serial m a) => Serial m (N a) instance [overlap ok] Monad m => CoSerial m Integer instance [overlap ok] Monad m => Serial m Integer instance [overlap ok] Monad m => CoSerial m Int instance [overlap ok] Monad m => Serial m Int instance [overlap ok] Monad m => CoSerial m () instance [overlap ok] Monad m => Serial m () instance [overlap ok] GSerial m f => GSerial m (C1 c f) instance [overlap ok] (Monad m, GCoSerial m a, GCoSerial m b) => GCoSerial m (a :+: b) instance [overlap ok] (Monad m, GSerial m a, GSerial m b) => GSerial m (a :+: b) instance [overlap ok] (Monad m, GCoSerial m a, GCoSerial m b) => GCoSerial m (a :*: b) instance [overlap ok] (Monad m, GSerial m a, GSerial m b) => GSerial m (a :*: b) instance [overlap ok] GCoSerial m U1 instance [overlap ok] GSerial m U1 instance [overlap ok] CoSerial m c => GCoSerial m (K1 i c) instance [overlap ok] Serial m c => GSerial m (K1 i c) instance [overlap ok] GCoSerial m f => GCoSerial m (M1 i c f) instance [overlap ok] GSerial m f => GSerial m (M1 i c f) -- | You should only need this module if you wish to create your own way to -- run SmallCheck tests module Test.SmallCheck.Drivers -- | A simple driver that runs the test in the IO monad and prints -- the results. smallCheck :: Testable IO a => Depth -> a -> IO () -- | Use this if: -- -- smallCheckM :: Testable m a => Depth -> a -> m (Maybe PropertyFailure) -- | Like smallCheckM, but allows to specify a monadic hook that -- gets executed after each test is run. -- -- Useful for applications that want to report progress information to -- the user. smallCheckWithHook :: Testable m a => Depth -> (TestQuality -> m ()) -> a -> m (Maybe PropertyFailure) test :: Testable m a => a -> Property m ppFailure :: PropertyFailure -> String data PropertyFailure NotExist :: PropertyFailure AtLeastTwo :: [Argument] -> PropertySuccess -> [Argument] -> PropertySuccess -> PropertyFailure CounterExample :: [Argument] -> PropertyFailure -> PropertyFailure PropertyFalse :: PropertyFailure data PropertySuccess Exist :: [Argument] -> PropertySuccess -> PropertySuccess ExistUnique :: [Argument] -> PropertySuccess -> PropertySuccess PropertyTrue :: PropertySuccess Vacuously :: PropertyFailure -> PropertySuccess type Argument = String data TestQuality GoodTest :: TestQuality BadTest :: TestQuality -- | This module exports the main pieces of SmallCheck functionality. -- -- To generate test cases for your own types, refer to -- Test.SmallCheck.Series. -- -- For pointers to other sources of information about SmallCheck, please -- refer to the README at -- https://github.com/feuerbach/smallcheck/blob/master/README.md module Test.SmallCheck -- | Set the universal quantification context forAll :: Testable m a => a -> Property m -- | Set the existential quantification context exists :: Testable m a => a -> Property m -- | Set the uniqueness quantification context. -- -- Bear in mind that ∃! (x, y): p x y is not the same as ∃! x: ∃! y: p x -- y. -- -- For example, ∃! x: ∃! y: |x| = |y| is true (it holds only when x=0), -- but ∃! (x,y): |x| = |y| is false (there are many such pairs). -- -- As is customary in mathematics, existsUnique $ \x y -> p -- x y is equivalent to existsUnique $ \(x,y) -> p x -- y and not to existsUnique $ \x -> -- existsUnique $ \y -> p x y (the latter, of course, may -- be explicitly written when desired). -- -- That is, all the variables affected by the same uniqueness context are -- quantified simultaneously as a tuple. existsUnique :: Testable m a => a -> Property m -- | over s $ \x -> p x makes x range over the -- Series s (by default, all variables range over the -- series for their types). -- -- Note that, unlike the quantification operators, this affects only the -- variable following the operator and not subsequent variables. -- -- over does not affect the quantification context. over :: (Show a, Testable m b) => Series m a -> (a -> b) -> Property m -- | Execute a monadic test monadic :: Testable m a => m a -> Property m -- | The ==> operator can be used to express a restricting -- condition under which a property should hold. It corresponds to -- implication in the classical logic. -- -- Note that ==> resets the quantification context for its -- operands to the default (universal). (==>) :: (Testable m c, Testable m a) => c -> a -> Property m -- | Run property with a modified depth. Affects all quantified variables -- in the property. changeDepth :: Testable m a => (Depth -> Depth) -> a -> Property m -- | Quantify the function's argument over its series, but adjust -- the depth. This doesn't affect any subsequent variables. changeDepth1 :: (Show a, Serial m a, Testable m b) => (Depth -> Depth) -> (a -> b) -> Property m -- | Maximum depth of generated test values. -- -- For data values, it is the depth of nested constructor applications. -- -- For functional values, it is both the depth of nested case analysis -- and the depth of results. type Depth = Int -- | A simple driver that runs the test in the IO monad and prints -- the results. smallCheck :: Testable IO a => Depth -> a -> IO () -- | Class of tests that can be run in a monad. For pure tests, it is -- recommended to keep their types polymorphic in m rather than -- specialising it to Identity. class Monad m => Testable m a -- | The type of properties over the monad m data Property m