{-# LANGUAGE OverloadedStrings #-} module Jenkins.Rest.InternalSpec (spec) where import Control.Lens import Control.Exception (throwIO) import Control.Exception.Lens (throwingM, _IOException) import Control.Monad.IO.Class (liftIO) import Network.HTTP.Conduit (HttpException) import Network.HTTP.Types (Status(..)) import Test.Hspec.Lens import System.IO.Error import System.IO.Error.Lens (errorType, _NoSuchThing) import Jenkins.Rest.Internal import Network.HTTP.Conduit.Lens (_StatusCodeException, _TooManyRetries) _JenkinsException :: Iso' JenkinsException HttpException _JenkinsException = iso (\(JenkinsHttpException e) -> e) JenkinsHttpException spec :: Spec spec = do let raiseHttp, raiseIO :: Jenkins a raiseHttp = liftIO (throwingM _TooManyRetries ()) raiseIO = liftIO (throwIO (mkIOError doesNotExistErrorType "foo" Nothing Nothing)) describe "runJenkins" $ do it "wraps uncatched 'HttpException' exceptions from the queries in 'Error'" $ runJenkins (defaultConnectInfo & jenkinsPort .~ 80) (liftJ (Get "hi" id)) `shouldPerform` Status 404 "" `through` _Error._JenkinsException._StatusCodeException._1 it "can catch 'HttpException' exceptions related from the queries" $ runJenkins (defaultConnectInfo & jenkinsPort .~ 80) (liftJ (Or (liftJ (Get "hi" id) >> return 4) (return 7))) `shouldPerform` 7 `through` _Result it "does not catch (and wrap) 'HttpException's not from the queries" $ runJenkins defaultConnectInfo raiseHttp `shouldThrow` _TooManyRetries it "does not catch (and wrap) 'IOException's" $ runJenkins defaultConnectInfo raiseIO `shouldThrow` _IOException.errorType._NoSuchThing