Skip to content

Instantly share code, notes, and snippets.

Embed
What would you like to do?
forAll :: (Show a, Testable testable)
=> Gen a -> Shrink a -> (a -> testable) -> Property
forAll argGen shrink prop =
Property $ Gen $ \rand -> -- Create a new property that will
let (rand1, rand2) = split rand -- Split the generator in two
arg = runGen argGen rand1 -- Use the first generator to produce an arg
runSub = evalSubProp prop rand2 -- Factorize a runner for the sub-property
result = runSub arg -- Run the sub-property with value `arg`
in overFailure result $ \failure -> -- In case of failure,
shrinking shrink arg runSub -- Attempt to shrink the counter example
<> -- OR (in case the shrinking failed)
addToCounterExample arg failure -- Add the argument to the counter example
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment