Sto cercando di utilizzare QuickCheck dopo another answer. I test come questo:quickCheckAll restituisce sempre "True"
{-# 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
Poi ho caricarlo nel winGHCI e chiamare check
e check2
. Ottengo
quickCheck
*** Failed! (after 1 test):
Exception:
list.hs:(7,1)-(8,23): Non-exhaustive patterns in function last'
""
che penso sia ragionevole. Tuttavia, ottengo questo da check2
quickCheckAll
True
Sono confuso perché non importa quanto a cambiare la funzione last'
, anche sbagliato, quickCheckAll
tornare sempre vero.
Cosa c'è di sbagliato nel mio codice? Come posso risolvere questo?
Per quello che vale, quando provo, ricevo anche un avviso: "Nome prop_test trovato nel file sorgente ma non era nell'ambito" (con un numero di linea che punta alla chiamata a 'quickCheckAll'). Molto misterioso –