Sha256: 2a4ddbbcfc401fadd9f394cd1912a3276f1af0335e3b41429c1d2f38bcbf1775

Contents?: true

Size: 1.54 KB

Versions: 145

Compression:

Stored size: 1.54 KB

Contents

{-# OPTIONS_GHC -fno-warn-type-defaults #-}
{-# LANGUAGE RecordWildCards #-}

import Data.Foldable     (for_)
import Test.Hspec        (Spec, describe, it, shouldBe)
import Test.Hspec.Runner (configFastFail, defaultConfig, hspecWith)

import CollatzConjecture (collatz)

main :: IO ()
main = hspecWith defaultConfig {configFastFail = True} specs

specs :: Spec
specs = describe "collatz" $ for_ cases test
  where

    test Case{..} = it description assertion
      where
        assertion = collatz number `shouldBe` expected


data Case = Case { description :: String
                 , number      :: Integer
                 , expected    :: Maybe Integer
                 }

cases :: [Case]
cases = [ Case { description = "zero steps for one"
               , number      = 1
               , expected    = Just 0
               }
        , Case { description = "divide if even"
               , number      = 16
               , expected    = Just 4
               }
        , Case { description = "even and odd steps"
               , number      = 12
               , expected    = Just 9
               }
        , Case { description = "Large number of even and odd steps"
               , number      = 1000000
               , expected    = Just 152
               }
        , Case { description = "zero is an error"
               , number      = 0
               , expected    = Nothing
               }
        , Case { description = "negative value is an error"
               , number      = -15
               , expected    = Nothing
               }
        ]

Version data entries

145 entries across 145 versions & 1 rubygems

Version Path
trackler-2.2.1.180 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.179 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.178 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.177 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.176 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.175 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.174 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.173 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.172 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.171 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.170 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.169 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.167 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.166 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.165 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.164 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.163 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.162 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.161 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs
trackler-2.2.1.160 tracks/haskell/exercises/collatz-conjecture/test/Tests.hs