Fix Integer FromText instance.
And add FromText/ToText tests.
This commit is contained in:
parent
5f1e8c3607
commit
5be2430b11
4 changed files with 72 additions and 13 deletions
|
@ -89,6 +89,7 @@ test-suite spec
|
||||||
, bytestring
|
, bytestring
|
||||||
, hspec == 2.*
|
, hspec == 2.*
|
||||||
, QuickCheck
|
, QuickCheck
|
||||||
|
, quickcheck-instances
|
||||||
, parsec
|
, parsec
|
||||||
, servant
|
, servant
|
||||||
, string-conversions
|
, string-conversions
|
||||||
|
|
|
@ -13,10 +13,14 @@ import Data.Text.Read ( rational, signed, decimal, Reader )
|
||||||
import Data.Word ( Word, Word8, Word16, Word32, Word64 )
|
import Data.Word ( Word, Word8, Word16, Word32, Word64 )
|
||||||
|
|
||||||
-- | For getting values from url captures and query string parameters
|
-- | For getting values from url captures and query string parameters
|
||||||
|
-- Instances should obey:
|
||||||
|
-- > fromText (toText a) == Just a
|
||||||
class FromText a where
|
class FromText a where
|
||||||
fromText :: Text -> Maybe a
|
fromText :: Text -> Maybe a
|
||||||
|
|
||||||
-- | For putting values in paths and query string parameters
|
-- | For putting values in paths and query string parameters
|
||||||
|
-- Instances should obey:
|
||||||
|
-- > fromText (toText a) == Just a
|
||||||
class ToText a where
|
class ToText a where
|
||||||
toText :: a -> Text
|
toText :: a -> Text
|
||||||
|
|
||||||
|
@ -109,7 +113,7 @@ instance ToText Word64 where
|
||||||
toText = cs . show
|
toText = cs . show
|
||||||
|
|
||||||
instance FromText Integer where
|
instance FromText Integer where
|
||||||
fromText = runReader decimal
|
fromText = runReader (signed decimal)
|
||||||
|
|
||||||
instance ToText Integer where
|
instance ToText Integer where
|
||||||
toText = cs . show
|
toText = cs . show
|
||||||
|
|
|
@ -21,6 +21,7 @@ import qualified Data.Text.Lazy as TextL
|
||||||
import GHC.Generics
|
import GHC.Generics
|
||||||
import Test.Hspec
|
import Test.Hspec
|
||||||
import Test.QuickCheck
|
import Test.QuickCheck
|
||||||
|
import Test.QuickCheck.Instances ()
|
||||||
|
|
||||||
import Servant.API.ContentTypes
|
import Servant.API.ContentTypes
|
||||||
|
|
||||||
|
@ -145,12 +146,6 @@ instance ToJSON SomeData
|
||||||
instance Arbitrary SomeData where
|
instance Arbitrary SomeData where
|
||||||
arbitrary = SomeData <$> arbitrary <*> arbitrary
|
arbitrary = SomeData <$> arbitrary <*> arbitrary
|
||||||
|
|
||||||
instance Arbitrary TextL.Text where
|
|
||||||
arbitrary = TextL.pack <$> arbitrary
|
|
||||||
|
|
||||||
instance Arbitrary TextS.Text where
|
|
||||||
arbitrary = TextS.pack <$> arbitrary
|
|
||||||
|
|
||||||
instance Arbitrary ZeroToOne where
|
instance Arbitrary ZeroToOne where
|
||||||
arbitrary = ZeroToOne <$> elements [ x / 10 | x <- [1..10]]
|
arbitrary = ZeroToOne <$> elements [ x / 10 | x <- [1..10]]
|
||||||
|
|
||||||
|
@ -169,12 +164,6 @@ instance ToJSON ByteString where
|
||||||
instance IsString AcceptHeader where
|
instance IsString AcceptHeader where
|
||||||
fromString = AcceptHeader . fromString
|
fromString = AcceptHeader . fromString
|
||||||
|
|
||||||
instance Arbitrary BSL.ByteString where
|
|
||||||
arbitrary = cs <$> (arbitrary :: Gen String)
|
|
||||||
|
|
||||||
instance Arbitrary ByteString where
|
|
||||||
arbitrary = cs <$> (arbitrary :: Gen String)
|
|
||||||
|
|
||||||
addToAccept :: Accept a => Proxy a -> ZeroToOne -> AcceptHeader -> AcceptHeader
|
addToAccept :: Accept a => Proxy a -> ZeroToOne -> AcceptHeader -> AcceptHeader
|
||||||
addToAccept p (ZeroToOne f) (AcceptHeader h) = AcceptHeader (cont h)
|
addToAccept p (ZeroToOne f) (AcceptHeader h) = AcceptHeader (cont h)
|
||||||
where new = cs (show $ contentType p) `append` "; q=" `append` pack (show f)
|
where new = cs (show $ contentType p) `append` "; q=" `append` pack (show f)
|
||||||
|
|
65
test/Servant/Common/TextSpec.hs
Normal file
65
test/Servant/Common/TextSpec.hs
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
module Servant.Common.TextSpec where
|
||||||
|
|
||||||
|
import Servant.Common.Text
|
||||||
|
import Test.Hspec
|
||||||
|
import Test.QuickCheck
|
||||||
|
import Test.QuickCheck.Instances ()
|
||||||
|
import Data.Int ( Int8, Int16, Int32, Int64 )
|
||||||
|
import Data.Text ( Text )
|
||||||
|
import Data.Word ( Word, Word8, Word16, Word32, Word64 )
|
||||||
|
|
||||||
|
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)
|
||||||
|
|
||||||
|
it "holds for Double" $
|
||||||
|
property $ \x -> textLaw (x :: Double)
|
||||||
|
|
||||||
|
it "holds for Float" $
|
||||||
|
property $ \x -> textLaw (x :: Float)
|
||||||
|
|
||||||
|
textLaw :: (FromText a, ToText a, Eq a) => a -> Bool
|
||||||
|
textLaw a = fromText (toText a) == Just a
|
Loading…
Reference in a new issue