2021-04-11 17:04:53 +03:00
|
|
|
{-# OPTIONS_GHC -Wno-missing-import-lists #-}
|
|
|
|
{-# LANGUAGE FlexibleInstances #-}
|
|
|
|
{-# LANGUAGE MultiParamTypeClasses #-}
|
|
|
|
{-# LANGUAGE TemplateHaskell #-}
|
2021-04-10 20:34:26 +03:00
|
|
|
{-# LANGUAGE TypeApplications #-}
|
2020-11-13 19:49:41 +03:00
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
import Data.Int
|
|
|
|
import Data.List.NonEmpty
|
2021-04-11 17:04:53 +03:00
|
|
|
import Data.Word
|
|
|
|
import Numeric.Natural
|
2021-04-10 20:34:26 +03:00
|
|
|
import Test.HUnit
|
|
|
|
import Witch
|
2020-11-13 19:49:41 +03:00
|
|
|
|
2020-11-14 19:54:45 +03:00
|
|
|
main :: IO ()
|
2021-04-10 20:34:26 +03:00
|
|
|
main = runTestTTAndExit $ "Witch" ~:
|
2021-04-11 17:04:53 +03:00
|
|
|
[ as @Int8 1 ~?= 1
|
|
|
|
, cast (1 :: Int8) ~?= (1 :: Int16)
|
|
|
|
, from @Int8 1 ~?= (1 :: Int)
|
|
|
|
, into @Int16 (1 :: Int8) ~?= 1
|
|
|
|
, over @String (<> "!") (Name "Simon") ~?= Name "Simon!"
|
|
|
|
, via @Int16 (1 :: Int8) ~?= (1 :: Int32)
|
|
|
|
, tryFrom @Int16 1 ~?= Right (1 :: Int8)
|
|
|
|
, tryInto @Int8 (1 :: Int16) ~?= Right 1
|
|
|
|
, unsafeCast (1 :: Int16) ~?= (1 :: Int8)
|
|
|
|
, unsafeFrom @Int16 1 ~?= (1 :: Int8)
|
|
|
|
, unsafeInto @Int8 (1 :: Int16) ~?= 1
|
2021-04-11 17:16:56 +03:00
|
|
|
, ($$( liftedCast (1 :: Int16) ) :: Int8) ~?= 1
|
|
|
|
, ($$( liftedFrom @Int16 1 ) :: Int8) ~?= 1
|
|
|
|
, ($$( liftedInto @Int8 (1 :: Int16) ) :: Int8) ~?= 1
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- []
|
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
, "TryCast [a] (NonEmpty a)" ~:
|
2021-04-11 17:04:53 +03:00
|
|
|
[ tryCast @[Int] @(NonEmpty Int) [] ~?= Left (TryCastException [])
|
|
|
|
, tryCast @[Int] @(NonEmpty Int) [1] ~?= Right (1 :| [])
|
|
|
|
, tryCast @[Int] @(NonEmpty Int) [1, 2] ~?= Right (1 :| [2])
|
2021-04-10 20:34:26 +03:00
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- NonEmpty
|
|
|
|
|
|
|
|
, "Cast (NonEmpty a) [a]" ~:
|
|
|
|
[ cast @(NonEmpty Int) @[Int] (1 :| []) ~?= [1]
|
|
|
|
, cast @(NonEmpty Int) @[Int] (1 :| [2]) ~?= [1, 2]
|
|
|
|
]
|
|
|
|
|
|
|
|
-- Int8
|
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
, "Cast Int8 Int16" ~:
|
|
|
|
[ cast @Int8 @Int16 0 ~?= 0
|
|
|
|
, cast @Int8 @Int16 127 ~?= 127
|
|
|
|
, cast @Int8 @Int16 (-128) ~?= -128
|
|
|
|
]
|
|
|
|
, "Cast Int8 Int32" ~:
|
|
|
|
[ cast @Int8 @Int32 0 ~?= 0
|
|
|
|
, cast @Int8 @Int32 127 ~?= 127
|
|
|
|
, cast @Int8 @Int32 (-128) ~?= -128
|
|
|
|
]
|
|
|
|
, "Cast Int8 Int64" ~:
|
|
|
|
[ cast @Int8 @Int64 0 ~?= 0
|
|
|
|
, cast @Int8 @Int64 127 ~?= 127
|
|
|
|
, cast @Int8 @Int64 (-128) ~?= -128
|
|
|
|
]
|
|
|
|
, "Cast Int8 Int" ~:
|
|
|
|
[ cast @Int8 @Int 0 ~?= 0
|
|
|
|
, cast @Int8 @Int 127 ~?= 127
|
|
|
|
, cast @Int8 @Int (-128) ~?= -128
|
|
|
|
]
|
|
|
|
, "Cast Int8 Integer" ~:
|
|
|
|
[ cast @Int8 @Integer 0 ~?= 0
|
|
|
|
, cast @Int8 @Integer 127 ~?= 127
|
|
|
|
, cast @Int8 @Integer (-128) ~?= -128
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Int8 Word8" ~:
|
|
|
|
[ tryCast @Int8 @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Int8 @Word8 127 ~?= Right 127
|
|
|
|
, tryCast @Int8 @Word8 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int8 Word16" ~:
|
|
|
|
[ tryCast @Int8 @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Int8 @Word16 127 ~?= Right 127
|
|
|
|
, tryCast @Int8 @Word16 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int8 Word32" ~:
|
|
|
|
[ tryCast @Int8 @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Int8 @Word32 127 ~?= Right 127
|
|
|
|
, tryCast @Int8 @Word32 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int8 Word64" ~:
|
|
|
|
[ tryCast @Int8 @Word64 0 ~?= Right 0
|
|
|
|
, tryCast @Int8 @Word64 127 ~?= Right 127
|
|
|
|
, tryCast @Int8 @Word64 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int8 Word" ~:
|
|
|
|
[ tryCast @Int8 @Word 0 ~?= Right 0
|
|
|
|
, tryCast @Int8 @Word 127 ~?= Right 127
|
|
|
|
, tryCast @Int8 @Word (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int8 Natural" ~:
|
|
|
|
[ tryCast @Int8 @Natural 0 ~?= Right 0
|
|
|
|
, tryCast @Int8 @Natural 127 ~?= Right 127
|
|
|
|
, tryCast @Int8 @Natural (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Int16
|
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
, "TryCast Int16 Int8" ~:
|
|
|
|
[ tryCast @Int16 @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Int16 @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Int16 @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
, tryCast @Int16 @Int8 (-128) ~?= Right (-128)
|
|
|
|
, tryCast @Int16 @Int8 (-129) ~?= Left (TryCastException $ -129)
|
|
|
|
]
|
|
|
|
, "Cast Int16 Int32" ~:
|
|
|
|
[ cast @Int16 @Int32 0 ~?= 0
|
|
|
|
, cast @Int16 @Int32 32767 ~?= 32767
|
|
|
|
, cast @Int16 @Int32 (-32768) ~?= -32768
|
|
|
|
]
|
|
|
|
, "Cast Int16 Int64" ~:
|
|
|
|
[ cast @Int16 @Int64 0 ~?= 0
|
|
|
|
, cast @Int16 @Int64 32767 ~?= 32767
|
|
|
|
, cast @Int16 @Int64 (-32768) ~?= -32768
|
|
|
|
]
|
|
|
|
, "Cast Int16 Int" ~:
|
|
|
|
[ cast @Int16 @Int 0 ~?= 0
|
|
|
|
, cast @Int16 @Int 32767 ~?= 32767
|
|
|
|
, cast @Int16 @Int (-32768) ~?= -32768
|
|
|
|
]
|
|
|
|
, "Cast Int16 Integer" ~:
|
|
|
|
[ cast @Int16 @Integer 0 ~?= 0
|
|
|
|
, cast @Int16 @Integer 32767 ~?= 32767
|
|
|
|
, cast @Int16 @Integer (-32768) ~?= -32768
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Int16 Word8" ~:
|
|
|
|
[ tryCast @Int16 @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Int16 @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Int16 @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
, tryCast @Int16 @Word8 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int16 Word16" ~:
|
|
|
|
[ tryCast @Int16 @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Int16 @Word16 127 ~?= Right 127
|
|
|
|
, tryCast @Int16 @Word16 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int16 Word32" ~:
|
|
|
|
[ tryCast @Int16 @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Int16 @Word32 32767 ~?= Right 32767
|
|
|
|
, tryCast @Int16 @Word32 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int16 Word64" ~:
|
|
|
|
[ tryCast @Int16 @Word64 0 ~?= Right 0
|
|
|
|
, tryCast @Int16 @Word64 32767 ~?= Right 32767
|
|
|
|
, tryCast @Int16 @Word64 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int16 Word" ~:
|
|
|
|
[ tryCast @Int16 @Word 0 ~?= Right 0
|
|
|
|
, tryCast @Int16 @Word 32767 ~?= Right 32767
|
|
|
|
, tryCast @Int16 @Word (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int16 Natural" ~:
|
|
|
|
[ tryCast @Int16 @Natural 0 ~?= Right 0
|
|
|
|
, tryCast @Int16 @Natural 32767 ~?= Right 32767
|
|
|
|
, tryCast @Int16 @Natural (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Int32
|
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
, "TryCast Int32 Int8" ~:
|
|
|
|
[ tryCast @Int32 @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Int32 @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
, tryCast @Int32 @Int8 (-128) ~?= Right (-128)
|
|
|
|
, tryCast @Int32 @Int8 (-129) ~?= Left (TryCastException $ -129)
|
|
|
|
]
|
|
|
|
, "TryCast Int32 Int16" ~:
|
|
|
|
[ tryCast @Int32 @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Int32 @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
, tryCast @Int32 @Int16 (-32768) ~?= Right (-32768)
|
|
|
|
, tryCast @Int32 @Int16 (-32769) ~?= Left (TryCastException $ -32769)
|
|
|
|
]
|
|
|
|
, "Cast Int32 Int64" ~:
|
|
|
|
[ cast @Int32 @Int64 0 ~?= 0
|
|
|
|
, cast @Int32 @Int64 2147483647 ~?= 2147483647
|
|
|
|
, cast @Int32 @Int64 (-2147483648) ~?= -2147483648
|
|
|
|
]
|
|
|
|
, "TryCast Int32 Int" ~:
|
2021-04-11 21:06:17 +03:00
|
|
|
if toInteger (maxBound :: Int) < 2147483647 then untested else
|
2021-04-10 20:34:26 +03:00
|
|
|
[ tryCast @Int32 @Int 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Int 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Int32 @Int (-2147483648) ~?= Right (-2147483648)
|
|
|
|
]
|
|
|
|
, "Cast Int32 Integer" ~:
|
|
|
|
[ cast @Int32 @Integer 0 ~?= 0
|
|
|
|
, cast @Int32 @Integer 2147483647 ~?= 2147483647
|
|
|
|
, cast @Int32 @Integer (-2147483648) ~?= -2147483648
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Int32 Word8" ~:
|
|
|
|
[ tryCast @Int32 @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Int32 @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
, tryCast @Int32 @Word8 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int32 Word16" ~:
|
|
|
|
[ tryCast @Int32 @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Word16 65535 ~?= Right 65535
|
|
|
|
, tryCast @Int32 @Word16 65536 ~?= Left (TryCastException 65536)
|
|
|
|
, tryCast @Int32 @Word16 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int32 Word32" ~:
|
|
|
|
[ tryCast @Int32 @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Word32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Int32 @Word32 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int32 Word64" ~:
|
|
|
|
[ tryCast @Int32 @Word64 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Word64 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Int32 @Word64 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int32 Word" ~:
|
|
|
|
if toInteger (maxBound :: Word) < 2147483647 then untested else
|
|
|
|
[ tryCast @Int32 @Word 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Word 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Int32 @Word (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int32 Natural" ~:
|
|
|
|
[ tryCast @Int32 @Natural 0 ~?= Right 0
|
|
|
|
, tryCast @Int32 @Natural 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Int32 @Natural (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Int64
|
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
, "TryCast Int64 Int8" ~:
|
|
|
|
[ tryCast @Int64 @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Int64 @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
, tryCast @Int64 @Int8 (-128) ~?= Right (-128)
|
|
|
|
, tryCast @Int64 @Int8 (-129) ~?= Left (TryCastException $ -129)
|
|
|
|
]
|
|
|
|
, "TryCast Int64 Int16" ~:
|
|
|
|
[ tryCast @Int64 @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Int64 @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
, tryCast @Int64 @Int16 (-32768) ~?= Right (-32768)
|
|
|
|
, tryCast @Int64 @Int16 (-32769) ~?= Left (TryCastException $ -32769)
|
|
|
|
]
|
|
|
|
, "TryCast Int64 Int32" ~:
|
|
|
|
[ tryCast @Int64 @Int32 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Int32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Int64 @Int32 2147483648 ~?= Left (TryCastException 2147483648)
|
|
|
|
, tryCast @Int64 @Int32 (-2147483648) ~?= Right (-2147483648)
|
|
|
|
, tryCast @Int64 @Int32 (-2147483649) ~?= Left (TryCastException $ -2147483649)
|
|
|
|
]
|
|
|
|
, "TryCast Int64 Int" ~:
|
2021-04-11 21:06:17 +03:00
|
|
|
if toInteger (maxBound :: Int) < 9223372036854775807 then untested else
|
2021-04-10 20:34:26 +03:00
|
|
|
[ tryCast @Int64 @Int 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Int 9223372036854775807 ~?= Right 9223372036854775807
|
|
|
|
, tryCast @Int64 @Int (-9223372036854775808) ~?= Right (-9223372036854775808)
|
|
|
|
]
|
|
|
|
, "Cast Int64 Integer" ~:
|
|
|
|
[ cast @Int64 @Integer 0 ~?= 0
|
|
|
|
, cast @Int64 @Integer 9223372036854775807 ~?= 9223372036854775807
|
|
|
|
, cast @Int64 @Integer (-9223372036854775808) ~?= -9223372036854775808
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Int64 Word8" ~:
|
|
|
|
[ tryCast @Int64 @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Int64 @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
, tryCast @Int64 @Word8 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int64 Word16" ~:
|
|
|
|
[ tryCast @Int64 @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Word16 65535 ~?= Right 65535
|
|
|
|
, tryCast @Int64 @Word16 65536 ~?= Left (TryCastException 65536)
|
|
|
|
, tryCast @Int64 @Word16 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int64 Word32" ~:
|
|
|
|
[ tryCast @Int64 @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Word32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Int64 @Word32 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int64 Word64" ~:
|
|
|
|
[ tryCast @Int64 @Word64 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Word64 9223372036854775807 ~?= Right 9223372036854775807
|
|
|
|
, tryCast @Int64 @Word64 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int64 Word" ~:
|
|
|
|
if toInteger (maxBound :: Word) < 9223372036854775807 then untested else
|
|
|
|
[ tryCast @Int64 @Word 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Word 9223372036854775807 ~?= Right 9223372036854775807
|
|
|
|
, tryCast @Int64 @Word (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int64 Natural" ~:
|
|
|
|
[ tryCast @Int64 @Natural 0 ~?= Right 0
|
|
|
|
, tryCast @Int64 @Natural 9223372036854775807 ~?= Right 9223372036854775807
|
|
|
|
, tryCast @Int64 @Natural (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Int
|
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
, "TryCast Int Int8" ~:
|
|
|
|
[ tryCast @Int @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Int @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
, tryCast @Int @Int8 (-128) ~?= Right (-128)
|
|
|
|
, tryCast @Int @Int8 (-129) ~?= Left (TryCastException $ -129)
|
|
|
|
]
|
|
|
|
, "TryCast Int Int16" ~:
|
|
|
|
[ tryCast @Int @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Int @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
, tryCast @Int @Int16 (-32768) ~?= Right (-32768)
|
|
|
|
, tryCast @Int @Int16 (-32769) ~?= Left (TryCastException $ -32769)
|
|
|
|
]
|
|
|
|
, "TryCast Int Int32" ~:
|
2021-04-11 21:06:17 +03:00
|
|
|
if toInteger (maxBound :: Int) < 2147483647 then untested else
|
2021-04-10 20:34:26 +03:00
|
|
|
[ tryCast @Int @Int32 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Int32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Int @Int32 2147483648 ~?= Left (TryCastException 2147483648)
|
|
|
|
, tryCast @Int @Int32 (-2147483648) ~?= Right (-2147483648)
|
|
|
|
, tryCast @Int @Int32 (-2147483649) ~?= Left (TryCastException $ -2147483649)
|
|
|
|
]
|
|
|
|
, "Cast Int Int64" ~:
|
|
|
|
[ cast @Int @Int64 0 ~?= 0
|
|
|
|
, cast @Int @Int64 maxBound ~?= fromIntegral (maxBound :: Int)
|
|
|
|
, cast @Int @Int64 minBound ~?= fromIntegral (minBound :: Int)
|
|
|
|
]
|
|
|
|
, "Cast Int Integer" ~:
|
|
|
|
[ cast @Int @Integer 0 ~?= 0
|
|
|
|
, cast @Int @Integer maxBound ~?= fromIntegral (maxBound :: Int)
|
|
|
|
, cast @Int @Integer minBound ~?= fromIntegral (minBound :: Int)
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Int Word8" ~:
|
|
|
|
[ tryCast @Int @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Int @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
, tryCast @Int @Word8 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int Word16" ~:
|
|
|
|
[ tryCast @Int @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Word16 65535 ~?= Right 65535
|
|
|
|
, tryCast @Int @Word16 65536 ~?= Left (TryCastException 65536)
|
|
|
|
, tryCast @Int @Word16 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int Word32" ~:
|
|
|
|
if toInteger (maxBound :: Int) < 4294967295 then untested else
|
|
|
|
[ tryCast @Int @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Word32 4294967295 ~?= Right 4294967295
|
|
|
|
, tryCast @Int @Word32 4294967296 ~?= Left (TryCastException 4294967296)
|
|
|
|
, tryCast @Int @Word32 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int Word64" ~:
|
|
|
|
[ tryCast @Int @Word64 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Word64 maxBound ~?= Right (fromIntegral (maxBound :: Int))
|
|
|
|
, tryCast @Int @Word64 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int Word" ~:
|
|
|
|
[ tryCast @Int @Word 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Word maxBound ~?= Right (fromIntegral (maxBound :: Int))
|
|
|
|
, tryCast @Int @Word (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Int Natural" ~:
|
|
|
|
[ tryCast @Int @Natural 0 ~?= Right 0
|
|
|
|
, tryCast @Int @Natural maxBound ~?= Right (fromIntegral (maxBound :: Int))
|
|
|
|
, tryCast @Int @Natural (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Integer
|
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
, "TryCast Integer Int8" ~:
|
|
|
|
[ tryCast @Integer @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Integer @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
, tryCast @Integer @Int8 (-128) ~?= Right (-128)
|
|
|
|
, tryCast @Integer @Int8 (-129) ~?= Left (TryCastException $ -129)
|
|
|
|
]
|
|
|
|
, "TryCast Integer Int16" ~:
|
|
|
|
[ tryCast @Integer @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Integer @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
, tryCast @Integer @Int16 (-32768) ~?= Right (-32768)
|
|
|
|
, tryCast @Integer @Int16 (-32769) ~?= Left (TryCastException $ -32769)
|
|
|
|
]
|
|
|
|
, "TryCast Integer Int32" ~:
|
|
|
|
[ tryCast @Integer @Int32 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Int32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Integer @Int32 2147483648 ~?= Left (TryCastException 2147483648)
|
|
|
|
, tryCast @Integer @Int32 (-2147483648) ~?= Right (-2147483648)
|
|
|
|
, tryCast @Integer @Int32 (-2147483649) ~?= Left (TryCastException $ -2147483649)
|
|
|
|
]
|
|
|
|
, "TryCast Integer Int64" ~:
|
|
|
|
[ tryCast @Integer @Int64 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Int64 9223372036854775807 ~?= Right 9223372036854775807
|
|
|
|
, tryCast @Integer @Int64 9223372036854775808 ~?= Left (TryCastException 9223372036854775808)
|
|
|
|
, tryCast @Integer @Int64 (-9223372036854775808) ~?= Right (-9223372036854775808)
|
|
|
|
, tryCast @Integer @Int64 (-9223372036854775809) ~?= Left (TryCastException $ -9223372036854775809)
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
, "TryCast Integer Int" ~:
|
|
|
|
[ tryCast @Integer @Int 0 ~?= Right 0
|
|
|
|
, let x = maxBound :: Int
|
|
|
|
in tryCast @Integer @Int (fromIntegral x) ~?= Right x
|
|
|
|
, let x = toInteger (maxBound :: Int) + 1
|
|
|
|
in tryCast @Integer @Int x ~?= Left (TryCastException x)
|
|
|
|
, let x = minBound :: Int
|
|
|
|
in tryCast @Integer @Int (fromIntegral x) ~?= Right x
|
|
|
|
, let x = toInteger (minBound :: Int) - 1
|
|
|
|
in tryCast @Integer @Int x ~?= Left (TryCastException x)
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Integer Word8" ~:
|
|
|
|
[ tryCast @Integer @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Integer @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
, tryCast @Integer @Word8 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Integer Word16" ~:
|
|
|
|
[ tryCast @Integer @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Word16 65535 ~?= Right 65535
|
|
|
|
, tryCast @Integer @Word16 65536 ~?= Left (TryCastException 65536)
|
|
|
|
, tryCast @Integer @Word16 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Integer Word32" ~:
|
|
|
|
[ tryCast @Integer @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Word32 4294967295 ~?= Right 4294967295
|
|
|
|
, tryCast @Integer @Word32 4294967296 ~?= Left (TryCastException 4294967296)
|
|
|
|
, tryCast @Integer @Word32 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Integer Word64" ~:
|
|
|
|
[ tryCast @Integer @Word64 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Word64 18446744073709551615 ~?= Right 18446744073709551615
|
|
|
|
, tryCast @Integer @Word64 18446744073709551616 ~?= Left (TryCastException 18446744073709551616)
|
|
|
|
, tryCast @Integer @Word64 (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Integer Word" ~:
|
|
|
|
[ tryCast @Integer @Word 0 ~?= Right 0
|
|
|
|
, let x = maxBound :: Word
|
|
|
|
in tryCast @Integer @Word (fromIntegral x) ~?= Right x
|
|
|
|
, let x = toInteger (maxBound :: Word) + 1
|
|
|
|
in tryCast @Integer @Word x ~?= Left (TryCastException x)
|
|
|
|
, tryCast @Integer @Word (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
|
|
|
, "TryCast Integer Natural" ~:
|
|
|
|
[ tryCast @Integer @Natural 0 ~?= Right 0
|
|
|
|
, tryCast @Integer @Natural 18446744073709551616 ~?= Right 18446744073709551616
|
|
|
|
, tryCast @Integer @Natural (-1) ~?= Left (TryCastException $ -1)
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Word8
|
|
|
|
|
|
|
|
, "Cast Word8 Word16" ~:
|
|
|
|
[ cast @Word8 @Word16 0 ~?= 0
|
|
|
|
, cast @Word8 @Word16 255 ~?= 255
|
|
|
|
]
|
|
|
|
, "Cast Word8 Word32" ~:
|
|
|
|
[ cast @Word8 @Word32 0 ~?= 0
|
|
|
|
, cast @Word8 @Word32 255 ~?= 255
|
|
|
|
]
|
|
|
|
, "Cast Word8 Word64" ~:
|
|
|
|
[ cast @Word8 @Word64 0 ~?= 0
|
|
|
|
, cast @Word8 @Word64 255 ~?= 255
|
|
|
|
]
|
|
|
|
, "Cast Word8 Word" ~:
|
|
|
|
[ cast @Word8 @Word 0 ~?= 0
|
|
|
|
, cast @Word8 @Word 255 ~?= 255
|
|
|
|
]
|
|
|
|
, "Cast Word8 Natural" ~:
|
|
|
|
[ cast @Word8 @Natural 0 ~?= 0
|
|
|
|
, cast @Word8 @Natural 255 ~?= 255
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Word8 Int8" ~:
|
|
|
|
[ tryCast @Word8 @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Word8 @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Word8 @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
]
|
|
|
|
, "Cast Word8 Int16" ~:
|
|
|
|
[ cast @Word8 @Int16 0 ~?= 0
|
|
|
|
, cast @Word8 @Int16 255 ~?= 255
|
|
|
|
]
|
|
|
|
, "Cast Word8 Int32" ~:
|
|
|
|
[ cast @Word8 @Int32 0 ~?= 0
|
|
|
|
, cast @Word8 @Int32 255 ~?= 255
|
|
|
|
]
|
|
|
|
, "Cast Word8 Int64" ~:
|
|
|
|
[ cast @Word8 @Int64 0 ~?= 0
|
|
|
|
, cast @Word8 @Int64 255 ~?= 255
|
|
|
|
]
|
|
|
|
, "Cast Word8 Int" ~:
|
|
|
|
[ cast @Word8 @Int 0 ~?= 0
|
|
|
|
, cast @Word8 @Int 255 ~?= 255
|
|
|
|
]
|
|
|
|
, "Cast Word8 Integer" ~:
|
|
|
|
[ cast @Word8 @Integer 0 ~?= 0
|
|
|
|
, cast @Word8 @Integer 255 ~?= 255
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Word16
|
|
|
|
|
|
|
|
, "TryCast Word16 Word8" ~:
|
|
|
|
[ tryCast @Word16 @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Word16 @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Word16 @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
]
|
|
|
|
, "Cast Word16 Word32" ~:
|
|
|
|
[ cast @Word16 @Word32 0 ~?= 0
|
|
|
|
, cast @Word16 @Word32 65535 ~?= 65535
|
|
|
|
]
|
|
|
|
, "Cast Word16 Word64" ~:
|
|
|
|
[ cast @Word16 @Word64 0 ~?= 0
|
|
|
|
, cast @Word16 @Word64 65535 ~?= 65535
|
|
|
|
]
|
|
|
|
, "Cast Word16 Word" ~:
|
|
|
|
[ cast @Word16 @Word 0 ~?= 0
|
|
|
|
, cast @Word16 @Word 65535 ~?= 65535
|
|
|
|
]
|
|
|
|
, "Cast Word16 Natural" ~:
|
|
|
|
[ cast @Word16 @Natural 0 ~?= 0
|
|
|
|
, cast @Word16 @Natural 65535 ~?= 65535
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Word16 Int8" ~:
|
|
|
|
[ tryCast @Word16 @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Word16 @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Word16 @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
]
|
|
|
|
, "TryCast Word16 Int16" ~:
|
|
|
|
[ tryCast @Word16 @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Word16 @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Word16 @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
]
|
|
|
|
, "Cast Word16 Int32" ~:
|
|
|
|
[ cast @Word16 @Int32 0 ~?= 0
|
|
|
|
, cast @Word16 @Int32 65535 ~?= 65535
|
|
|
|
]
|
|
|
|
, "Cast Word16 Int64" ~:
|
|
|
|
[ cast @Word16 @Int64 0 ~?= 0
|
|
|
|
, cast @Word16 @Int64 65535 ~?= 65535
|
|
|
|
]
|
|
|
|
, "Cast Word16 Int" ~:
|
|
|
|
[ cast @Word16 @Int 0 ~?= 0
|
|
|
|
, cast @Word16 @Int 65535 ~?= 65535
|
|
|
|
]
|
|
|
|
, "Cast Word16 Integer" ~:
|
|
|
|
[ cast @Word16 @Integer 0 ~?= 0
|
|
|
|
, cast @Word16 @Integer 65535 ~?= 65535
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Word32
|
|
|
|
|
|
|
|
, "TryCast Word32 Word8" ~:
|
|
|
|
[ tryCast @Word32 @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Word32 @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Word32 @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
]
|
|
|
|
, "TryCast Word32 Word16" ~:
|
|
|
|
[ tryCast @Word32 @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Word32 @Word16 65535 ~?= Right 65535
|
|
|
|
, tryCast @Word32 @Word16 65536 ~?= Left (TryCastException 65536)
|
|
|
|
]
|
|
|
|
, "Cast Word32 Word64" ~:
|
|
|
|
[ cast @Word32 @Word64 0 ~?= 0
|
|
|
|
, cast @Word32 @Word64 4294967295 ~?= 4294967295
|
|
|
|
]
|
|
|
|
, "TryCast Word32 Word" ~:
|
2021-04-11 21:06:17 +03:00
|
|
|
if toInteger (maxBound :: Word) < 4294967295 then untested else
|
2021-04-11 17:04:53 +03:00
|
|
|
[ tryCast @Word32 @Word 0 ~?= Right 0
|
|
|
|
, tryCast @Word32 @Word 4294967295 ~?= Right 4294967295
|
|
|
|
]
|
|
|
|
, "Cast Word32 Natural" ~:
|
|
|
|
[ cast @Word32 @Natural 0 ~?= 0
|
|
|
|
, cast @Word32 @Natural 4294967295 ~?= 4294967295
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Word32 Int8" ~:
|
|
|
|
[ tryCast @Word32 @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Word32 @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Word32 @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
]
|
|
|
|
, "TryCast Word32 Int16" ~:
|
|
|
|
[ tryCast @Word32 @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Word32 @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Word32 @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
]
|
|
|
|
, "TryCast Word32 Int32" ~:
|
|
|
|
[ tryCast @Word32 @Int32 0 ~?= Right 0
|
|
|
|
, tryCast @Word32 @Int32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Word32 @Int32 2147483648 ~?= Left (TryCastException 2147483648)
|
|
|
|
]
|
|
|
|
, "Cast Word32 Int64" ~:
|
|
|
|
[ cast @Word32 @Int64 0 ~?= 0
|
|
|
|
, cast @Word32 @Int64 4294967295 ~?= 4294967295
|
|
|
|
]
|
|
|
|
, "TryCast Word32 Int" ~:
|
|
|
|
if toInteger (maxBound :: Int) < 4294967295 then untested else
|
|
|
|
[ tryCast @Word32 @Int 0 ~?= Right 0
|
|
|
|
, tryCast @Word32 @Int 4294967295 ~?= Right 4294967295
|
|
|
|
]
|
|
|
|
, "Cast Word32 Integer" ~:
|
|
|
|
[ cast @Word32 @Integer 0 ~?= 0
|
|
|
|
, cast @Word32 @Integer 4294967295 ~?= 4294967295
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Word64
|
|
|
|
|
|
|
|
, "TryCast Word64 Word8" ~:
|
|
|
|
[ tryCast @Word64 @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Word64 @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Word64 @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
]
|
|
|
|
, "TryCast Word64 Word16" ~:
|
|
|
|
[ tryCast @Word64 @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Word64 @Word16 65535 ~?= Right 65535
|
|
|
|
, tryCast @Word64 @Word16 65536 ~?= Left (TryCastException 65536)
|
|
|
|
]
|
|
|
|
, "TryCast Word64 Word32" ~:
|
|
|
|
[ tryCast @Word64 @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Word64 @Word32 4294967295 ~?= Right 4294967295
|
|
|
|
, tryCast @Word64 @Word32 4294967296 ~?= Left (TryCastException 4294967296)
|
|
|
|
]
|
|
|
|
, "TryCast Word64 Word" ~:
|
2021-04-11 21:06:17 +03:00
|
|
|
if toInteger (maxBound :: Word) < 18446744073709551615 then untested else
|
2021-04-11 17:04:53 +03:00
|
|
|
[ tryCast @Word64 @Word 0 ~?= Right 0
|
|
|
|
, tryCast @Word64 @Word 18446744073709551615 ~?= Right 18446744073709551615
|
|
|
|
]
|
|
|
|
, "Cast Word64 Natural" ~:
|
|
|
|
[ cast @Word64 @Natural 0 ~?= 0
|
|
|
|
, cast @Word64 @Natural 18446744073709551615 ~?= 18446744073709551615
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Word64 Int8" ~:
|
|
|
|
[ tryCast @Word64 @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Word64 @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Word64 @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
]
|
|
|
|
, "TryCast Word64 Int16" ~:
|
|
|
|
[ tryCast @Word64 @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Word64 @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Word64 @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
]
|
|
|
|
, "TryCast Word64 Int32" ~:
|
|
|
|
[ tryCast @Word64 @Int32 0 ~?= Right 0
|
|
|
|
, tryCast @Word64 @Int32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Word64 @Int32 2147483648 ~?= Left (TryCastException 2147483648)
|
|
|
|
]
|
|
|
|
, "TryCast Word64 Int64" ~:
|
|
|
|
[ tryCast @Word64 @Int64 0 ~?= Right 0
|
|
|
|
, tryCast @Word64 @Int64 9223372036854775807 ~?= Right 9223372036854775807
|
|
|
|
, tryCast @Word64 @Int32 9223372036854775808 ~?= Left (TryCastException 9223372036854775808)
|
|
|
|
]
|
|
|
|
, "TryCast Word64 Int" ~:
|
|
|
|
[ tryCast @Word64 @Int 0 ~?= Right 0
|
|
|
|
, let x = maxBound :: Int
|
|
|
|
in tryCast @Word64 @Int (fromIntegral x) ~?= Right x
|
|
|
|
, let x = fromIntegral (maxBound :: Int) + 1 :: Word64
|
|
|
|
in tryCast @Word64 @Int x ~?= Left (TryCastException x)
|
|
|
|
]
|
|
|
|
, "Cast Word64 Integer" ~:
|
|
|
|
[ cast @Word64 @Integer 0 ~?= 0
|
|
|
|
, cast @Word64 @Integer 18446744073709551615 ~?= 18446744073709551615
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Word
|
|
|
|
|
|
|
|
, "TryCast Word Word8" ~:
|
|
|
|
[ tryCast @Word @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Word @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Word @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
]
|
|
|
|
, "TryCast Word Word16" ~:
|
|
|
|
[ tryCast @Word @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Word @Word16 65535 ~?= Right 65535
|
|
|
|
, tryCast @Word @Word16 65536 ~?= Left (TryCastException 65536)
|
|
|
|
]
|
|
|
|
, "TryCast Word Word32" ~:
|
2021-04-11 21:06:17 +03:00
|
|
|
if toInteger (maxBound :: Word) < 4294967295 then untested else
|
2021-04-11 17:04:53 +03:00
|
|
|
[ tryCast @Word @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Word @Word32 4294967295 ~?= Right 4294967295
|
|
|
|
, tryCast @Word @Word32 4294967296 ~?= Left (TryCastException 4294967296)
|
|
|
|
]
|
|
|
|
, "Cast Word Word64" ~:
|
|
|
|
[ cast @Word @Word64 0 ~?= 0
|
|
|
|
, cast @Word @Word64 maxBound ~?= fromIntegral (maxBound :: Word)
|
|
|
|
]
|
|
|
|
, "Cast Word Natural" ~:
|
|
|
|
[ cast @Word @Natural 0 ~?= 0
|
|
|
|
, cast @Word @Natural maxBound ~?= fromIntegral (maxBound :: Word)
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Word Int8" ~:
|
|
|
|
[ tryCast @Word @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Word @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Word @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
]
|
|
|
|
, "TryCast Word Int16" ~:
|
|
|
|
[ tryCast @Word @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Word @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Word @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
]
|
|
|
|
, "TryCast Word Int32" ~:
|
|
|
|
if toInteger (maxBound :: Word) < 2147483647 then untested else
|
|
|
|
[ tryCast @Word @Int32 0 ~?= Right 0
|
|
|
|
, tryCast @Word @Int32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Word @Int32 2147483648 ~?= Left (TryCastException 2147483648)
|
|
|
|
]
|
|
|
|
, "TryCast Word Int64" ~:
|
|
|
|
if toInteger (maxBound :: Word) < 9223372036854775807 then untested else
|
|
|
|
[ tryCast @Word @Int64 0 ~?= Right 0
|
|
|
|
, tryCast @Word @Int64 9223372036854775807 ~?= Right 9223372036854775807
|
|
|
|
, tryCast @Word @Int32 9223372036854775808 ~?= Left (TryCastException 9223372036854775808)
|
|
|
|
]
|
|
|
|
, "TryCast Word Int" ~:
|
|
|
|
[ tryCast @Word @Int 0 ~?= Right 0
|
|
|
|
, let x = maxBound :: Int
|
|
|
|
in tryCast @Word @Int (fromIntegral x) ~?= Right x
|
|
|
|
, let x = fromIntegral (maxBound :: Int) + 1 :: Word
|
|
|
|
in tryCast @Word @Int x ~?= Left (TryCastException x)
|
|
|
|
]
|
|
|
|
, "Cast Word Integer" ~:
|
|
|
|
[ cast @Word @Integer 0 ~?= 0
|
|
|
|
, cast @Word @Integer maxBound ~?= fromIntegral (maxBound :: Word)
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
|
|
|
-- Natural
|
|
|
|
|
|
|
|
, "TryCast Natural Word8" ~:
|
|
|
|
[ tryCast @Natural @Word8 0 ~?= Right 0
|
|
|
|
, tryCast @Natural @Word8 255 ~?= Right 255
|
|
|
|
, tryCast @Natural @Word8 256 ~?= Left (TryCastException 256)
|
|
|
|
]
|
|
|
|
, "TryCast Natural Word16" ~:
|
|
|
|
[ tryCast @Natural @Word16 0 ~?= Right 0
|
|
|
|
, tryCast @Natural @Word16 65535 ~?= Right 65535
|
|
|
|
, tryCast @Natural @Word16 65536 ~?= Left (TryCastException 65536)
|
|
|
|
]
|
|
|
|
, "TryCast Natural Word32" ~:
|
|
|
|
[ tryCast @Natural @Word32 0 ~?= Right 0
|
|
|
|
, tryCast @Natural @Word32 4294967295 ~?= Right 4294967295
|
|
|
|
, tryCast @Natural @Word32 4294967296 ~?= Left (TryCastException 4294967296)
|
|
|
|
]
|
|
|
|
, "TryCast Natural Word64" ~:
|
|
|
|
[ tryCast @Natural @Word64 0 ~?= Right 0
|
|
|
|
, tryCast @Natural @Word64 18446744073709551615 ~?= Right 18446744073709551615
|
|
|
|
, tryCast @Natural @Word64 18446744073709551616 ~?= Left (TryCastException 18446744073709551616)
|
|
|
|
]
|
|
|
|
, "TryCast Natural Word" ~:
|
|
|
|
[ tryCast @Natural @Word 0 ~?= Right 0
|
|
|
|
, let x = maxBound :: Word
|
|
|
|
in tryCast @Natural @Word (fromIntegral x) ~?= Right x
|
|
|
|
, let x = fromIntegral (maxBound :: Word) + 1 :: Natural
|
|
|
|
in tryCast @Natural @Word x ~?= Left (TryCastException x)
|
|
|
|
]
|
2021-04-11 21:06:17 +03:00
|
|
|
, "TryCast Natural Int8" ~:
|
|
|
|
[ tryCast @Natural @Int8 0 ~?= Right 0
|
|
|
|
, tryCast @Natural @Int8 127 ~?= Right 127
|
|
|
|
, tryCast @Natural @Int8 128 ~?= Left (TryCastException 128)
|
|
|
|
]
|
|
|
|
, "TryCast Natural Int16" ~:
|
|
|
|
[ tryCast @Natural @Int16 0 ~?= Right 0
|
|
|
|
, tryCast @Natural @Int16 32767 ~?= Right 32767
|
|
|
|
, tryCast @Natural @Int16 32768 ~?= Left (TryCastException 32768)
|
|
|
|
]
|
|
|
|
, "TryCast Natural Int32" ~:
|
|
|
|
[ tryCast @Natural @Int32 0 ~?= Right 0
|
|
|
|
, tryCast @Natural @Int32 2147483647 ~?= Right 2147483647
|
|
|
|
, tryCast @Natural @Int32 2147483648 ~?= Left (TryCastException 2147483648)
|
|
|
|
]
|
|
|
|
, "TryCast Natural Int64" ~:
|
|
|
|
[ tryCast @Natural @Int64 0 ~?= Right 0
|
|
|
|
, tryCast @Natural @Int64 9223372036854775807 ~?= Right 9223372036854775807
|
|
|
|
, tryCast @Natural @Int32 9223372036854775808 ~?= Left (TryCastException 9223372036854775808)
|
|
|
|
]
|
|
|
|
, "TryCast Natural Int" ~:
|
|
|
|
[ tryCast @Natural @Int 0 ~?= Right 0
|
|
|
|
, let x = maxBound :: Int
|
|
|
|
in tryCast @Natural @Int (fromIntegral x) ~?= Right x
|
|
|
|
, let x = fromIntegral (maxBound :: Int) + 1 :: Natural
|
|
|
|
in tryCast @Natural @Int x ~?= Left (TryCastException x)
|
|
|
|
]
|
|
|
|
, "Cast Natural Integer" ~:
|
|
|
|
[ cast @Natural @Integer 0 ~?= 0
|
|
|
|
, cast @Natural @Integer 9223372036854775808 ~?= 9223372036854775808
|
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
2021-04-10 20:34:26 +03:00
|
|
|
]
|
2021-04-11 17:04:53 +03:00
|
|
|
|
2021-04-11 21:06:17 +03:00
|
|
|
untested :: [Test]
|
|
|
|
untested = [False ~? "untested"]
|
|
|
|
|
2021-04-11 17:04:53 +03:00
|
|
|
newtype Name
|
|
|
|
= Name String
|
|
|
|
deriving (Eq, Show)
|
|
|
|
|
|
|
|
instance Cast Name String
|
|
|
|
|
|
|
|
instance Cast String Name
|