quickcheck-state-machine-0.10.0: Test monadic programs using state machine based models
Copyright(C) 2017 ATS Advanced Telematic Systems GmbH
LicenseBSD-style (see the file LICENSE)
MaintainerStevan Andjelkovic <stevan.andjelkovic@strath.ac.uk>
Stabilityprovisional
Portabilitynon-portable (GHC extensions)
Safe HaskellSafe-Inferred
LanguageHaskell2010

Test.StateMachine.Types

Description

 
Synopsis

Documentation

data StateMachine model cmd m resp Source #

Constructors

StateMachine 

Fields

data Command cmd resp Source #

Previously symbolically executed command

Invariant: the variables must be the variables in the response.

Constructors

Command !(cmd Symbolic) !(resp Symbolic) ![Var] 

Instances

Instances details
(Read (cmd Symbolic), Read (resp Symbolic)) => Read (Command cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

readsPrec :: Int -> ReadS (Command cmd resp) #

readList :: ReadS [Command cmd resp] #

readPrec :: ReadPrec (Command cmd resp) #

readListPrec :: ReadPrec [Command cmd resp] #

(Show (cmd Symbolic), Show (resp Symbolic)) => Show (Command cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

showsPrec :: Int -> Command cmd resp -> ShowS #

show :: Command cmd resp -> String #

showList :: [Command cmd resp] -> ShowS #

(Eq (cmd Symbolic), Eq (resp Symbolic)) => Eq (Command cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

(==) :: Command cmd resp -> Command cmd resp -> Bool #

(/=) :: Command cmd resp -> Command cmd resp -> Bool #

getCommand :: Command cmd resp -> cmd Symbolic Source #

newtype Commands cmd resp Source #

Constructors

Commands 

Fields

Instances

Instances details
Monoid (Commands cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

mempty :: Commands cmd resp #

mappend :: Commands cmd resp -> Commands cmd resp -> Commands cmd resp #

mconcat :: [Commands cmd resp] -> Commands cmd resp #

Semigroup (Commands cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

(<>) :: Commands cmd resp -> Commands cmd resp -> Commands cmd resp #

sconcat :: NonEmpty (Commands cmd resp) -> Commands cmd resp #

stimes :: Integral b => b -> Commands cmd resp -> Commands cmd resp #

(Read (cmd Symbolic), Read (resp Symbolic)) => Read (Commands cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

readsPrec :: Int -> ReadS (Commands cmd resp) #

readList :: ReadS [Commands cmd resp] #

readPrec :: ReadPrec (Commands cmd resp) #

readListPrec :: ReadPrec [Commands cmd resp] #

(Show (cmd Symbolic), Show (resp Symbolic)) => Show (Commands cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

showsPrec :: Int -> Commands cmd resp -> ShowS #

show :: Commands cmd resp -> String #

showList :: [Commands cmd resp] -> ShowS #

(Eq (cmd Symbolic), Eq (resp Symbolic)) => Eq (Commands cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

(==) :: Commands cmd resp -> Commands cmd resp -> Bool #

(/=) :: Commands cmd resp -> Commands cmd resp -> Bool #

data ParallelCommandsF t cmd resp Source #

Constructors

ParallelCommands 

Fields

Instances

Instances details
(Show (cmd Symbolic), Show (resp Symbolic), Show (t (Commands cmd resp))) => Show (ParallelCommandsF t cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

showsPrec :: Int -> ParallelCommandsF t cmd resp -> ShowS #

show :: ParallelCommandsF t cmd resp -> String #

showList :: [ParallelCommandsF t cmd resp] -> ShowS #

(Eq (cmd Symbolic), Eq (resp Symbolic), Eq (t (Commands cmd resp))) => Eq (ParallelCommandsF t cmd resp) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

(==) :: ParallelCommandsF t cmd resp -> ParallelCommandsF t cmd resp -> Bool #

(/=) :: ParallelCommandsF t cmd resp -> ParallelCommandsF t cmd resp -> Bool #

data Pair a Source #

Constructors

Pair 

Fields

Instances

Instances details
Foldable Pair Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

fold :: Monoid m => Pair m -> m #

foldMap :: Monoid m => (a -> m) -> Pair a -> m #

foldMap' :: Monoid m => (a -> m) -> Pair a -> m #

foldr :: (a -> b -> b) -> b -> Pair a -> b #

foldr' :: (a -> b -> b) -> b -> Pair a -> b #

foldl :: (b -> a -> b) -> b -> Pair a -> b #

foldl' :: (b -> a -> b) -> b -> Pair a -> b #

foldr1 :: (a -> a -> a) -> Pair a -> a #

foldl1 :: (a -> a -> a) -> Pair a -> a #

toList :: Pair a -> [a] #

null :: Pair a -> Bool #

length :: Pair a -> Int #

elem :: Eq a => a -> Pair a -> Bool #

maximum :: Ord a => Pair a -> a #

minimum :: Ord a => Pair a -> a #

sum :: Num a => Pair a -> a #

product :: Num a => Pair a -> a #

Traversable Pair Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

traverse :: Applicative f => (a -> f b) -> Pair a -> f (Pair b) #

sequenceA :: Applicative f => Pair (f a) -> f (Pair a) #

mapM :: Monad m => (a -> m b) -> Pair a -> m (Pair b) #

sequence :: Monad m => Pair (m a) -> m (Pair a) #

Functor Pair Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

fmap :: (a -> b) -> Pair a -> Pair b #

(<$) :: a -> Pair b -> Pair a #

Show a => Show (Pair a) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

showsPrec :: Int -> Pair a -> ShowS #

show :: Pair a -> String #

showList :: [Pair a] -> ShowS #

Eq a => Eq (Pair a) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

(==) :: Pair a -> Pair a -> Bool #

(/=) :: Pair a -> Pair a -> Bool #

Ord a => Ord (Pair a) Source # 
Instance details

Defined in Test.StateMachine.Types

Methods

compare :: Pair a -> Pair a -> Ordering #

(<) :: Pair a -> Pair a -> Bool #

(<=) :: Pair a -> Pair a -> Bool #

(>) :: Pair a -> Pair a -> Bool #

(>=) :: Pair a -> Pair a -> Bool #

max :: Pair a -> Pair a -> Pair a #

min :: Pair a -> Pair a -> Pair a #

fromPair :: Pair a -> (a, a) Source #

toPair :: (a, a) -> Pair a Source #

noCleanup :: Monad m => model Concrete -> m () Source #