quickCheckAll всегда возвращает True

Я пытаюсь использовать 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.

Что не так с моим кодом? Как я могу это исправить?


person Ervine    schedule 06.02.2015    source источник
comment
Что бы это ни стоило, когда я пытаюсь, я также получаю предупреждение: Имя prop_test найдено в исходном файле, но не входит в область действия (с номером строки, указывающим на вызов quickCheckAll). Очень загадочно.   -  person Daniel Wagner    schedule 06.02.2015


Ответы (2)


Из документов Test.QuickCheck.All:

Чтобы использовать quickCheckAll, добавьте определение в свой модуль в соответствии со строками

return []
runTests = $quickCheckAll

а затем выполните runTests.

Примечание: странная цифра return [] в приведенном выше примере необходима для GHC 7.8; без него quickCheckAll не сможет найти ни одно из свойств.

Добавление return [] перед вашим check помогает мне.

person Ørjan Johansen    schedule 06.02.2015

Чтобы использовать quickCheckAll, вам нужна функция, которая гласит:

return [] runTests = $quickCheckAll

В другом комментарии упоминается об этом, но не указывается, что он все равно всегда будет возвращать true, если функция не расположена ниже всех ваших функций quickCheck!

person Joseph Boyd    schedule 15.01.2017