Получайте ошибку соответствия в haskell при тестировании функции

это функция

toRevDigits :: Integer -> [Integer]
toRevDigits 0 = []
toRevDigits x
    | x<0 = []
    | otherwise = lastDigit x:(toRevDigits (dropLastDigit x))

это тест

testRevDigits :: (Integer, [Integer]) -> Bool
testRevDigits (n, [d]) = toRevDigits n ==[n]

ex2Tests :: [Test]
ex2Tests = [Test "toRevDigits test" testRevDigits
            [(321,[1,2,3]), (0,[]), ((-17),[])]
           ]

это ошибка

*** Exception: LAB8Tests.hs:27:1-44: Non-exhaustive patterns in function         testRevDigits

Как я могу исправить работу тестера, чтобы он работал?

1 ответ

Конечно это - в вашем testRevDigits вы подходите для [d] - это означает, что второй компонент входного кортежа будет работать только со списками длины 1, но вы переходите в более длинные списки.

Мое лучшее предположение, что вы хотите это:

testRevDigits :: (Integer, [Integer]) -> Bool
testRevDigits (n,expected) = toRevDigits n == expected
Другие вопросы по тегам