73 lines
2.2 KiB
Haskell
73 lines
2.2 KiB
Haskell
module Servant.Common.TextSpec where
|
|
|
|
import Data.Int (Int16, Int32, Int64, Int8)
|
|
import Data.Text (Text)
|
|
import Data.Word (Word, Word16, Word32, Word64, Word8)
|
|
import Servant.Common.Text
|
|
import Test.Hspec
|
|
import Test.QuickCheck
|
|
import Test.QuickCheck.Instances ()
|
|
|
|
spec :: Spec
|
|
spec = describe "Servant.Common.Text" $ do
|
|
|
|
context "FromText and ToText laws" $ do
|
|
|
|
it "holds for Text" $
|
|
property $ \x -> textLaw (x :: Text)
|
|
|
|
it "holds for String" $
|
|
property $ \x -> textLaw (x :: String)
|
|
|
|
it "holds for Bool" $
|
|
property $ \x -> textLaw (x :: Bool)
|
|
|
|
it "holds for Int" $
|
|
property $ \x -> textLaw (x :: Int)
|
|
|
|
it "holds for Int8" $
|
|
property $ \x -> textLaw (x :: Int8)
|
|
|
|
it "holds for Int16" $
|
|
property $ \x -> textLaw (x :: Int16)
|
|
|
|
it "holds for Int32" $
|
|
property $ \x -> textLaw (x :: Int32)
|
|
|
|
it "holds for Int64" $
|
|
property $ \x -> textLaw (x :: Int64)
|
|
|
|
it "holds for Word" $
|
|
property $ \x -> textLaw (x :: Word)
|
|
|
|
it "holds for Word8" $
|
|
property $ \x -> textLaw (x :: Word8)
|
|
|
|
it "holds for Word16" $
|
|
property $ \x -> textLaw (x :: Word16)
|
|
|
|
it "holds for Word32" $
|
|
property $ \x -> textLaw (x :: Word32)
|
|
|
|
it "holds for Word64" $
|
|
property $ \x -> textLaw (x :: Word64)
|
|
|
|
it "holds for Integer" $
|
|
property $ \x -> textLaw (x :: Integer)
|
|
|
|
-- The following two properties are only reasonably expected to hold up
|
|
-- to a certain precision.
|
|
--
|
|
-- http://en.wikipedia.org/wiki/Floating_point#Internal_representation
|
|
it "holds for Double" $
|
|
property $ \x ->
|
|
x < 1.0e15 && x > 1.0e-16 ==>
|
|
textLaw (x :: Double)
|
|
|
|
it "holds for Float" $
|
|
property $ \x ->
|
|
x < 1.0e7 && x > 1.0e-7 ==>
|
|
textLaw (x :: Float)
|
|
|
|
textLaw :: (FromText a, ToText a, Eq a) => a -> Bool
|
|
textLaw a = fromText (toText a) == Just a
|