Hspec: Behavior-Driven Development for Haskell

User's Manual

cabal update && cabal install hspec
-- file Spec.hs
import Test.Hspec
import Test.QuickCheck
import Control.Exception (evaluate)

main :: IO ()
main = hspec $ do
  describe "Prelude.head" $ do
    it "returns the first element of a list" $ do
      head [23 ..] `shouldBe` (23 :: Int)

    it "returns the first element of an *arbitrary* list" $
      property $ \x xs -> head (x:xs) == (x :: Int)

    it "throws an exception if used with an empty list" $ do
      evaluate (head []) `shouldThrow` anyException
runhaskell Spec.hs

Prelude.head
  - returns the first element of a list
  - returns the first element of an *arbitrary* list
  - throws an exception if used with an empty list

Finished in 0.0015 seconds
3 examples, 0 failures

Table of contents

About this manual

We continually improve this manual. If you want to help, grab the sources from GitHub and /join #hspec on freenode!

Other resources