module Xanthous.UtilSpec (main, test) where import Test.Prelude import Xanthous.Util import Control.Monad.State.Lazy (execState) main :: IO () main = defaultMain test test :: TestTree test = testGroup "Xanthous.Util" [ testGroup "smallestNotIn" [ testCase "examples" $ do smallestNotIn [7 :: Word, 3, 7] @?= 0 smallestNotIn [7 :: Word, 0, 1, 3, 7] @?= 2 , testProperty "returns an element not in the list" $ \(xs :: [Word]) -> smallestNotIn xs `notElem` xs , testProperty "pred return is in the list" $ \(xs :: [Word]) -> let res = smallestNotIn xs in res /= 0 ==> pred res `elem` xs , testProperty "ignores order" $ \(xs :: [Word]) -> forAll (shuffle xs) $ \shuffledXs -> smallestNotIn xs === smallestNotIn shuffledXs ] , testGroup "takeWhileInclusive" [ testProperty "takeWhileInclusive (const True) ≡ id" $ \(xs :: [Int]) -> takeWhileInclusive (const True) xs === xs ] , testGroup "endoTimes" [ testCase "endoTimes 4 succ 5" $ endoTimes (4 :: Int) succ (5 :: Int) @?= 9 ] , testGroup "modifyKL" [ testCase "_1 += 1" $ execState (modifyKL _1 $ pure . succ) (1 :: Int, 2 :: Int) @?= (2, 2) ] ]