Sha256: 5b775f5923ba08900b0a882877345ccf067c85e7e67d516553f1025dd8634713

Contents?: true

Size: 1.52 KB

Versions: 229

Compression:

Stored size: 1.52 KB

Contents

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

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

import Grains (square, total)

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

specs :: Spec
specs = do
          describe "square" $ for_ squareCases squareTest
          describe "total"  $ totalTest totalCase
  where

    squareTest (description, n, expected) = it description assertion
      where
        assertion  = expression `shouldBe` expected
        expression = fmap fromIntegral . square . fromIntegral $ n

    totalTest (description, expected) = it description assertion
      where
        assertion = fromIntegral total `shouldBe` expected

squareCases :: [(String, Integer, Maybe Integer)]
squareCases =
    [ ("square 1"             ,  1, Just                   1)
    , ("square 2"             ,  2, Just                   2)
    , ("square 3"             ,  3, Just                   4)
    , ("square 4"             ,  4, Just                   8)
    , ("square 16"            , 16, Just               32768)
    , ("square 32"            , 32, Just          2147483648)
    , ("square 64"            , 64, Just 9223372036854775808)
    , ("square negative"      , -1, Nothing                 )
    , ("square 0"             ,  0, Nothing                 )
    , ("square bigger than 64", 65, Nothing                 ) ]

totalCase :: (String, Integer)
totalCase = ("total grains", 18446744073709551615)

Version data entries

229 entries across 229 versions & 1 rubygems

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