mirror of
https://github.com/correl/elm.git
synced 2025-01-21 19:08:01 +00:00
4d81104a85
This allows learners to gradually approach exercise. However, unlike commented tests, the Elm compiler is still able to infer type information from the skipped tests.
86 lines
3.3 KiB
Elm
86 lines
3.3 KiB
Elm
module Tests exposing (..)
|
|
|
|
import Test exposing (..)
|
|
import Expect
|
|
import ListOps exposing (..)
|
|
|
|
|
|
tests : Test
|
|
tests =
|
|
describe "List Ops"
|
|
[ describe "length"
|
|
[ test "empty list" <|
|
|
\() -> Expect.equal 0 (ListOps.length [])
|
|
, skip <|
|
|
test "non-empty list" <|
|
|
\() -> Expect.equal 4 (ListOps.length (List.range 1 4))
|
|
]
|
|
, describe "reverse"
|
|
[ skip <|
|
|
test "empty list" <|
|
|
\() -> Expect.equal [] (ListOps.reverse [])
|
|
, skip <|
|
|
test "non-empty list" <|
|
|
\() -> Expect.equal [ 4, 3, 2, 1 ] (ListOps.reverse (List.range 1 4))
|
|
]
|
|
, describe "map"
|
|
[ skip <|
|
|
test "empty list" <|
|
|
\() -> Expect.equal [] (ListOps.map ((+) 1) [])
|
|
, skip <|
|
|
test "non-empty list" <|
|
|
\() -> Expect.equal (List.range 2 5) (ListOps.map ((+) 1) (List.range 1 4))
|
|
]
|
|
, describe "filter"
|
|
[ skip <|
|
|
test "empty list" <|
|
|
\() -> Expect.equal [] (ListOps.filter (\_ -> True) [])
|
|
, skip <|
|
|
test "non-empty list" <|
|
|
\() -> Expect.equal [ 2, 4 ] (ListOps.filter (\x -> x % 2 == 0) (List.range 1 4))
|
|
]
|
|
, describe "foldl"
|
|
[ skip <|
|
|
test "empty list" <|
|
|
\() -> Expect.equal 0 (ListOps.foldl (+) 0 [])
|
|
, skip <|
|
|
test "non-empty list" <|
|
|
\() -> Expect.equal 10 (ListOps.foldl (+) 0 (List.range 1 4))
|
|
, skip <|
|
|
test "direction" <|
|
|
\() -> Expect.equal [ 4, 3, 2, 1 ] (ListOps.foldl (::) [] (List.range 1 4))
|
|
]
|
|
, describe "foldr"
|
|
[ skip <|
|
|
test "empty list" <|
|
|
\() -> Expect.equal 0 (ListOps.foldr (+) 0 [])
|
|
, skip <|
|
|
test "non-empty list" <|
|
|
\() -> Expect.equal 10 (ListOps.foldr (+) 0 (List.range 1 4))
|
|
, skip <|
|
|
test "direction" <|
|
|
\() -> Expect.equal (List.range 1 4) (ListOps.foldr (::) [] (List.range 1 4))
|
|
]
|
|
, describe "append"
|
|
[ skip <|
|
|
test "empty lists" <|
|
|
\() -> Expect.equal [] (ListOps.append [] [])
|
|
, skip <|
|
|
test "empty and non-empty lists" <|
|
|
\() -> Expect.equal (List.range 1 4) (ListOps.append [] (List.range 1 4))
|
|
, skip <|
|
|
test "non-empty and empty lists" <|
|
|
\() -> Expect.equal (List.range 1 4) (ListOps.append (List.range 1 4) [])
|
|
, skip <|
|
|
test "non-empty lists" <|
|
|
\() -> Expect.equal (List.range 1 8) (ListOps.append (List.range 1 4) (List.range 5 8))
|
|
]
|
|
, describe "concat"
|
|
[ skip <|
|
|
test "empty list" <|
|
|
\() -> Expect.equal [] (ListOps.concat [])
|
|
, skip <|
|
|
test "list of lists" <|
|
|
\() -> Expect.equal (List.range 1 10) (ListOps.concat [ List.range 1 3, [], List.range 4 7, List.range 8 10 ])
|
|
]
|
|
]
|