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.139 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.138 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.137 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.136 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.135 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.134 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.133 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.132 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.131 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.130 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.129 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.128 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.127 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.126 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.125 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.124 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.123 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.122 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.121 tracks/haskell/exercises/accumulate/test/Tests.hs
trackler-2.2.1.120 tracks/haskell/exercises/accumulate/test/Tests.hs