diff --git a/servant-client/src/Servant/Common/Req.hs b/servant-client/src/Servant/Common/Req.hs index ffd4569f..d6933e34 100644 --- a/servant-client/src/Servant/Common/Req.hs +++ b/servant-client/src/Servant/Common/Req.hs @@ -53,7 +53,7 @@ data ServantError , responseBody :: ByteString } | ConnectionError - { connectionError :: String + { connectionError :: SomeException } deriving (Show, Typeable) @@ -156,7 +156,7 @@ performRequest reqMethod req isWantedStatus reqHost = do Client.httpLbs request manager case eResponse of Left err -> - left $ ConnectionError (show err) + left . ConnectionError $ SomeException err Right response -> do let status = Client.responseStatus response @@ -192,4 +192,4 @@ performRequestNoBody reqMethod req wantedStatus reqHost = do catchConnectionError :: IO a -> IO (Either ServantError a) catchConnectionError action = catch (Right <$> action) $ \e -> - pure . Left . ConnectionError . show $ (e :: HttpException) + pure . Left . ConnectionError $ SomeException (e :: HttpException) diff --git a/servant-client/test/Servant/ClientSpec.hs b/servant-client/test/Servant/ClientSpec.hs index 763d1397..7685a79c 100644 --- a/servant-client/test/Servant/ClientSpec.hs +++ b/servant-client/test/Servant/ClientSpec.hs @@ -68,11 +68,6 @@ instance FromFormUrlEncoded Person where a <- lookupEither "age" xs return $ Person (T.unpack n) (read $ T.unpack a) -deriving instance Eq ServantError - -instance Eq C.HttpException where - a == b = show a == show b - alice :: Person alice = Person "Alice" 42