Sha256: 6bbe33699a45271f597d2e6d19d13bdb5b046e032180ae9831681f4d1e17a2c1

Contents?: true

Size: 1.83 KB

Versions: 165

Compression:

Stored size: 1.83 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 LeapYear (isLeapYear)

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

specs :: Spec
specs = describe "leap" $
          describe "isLeapYear" $ for_ cases test
  where

    test Case{..} = it explanation assertion
      where
        explanation = unwords [show input, "-", description]
        assertion   = isLeapYear (fromIntegral input) `shouldBe` expected

-- Test cases adapted from `exercism/x-common/leap.json` on 2016-07-27.

data Case = Case { description :: String
                 , input       :: Integer
                 , expected    :: Bool
                 }

cases :: [Case]
cases = [ Case { description = "leap year"
               , input       = 1996
               , expected    = True
               }
        , Case { description = "standard and odd year"
               , input       = 1997
               , expected    = False
               }
        , Case { description = "standard even year"
               , input       = 1998
               , expected    = False
               }
        , Case { description = "standard nineteenth century"
               , input       = 1900
               , expected    = False
               }
        , Case { description = "standard eighteenth century"
               , input       = 1800
               , expected    = False
               }
        , Case { description = "leap twenty fourth century"
               , input       = 2400
               , expected    = True
               }
        , Case { description = "leap y2k"
               , input       = 2000
               , expected    = True
               }
        ]

Version data entries

165 entries across 165 versions & 1 rubygems

Version Path
trackler-2.1.0.9 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.8 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.7 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.6 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.5 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.4 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.3 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.2 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.1 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.1.0.0 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.55 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.54 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.53 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.52 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.51 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.50 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.49 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.48 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.47 tracks/haskell/exercises/leap/test/Tests.hs
trackler-2.0.8.46 tracks/haskell/exercises/leap/test/Tests.hs