2024-01-29 20:42:33 +00:00
|
|
|
module Test.Tools.RationalOrder exposing (..)
|
|
|
|
|
|
|
|
import Expect
|
2024-02-15 12:20:25 +00:00
|
|
|
import Fuzz exposing (Fuzzer)
|
2024-01-29 20:42:33 +00:00
|
|
|
import Internal.Tools.RationalOrder as RO exposing (RationalOrder(..))
|
2024-02-15 12:20:25 +00:00
|
|
|
import Test exposing (..)
|
|
|
|
|
2024-01-29 20:42:33 +00:00
|
|
|
|
|
|
|
fuzzer : Fuzzer RationalOrder
|
|
|
|
fuzzer =
|
|
|
|
Fuzz.map2 With Fuzz.int (Fuzz.lazy (\_ -> Fuzz.maybe fuzzer))
|
|
|
|
|
2024-02-15 12:20:25 +00:00
|
|
|
|
|
|
|
twoUnequal : Fuzzer ( RationalOrder, RationalOrder )
|
2024-01-29 20:42:33 +00:00
|
|
|
twoUnequal =
|
|
|
|
fuzzer
|
|
|
|
|> Fuzz.andThen
|
|
|
|
(\o ->
|
|
|
|
Fuzz.map2
|
|
|
|
(\o1 o2 ->
|
|
|
|
if RO.compare o1 o2 == LT then
|
|
|
|
( o1, o2 )
|
2024-02-15 12:20:25 +00:00
|
|
|
|
2024-01-29 20:42:33 +00:00
|
|
|
else
|
|
|
|
( o2, o1 )
|
|
|
|
)
|
|
|
|
(Fuzz.constant o)
|
|
|
|
(Fuzz.filter ((/=) o) fuzzer)
|
|
|
|
)
|
|
|
|
|
2024-02-15 12:20:25 +00:00
|
|
|
|
2024-01-29 20:42:33 +00:00
|
|
|
suite : Test
|
|
|
|
suite =
|
|
|
|
describe "RationalOrder"
|
|
|
|
[ describe "Semantic truths"
|
|
|
|
[ describe "After is always greater"
|
2024-02-15 12:20:25 +00:00
|
|
|
[ fuzz fuzzer
|
|
|
|
"Forwards"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\o ->
|
|
|
|
Expect.equal LT (RO.compare o (RO.after o))
|
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz fuzzer
|
|
|
|
"Backwards"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\o ->
|
|
|
|
Expect.equal GT (RO.compare (RO.after o) o)
|
|
|
|
)
|
|
|
|
]
|
|
|
|
, describe "Before is always lesser"
|
2024-02-15 12:20:25 +00:00
|
|
|
[ fuzz fuzzer
|
|
|
|
"Forwards"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\o ->
|
|
|
|
Expect.equal GT (RO.compare o (RO.before o))
|
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz fuzzer
|
|
|
|
"Backwards"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\o ->
|
|
|
|
Expect.equal LT (RO.compare (RO.before o) o)
|
|
|
|
)
|
|
|
|
]
|
|
|
|
, describe "Two unequal == two unequal"
|
2024-02-15 12:20:25 +00:00
|
|
|
[ fuzz twoUnequal
|
|
|
|
"Forwards"
|
|
|
|
(\( small, big ) ->
|
2024-01-29 20:42:33 +00:00
|
|
|
Expect.equal LT (RO.compare small big)
|
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz twoUnequal
|
|
|
|
"Backwards"
|
|
|
|
(\( small, big ) ->
|
2024-01-29 20:42:33 +00:00
|
|
|
Expect.equal GT (RO.compare big small)
|
|
|
|
)
|
|
|
|
]
|
|
|
|
, describe "compare"
|
2024-02-15 12:20:25 +00:00
|
|
|
[ fuzz2 fuzzer
|
|
|
|
fuzzer
|
|
|
|
"EQ iff same value"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\o1 o2 ->
|
|
|
|
Expect.equal
|
|
|
|
(o1 == o2)
|
|
|
|
(RO.compare o1 o2 == EQ)
|
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz2 fuzzer
|
|
|
|
fuzzer
|
|
|
|
"LT iff opposite GT"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\o1 o2 ->
|
|
|
|
Expect.equal
|
|
|
|
(RO.compare o1 o2 == LT)
|
|
|
|
(RO.compare o2 o1 == GT)
|
|
|
|
)
|
|
|
|
]
|
2024-02-15 12:20:25 +00:00
|
|
|
, describe "Between is always between"
|
|
|
|
[ fuzz twoUnequal
|
|
|
|
"Less than first - forwards"
|
|
|
|
(\( small, big ) ->
|
|
|
|
RO.between small big
|
|
|
|
|> RO.compare small
|
|
|
|
|> Expect.equal LT
|
|
|
|
)
|
|
|
|
, fuzz twoUnequal
|
|
|
|
"Less than first - backwards"
|
|
|
|
(\( small, big ) ->
|
|
|
|
small
|
|
|
|
|> RO.compare (RO.between small big)
|
|
|
|
|> Expect.equal GT
|
|
|
|
)
|
|
|
|
, fuzz twoUnequal
|
|
|
|
"Less than second - forwards"
|
|
|
|
(\( small, big ) ->
|
|
|
|
RO.between small big
|
|
|
|
|> RO.compare big
|
|
|
|
|> Expect.equal GT
|
|
|
|
)
|
|
|
|
, fuzz twoUnequal
|
|
|
|
"Less than second - backwards"
|
|
|
|
(\( small, big ) ->
|
|
|
|
big
|
|
|
|
|> RO.compare (RO.between small big)
|
|
|
|
|> Expect.equal LT
|
|
|
|
)
|
|
|
|
]
|
2024-01-29 20:42:33 +00:00
|
|
|
]
|
|
|
|
, describe "Between creates between"
|
|
|
|
[ test "With 0 Nothing <--> With 1 Nothing"
|
|
|
|
(\() ->
|
|
|
|
RO.between (With 0 Nothing) (With 1 Nothing)
|
|
|
|
|> Expect.equal (With 0 (Just (With 0 Nothing)))
|
|
|
|
)
|
|
|
|
, test "With 1 Nothing <--> With 0 Nothing"
|
|
|
|
(\() ->
|
|
|
|
RO.between (With 1 Nothing) (With 0 Nothing)
|
|
|
|
|> Expect.equal (With 0 (Just (With 0 Nothing)))
|
|
|
|
)
|
|
|
|
, test "With 0 is filled between With 1 Nothing"
|
|
|
|
(\() ->
|
|
|
|
With 0 Nothing
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> Expect.equal (With 0 (Just (With 5 Nothing)))
|
|
|
|
)
|
|
|
|
, test "Will start counting high level as soon as possible"
|
|
|
|
(\() ->
|
|
|
|
With 0 Nothing
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> Expect.equal (With 2 Nothing)
|
|
|
|
)
|
|
|
|
, test "Will start counting high level, then return lower level"
|
|
|
|
(\() ->
|
|
|
|
With 0 Nothing
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 1 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> RO.between (With 5 Nothing)
|
|
|
|
|> Expect.equal (With 4 (Just (With 6 Nothing)))
|
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz2 fuzzer
|
|
|
|
fuzzer
|
|
|
|
"Between is commutative"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\o1 o2 ->
|
|
|
|
Expect.equal (RO.between o1 o2) (RO.between o2 o1)
|
|
|
|
)
|
|
|
|
]
|
|
|
|
, describe "After"
|
2024-02-15 12:20:25 +00:00
|
|
|
[ fuzz Fuzz.int
|
|
|
|
"One more - level 1"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\a ->
|
|
|
|
Expect.equal
|
2024-02-15 12:20:25 +00:00
|
|
|
(RO.after <| With a Nothing)
|
|
|
|
(With (a + 1) Nothing)
|
2024-01-29 20:42:33 +00:00
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz2 Fuzz.int
|
|
|
|
Fuzz.int
|
|
|
|
"One more - level 2"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\a b ->
|
|
|
|
Expect.equal
|
2024-02-15 12:20:25 +00:00
|
|
|
(RO.after <| With a <| Just <| With b Nothing)
|
|
|
|
(With (a + 1) Nothing)
|
2024-01-29 20:42:33 +00:00
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz3 Fuzz.int
|
|
|
|
Fuzz.int
|
|
|
|
Fuzz.int
|
|
|
|
"One more - level 3"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\a b c ->
|
|
|
|
Expect.equal
|
2024-02-15 12:20:25 +00:00
|
|
|
(RO.after <| With a <| Just <| With b <| Just <| With c Nothing)
|
|
|
|
(With (a + 1) Nothing)
|
2024-01-29 20:42:33 +00:00
|
|
|
)
|
|
|
|
]
|
|
|
|
, describe "Before"
|
2024-02-15 12:20:25 +00:00
|
|
|
[ fuzz Fuzz.int
|
|
|
|
"One less - level 1"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\a ->
|
|
|
|
Expect.equal
|
2024-02-15 12:20:25 +00:00
|
|
|
(RO.before <| With a Nothing)
|
|
|
|
(With (a - 1) Nothing)
|
2024-01-29 20:42:33 +00:00
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz2 Fuzz.int
|
|
|
|
Fuzz.int
|
|
|
|
"One less - level 2"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\a b ->
|
|
|
|
Expect.equal
|
2024-02-15 12:20:25 +00:00
|
|
|
(RO.before <| With a <| Just <| With b Nothing)
|
|
|
|
(With (a - 1) Nothing)
|
2024-01-29 20:42:33 +00:00
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz3 Fuzz.int
|
|
|
|
Fuzz.int
|
|
|
|
Fuzz.int
|
|
|
|
"One less - level 3"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\a b c ->
|
|
|
|
Expect.equal
|
2024-02-15 12:20:25 +00:00
|
|
|
(RO.before <| With a <| Just <| With b <| Just <| With c Nothing)
|
|
|
|
(With (a - 1) Nothing)
|
2024-01-29 20:42:33 +00:00
|
|
|
)
|
|
|
|
]
|
|
|
|
, describe "Compare vs. list compare"
|
|
|
|
[ fuzz2
|
|
|
|
(Fuzz.listOfLengthBetween 1 32 Fuzz.int)
|
|
|
|
(Fuzz.listOfLengthBetween 1 32 Fuzz.int)
|
|
|
|
"Compares the same between normal lists and orders"
|
|
|
|
(\l1 l2 ->
|
|
|
|
Expect.equal
|
2024-02-15 12:20:25 +00:00
|
|
|
(Just <| Basics.compare l1 l2)
|
|
|
|
(Maybe.map2 RO.compare (RO.fromList l1) (RO.fromList l2))
|
2024-01-29 20:42:33 +00:00
|
|
|
)
|
2024-02-15 12:20:25 +00:00
|
|
|
, fuzz2 fuzzer
|
|
|
|
fuzzer
|
|
|
|
"Compares the same when converted to list"
|
2024-01-29 20:42:33 +00:00
|
|
|
(\o1 o2 ->
|
|
|
|
Expect.equal
|
2024-02-15 12:20:25 +00:00
|
|
|
(RO.compare o1 o2)
|
|
|
|
(Basics.compare (RO.toList o1) (RO.toList o2))
|
2024-01-29 20:42:33 +00:00
|
|
|
)
|
|
|
|
]
|
|
|
|
]
|