QuickCheck 1和QuickCheck 2有哪些主要区别?通过查看Haddock文档,我可以看到它分散在更多模块中,coarbitrary
已被新的Fun
类型和FunArbitrary
类所取代(这对我来说似乎更容易理解),现在支持测试monadic代码。我还应该注意什么?
答案 0 :(得分:54)
我已经看到了QuickCheck 2的一个重大进步,我认为与monadic代码测试一样重要,如果不是更多:
class Arbitrary a where
arbitrary :: Gen a
shrink :: a -> [a]
这是真的真棒。收缩方法是可选的,但是如果您可以提供类型的“可能为空”减少的列表,那么当QuickCheck发现错误检查时,它会尝试通过尝试收缩它然后重新将错误数据减少到最小 - 测试一下只要它失败,它就会缩小它。
一个小小的样本来说服你,不要畏缩:
FormulaPrim deparsing : *** Failed! Falsifiable (after 4 tests):
Poly (Polynome "p" [(CoeffRatio (26 % 25),PolyRest (CoeffRatio (129 % 40))),(CoeffInt 96,PolyRest (CoeffInt 11)),(CoeffInt 29,PolyRest (CoeffRatio (147 % 121))),(CoeffRatio (62 % 9),PolyRest (CoeffRatio (90 % 43))),(CoeffInt 56,PolyRest (CoeffInt 27))])
使用:
FormulaPrim deparsing : *** Failed! Falsifiable (after 2 tests and 3 shrinks):
Poly (Polynome "t" [(CoeffInt 14,PolyRest (CoeffInt 126))])
较短的失败示例意味着更快的调试: - )