hedgehog: Release with confidence.

[ bsd3, library, testing ] [ Propose Tags ]

Hedgehog automatically generates a comprehensive array of test cases, exercising your software in ways human testers would never imagine.

Generate hundreds of test cases automatically, exposing even the most insidious of corner cases. Failures are automatically simplified, giving developers coherent, intelligible error messages.

To get started quickly, see the examples.


[Skip to Readme]
Versions [faq] 0.1, 0.2, 0.2.1, 0.2.2, 0.3, 0.4, 0.4.1, 0.5, 0.5.1, 0.5.2, 0.5.3, 0.6, 0.6.1, 1.0, 1.0.1
Change log CHANGELOG.md
Dependencies ansi-terminal (>=0.6 && <0.11), async (>=2.0 && <2.3), base (>=4.9 && <5), bytestring (==0.10.*), concurrent-output (>=1.7 && <1.11), containers (>=0.4 && <0.7), directory (>=1.2 && <1.4), exceptions (>=0.7 && <0.11), fail (>=4.9 && <5), lifted-async (>=0.7 && <0.11), mmorph (>=1.0 && <1.2), monad-control (==1.0.*), mtl (>=2.1 && <2.3), pretty-show (>=1.6 && <1.10), primitive (>=0.6 && <0.8), random (==1.1.*), resourcet (>=1.1 && <1.3), semigroups (>=0.16 && <0.20), stm (>=2.4 && <2.6), template-haskell (>=2.10 && <2.16), text (>=1.1 && <1.3), time (>=1.4 && <1.10), transformers (==0.5.*), transformers-base (>=0.4.5.1 && <0.5), wl-pprint-annotated (>=0.0 && <0.2) [details]
License BSD-3-Clause
Author Jacob Stanley
Maintainer Jacob Stanley <jacob@stanley.io>
Revised Revision 1 made by moodmosaic at Wed Sep 18 21:01:45 UTC 2019
Category Testing
Home page https://hedgehog.qa
Bug tracker https://github.com/hedgehogqa/haskell-hedgehog/issues
Source repo head: git clone git://github.com/hedgehogqa/haskell-hedgehog.git
Uploaded by moodmosaic at Mon Sep 16 09:12:48 UTC 2019
Distributions Arch:1.0, Debian:0.6, LTSHaskell:0.6.1, NixOS:1.0.1, Stackage:0.6.1
Downloads 10321 total (579 in the last 30 days)
Rating 2.75 (votes: 12) [estimated by rule of succession]
Your Rating
  • λ
  • λ
  • λ
Status Hackage Matrix CI
Docs available [build log]
Last success reported on 2019-09-16 [all 1 reports]

Modules

[Index] [Quick Jump]

Downloads

Note: This package has metadata revisions in the cabal description newer than included in the tarball. To unpack the package including the revisions, use 'cabal get'.

Maintainer's Corner

For package maintainers and hackage trustees


Readme for hedgehog-1.0.1

[back to package description]
<!-- Apologies to those who are able to read this. Unfortunately, Hackage doesn't seem to render the HTML portion of the markdown spec so you may be better off paying us a visit on GitHub instead: https://github.com/hedgehogqa/haskell-hedgehog --> <div align="center">

<img width="400" src="https://github.com/hedgehogqa/haskell-hedgehog/raw/master/img/hedgehog-text-logo.png" />

Release with confidence.

Hackage Travis AppVeyor

<div align="left">

Hedgehog automatically generates a comprehensive array of test cases, exercising your software in ways human testers would never imagine.

Generate hundreds of test cases automatically, exposing even the most insidious of corner cases. Failures are automatically simplified, giving developers coherent, intelligible error messages.

Features

  • Integrated shrinking, shrinks obey invariants by construction.
  • Abstract state machine testing.
  • Generators allow monadic effects.
  • Range combinators for full control over the scope of generated numbers and collections.
  • Equality and roundtrip assertions show a diff instead of the two inequal values.
  • Template Haskell test runner which executes properties concurrently.

Example

The main module, Hedgehog, includes almost everything you need to get started writing property tests with Hedgehog.

It is designed to be used alongside Hedgehog.Gen and Hedgehog.Range which should be imported qualified. You also need to enable Template Haskell so the Hedgehog test runner can find your properties.

{-# LANGUAGE TemplateHaskell #-}

import           Hedgehog
import qualified Hedgehog.Gen as Gen
import qualified Hedgehog.Range as Range

Once you have your imports set up, you can write a simple property:

prop_reverse :: Property
prop_reverse =
  property $ do
    xs <- forAll $ Gen.list (Range.linear 0 100) Gen.alpha
    reverse (reverse xs) === xs

And add the Template Haskell splice which will discover your properties:

tests :: IO Bool
tests =
  checkParallel $$(discover)

If you prefer to avoid macros, you can specify the group of properties to run manually instead:

{-# LANGUAGE OverloadedStrings #-}

tests :: IO Bool
tests =
  checkParallel $ Group "Test.Example" [
      ("prop_reverse", prop_reverse)
    ]

You can then load the module in GHCi, and run it:

λ tests
━━━ Test.Example ━━━
  ✓ prop_reverse passed 100 tests.

<div align="center"> <br /> <img width="307" src="https://github.com/hedgehogqa/haskell-hedgehog/raw/master/img/hedgehog-logo-grey.png" />