Sha256: fb29501a63aee181fedc9e656f84c67586971e76fd2e669a24273afccd5d52b2

Contents?: true

Size: 1.1 KB

Versions: 229

Compression:

Stored size: 1.1 KB

Contents

import Data.Char         (toUpper)
import Test.Hspec        (Spec, it, shouldBe)
import Test.Hspec.Runner (configFastFail, defaultConfig, hspecWith)

import Accumulate (accumulate)

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

specs :: Spec
specs = do

    let square x = x * x :: Int

    it "empty accumulation" $
      accumulate square []
      `shouldBe` []

    it "accumulate squares" $
      accumulate square [1, 2, 3]
      `shouldBe` [1, 4, 9]

    it "accumulate upcases" $
      accumulate (map toUpper) ["hello", "world"]
      `shouldBe` ["HELLO", "WORLD"]

    it "accumulate reversed strings" $
      accumulate reverse ["the", "quick", "brown", "fox", "etc"]
      `shouldBe` ["eht", "kciuq", "nworb", "xof", "cte"]

    it "accumulate recursively" $
      accumulate (\c -> accumulate ((c:) . show) ([1, 2, 3] :: [Int])) "abc"
      `shouldBe` [["a1", "a2", "a3"], ["b1", "b2", "b3"], ["c1", "c2", "c3"]]

    it "accumulate non-strict" $
      take 1 (accumulate id ("nice work!" : error "accumulate should be even lazier, don't use reverse!"))
      `shouldBe` ["nice work!"]

Version data entries

229 entries across 229 versions & 1 rubygems

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