mirror of
https://github.com/jfmengels/elm-review.git
synced 2024-12-27 19:56:10 +03:00
107 lines
3.1 KiB
Elm
107 lines
3.1 KiB
Elm
module DefaultPatternPositionTest exposing (all)
|
|
|
|
import Elm.Syntax.Range exposing (Location, Range)
|
|
import Lint.Rule exposing (Error, Rule)
|
|
import Lint.Rule.DefaultPatternPosition exposing (PatternPosition(..), rule)
|
|
import Lint.Test exposing (LintResult)
|
|
import Test exposing (Test, describe, test)
|
|
|
|
|
|
testRule : PatternPosition -> String -> LintResult
|
|
testRule patternPosition =
|
|
Lint.Test.ruleTester (rule patternPosition)
|
|
|
|
|
|
error : String -> Error
|
|
error position =
|
|
Lint.Test.errorWithoutRange
|
|
("Expected default pattern to appear " ++ position ++ " in the list of patterns")
|
|
|
|
|
|
tests : List Test
|
|
tests =
|
|
[ test "should not report when default pattern is at the expected position (first)" <|
|
|
\() ->
|
|
"""module A exposing(..)
|
|
a = case b of
|
|
_ -> 1
|
|
Bar -> 1
|
|
Foo -> 1
|
|
"""
|
|
|> testRule ShouldBeFirst
|
|
|> Lint.Test.expectErrorsWithoutRange []
|
|
, test "should not report when default pattern is at the expected position (last)" <|
|
|
\() ->
|
|
"""module A exposing(..)
|
|
a = case b of
|
|
Foo -> 1
|
|
Bar -> 1
|
|
_ -> 1
|
|
"""
|
|
|> testRule ShouldBeLast
|
|
|> Lint.Test.expectErrorsWithoutRange []
|
|
, test "should not report when there is no default pattern (first)" <|
|
|
\() ->
|
|
"""module A exposing(..)
|
|
a = case b of
|
|
Foo -> 1
|
|
Bar -> 1
|
|
"""
|
|
|> testRule ShouldBeFirst
|
|
|> Lint.Test.expectErrorsWithoutRange []
|
|
, test "should not report when there is no default pattern (last)" <|
|
|
\() ->
|
|
"""module A exposing(..)
|
|
a = case b of
|
|
Foo -> 1
|
|
Bar -> 1
|
|
"""
|
|
|> testRule ShouldBeLast
|
|
|> Lint.Test.expectErrorsWithoutRange []
|
|
, test "should report an error when the default pattern is not at the expected position (first) (opposite expected position)" <|
|
|
\() ->
|
|
"""module A exposing(..)
|
|
a = case b of
|
|
Foo -> 1
|
|
Bar -> 1
|
|
_ -> 1
|
|
"""
|
|
|> testRule ShouldBeFirst
|
|
|> Lint.Test.expectErrorsWithoutRange [ error "first" ]
|
|
, test "should report an error when the default pattern is not at the expected position (first) (somewhere in the middle)" <|
|
|
\() ->
|
|
"""module A exposing(..)
|
|
a = case b of
|
|
Foo -> 1
|
|
_ -> 1
|
|
Bar -> 1
|
|
"""
|
|
|> testRule ShouldBeFirst
|
|
|> Lint.Test.expectErrorsWithoutRange [ error "first" ]
|
|
, test "should report an error when the default pattern is not at the expected position (last) (opposite expected position)" <|
|
|
\() ->
|
|
"""module A exposing(..)
|
|
a = case b of
|
|
_ -> 1
|
|
Foo -> 1
|
|
Bar -> 1
|
|
"""
|
|
|> testRule ShouldBeLast
|
|
|> Lint.Test.expectErrorsWithoutRange [ error "last" ]
|
|
, test "should report an error when the default pattern is not at the expected position (last) (somewhere in the middle)" <|
|
|
\() ->
|
|
"""module A exposing(..)
|
|
a = case b of
|
|
Foo -> 1
|
|
_ -> 1
|
|
Bar -> 1
|
|
"""
|
|
|> testRule ShouldBeLast
|
|
|> Lint.Test.expectErrorsWithoutRange [ error "last" ]
|
|
]
|
|
|
|
|
|
all : Test
|
|
all =
|
|
describe "DefaultPatternPosition" tests
|