| Safe Haskell | Safe |
|---|---|
| Language | Haskell2010 |
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.
- class Monad m => AssertM m where
- data AssertStackElem = AssertStackElem {}
- data AssertBool a
- = AssertOk a
- | AssertFailed [AssertStackElem]
- boolValue :: AssertBool a -> Bool
- eitherValue :: AssertBool a -> Either String a
- formatStack :: [AssertStackElem] -> String
Documentation
class Monad m => AssertM m where Source #
A typeclass for generic assertions.
Minimal complete definition
Methods
genericAssertFailure__ :: Location -> ColorString -> m a Source #
genericSubAssert :: Location -> Maybe String -> m a -> m a Source #
data AssertStackElem Source #
Stack trace element for generic assertions.
Constructors
| AssertStackElem | |
Fields | |
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 # | |
| Functor AssertBool Source # | |
| Applicative AssertBool Source # | |
| AssertM AssertBool Source # | |
| Eq a => Eq (AssertBool a) Source # | |
| Ord a => Ord (AssertBool a) Source # | |
| Read a => Read (AssertBool a) Source # | |
| Show a => Show (AssertBool a) Source # | |
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.