HTF-0.13.2.2: The Haskell Test Framework

Safe HaskellSafe
LanguageHaskell2010

Test.Framework.AssertM

Description

This module defines the AssertM monad, which allows you either to run assertions as ordinary unit tests or to evaluate them as pure functions.

Synopsis

Documentation

data AssertBool a Source #

Type for evaluating a generic assertion as a pure function.

Constructors

AssertOk a

Assertion passes successfully and yields the given value.

AssertFailed [AssertStackElem]

Assertion fails with the given stack trace. In the stack trace, the outermost stackframe comes first.

Instances

Monad AssertBool Source # 

Methods

(>>=) :: AssertBool a -> (a -> AssertBool b) -> AssertBool b #

(>>) :: AssertBool a -> AssertBool b -> AssertBool b #

return :: a -> AssertBool a #

fail :: String -> AssertBool a #

Functor AssertBool Source # 

Methods

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

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

Applicative AssertBool Source # 

Methods

pure :: a -> AssertBool a #

(<*>) :: AssertBool (a -> b) -> AssertBool a -> AssertBool b #

(*>) :: AssertBool a -> AssertBool b -> AssertBool b #

(<*) :: AssertBool a -> AssertBool b -> AssertBool a #

AssertM AssertBool Source # 
Eq a => Eq (AssertBool a) Source # 

Methods

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

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

Ord a => Ord (AssertBool a) Source # 
Read a => Read (AssertBool a) Source # 
Show a => Show (AssertBool a) Source # 

boolValue :: AssertBool a -> Bool Source #

Evaluates a generic assertion to a Bool value.

eitherValue :: AssertBool a -> Either String a Source #

Evaluates a generic assertion to an Either value. The result is Right x if the assertion passes and yields value x, otherwise the result is Left err, where err is an error message.

formatStack :: [AssertStackElem] -> String Source #

Formats a stack trace.