explainable-predicates

Predicates that can explain themselves.

https://github.com/cdsmith/explainable-predicates

Version on this page:0.1.2.3@rev:1
LTS Haskell 22.34:0.1.2.4
Stackage Nightly 2024-09-17:0.1.2.4
Latest on Hackage:0.1.2.4

See all snapshots explainable-predicates appears in

BSD-3-Clause licensed and maintained by Chris Smith
This version can be pinned in stack with:explainable-predicates-0.1.2.3@sha256:97e5e6f3d28302e244f9704677264628992d568b9b59bc6225b8007c90f681e1,3909

Module documentation for 0.1.2.3

explainable-predicates - Predicates that can explain themselves

CI Hackage

Explainable predicates are essentially functions from types to Bool which can additionally describe themselves and explain why an argument does or doesn’t match. They are intended to be used during unit tests to provide better error messages when tests fail. For example, if a collection is missing an element, an explainable predicate can tell you which element is missing.

FAQ

Here are a few tips for making the most of explainable-predicates.

Which GHC versions are supported?

explainable-predicates is tested with GHC versions from 8.6 through 9.4.

Changes

Revision history for explainable-predicates

0.1.2.3 – 2021-09-18

  • Version bounds now allow GHC 9.4

0.1.2.2 – 2021-12-20

  • Better error messages for HUnit integration.

0.1.2.1 – 2021-12-20

  • Builds with GHC 9.2.1

0.1.2.0 – 2021-09-25

  • HUnit and Hspec integration is now available in Test.Predicates.HUnit.

0.1.1.0 – 2021-09-25

  • Predicate now has a Contravariant instance.
  • ==~ is an infix synonym for accept.
  • Cabal regex and containers flags (default true) enable regex and container predicates, respectively.
  • Cabal dev flag (default false) turns GHC warnings into errors.
  • The inBranch and qADT combinators are now available for more convenient matching of algebraic data types and fields.
  • QuickCheck integration is now available in Test.Predicates.QuickCheck.

0.1.0.0 – 2021-09-18

  • First version. Released on an unsuspecting world.