我正在尝试遵循另一个答案来使用QuickCheck。 我的测试如下:
{-# LANGUAGE TemplateHaskell #-}
import Test.QuickCheck
import Test.QuickCheck.All
last' :: [a] -> a
last' [x] = x
last' (_:xs) = last' xs
prop_test x = last' x == last x
check = do
putStrLn "quickCheck"
quickCheck (prop_test :: [Char]-> Bool)
check2 = do
putStrLn "quickCheckAll"
$quickCheckAll
然后我在winGHCI中加载它,调用check
和check2
。 我得到
quickCheck
*** Failed! (after 1 test):
Exception:
list.hs:(7,1)-(8,23): Non-exhaustive patterns in function last'
""
我认为这很合理。然而,我从 check2
得到了这个结果。
quickCheckAll
True
我很困惑,因为无论我如何修改last'
函数,甚至是错误的修改,quickCheckAll
总是返回True。
我的代码出了什么问题?我该怎么修复?
quickCheckAll
的调用)。非常神秘。 - Daniel Wagner