git-subtree-dir: yesod-core git-subtree-mainline:cd5ee0fb12git-subtree-split:982d6185be
48 lines
1.2 KiB
Haskell
48 lines
1.2 KiB
Haskell
{-# LANGUAGE QuasiQuotes, TypeFamilies, TemplateHaskell, MultiParamTypeClasses #-}
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
{-# LANGUAGE FlexibleInstances #-}
|
|
module Test.Exceptions (exceptionsTest) where
|
|
|
|
import Yesod.Core hiding (Request)
|
|
import Yesod.Content
|
|
import Yesod.Dispatch
|
|
import Yesod.Handler (Route, ErrorResponse (InternalError))
|
|
|
|
import Test.Framework (defaultMain, testGroup, Test)
|
|
import Test.Framework.Providers.HUnit
|
|
import Test.HUnit hiding (Test)
|
|
import Network.Wai
|
|
import Network.Wai.Test
|
|
|
|
import qualified Data.ByteString.Lazy.Char8 as L8
|
|
|
|
data Y = Y
|
|
mkYesod "Y" [$parseRoutes|
|
|
/ RootR GET
|
|
|]
|
|
|
|
instance Yesod Y where
|
|
approot _ = "http://test"
|
|
errorHandler (InternalError e) = return $ chooseRep $ RepPlain $ toContent e
|
|
errorHandler x = defaultErrorHandler x
|
|
|
|
getRootR = error "FOOBAR" >> return ()
|
|
|
|
exceptionsTest :: Test
|
|
exceptionsTest = testGroup "Test.Exceptions"
|
|
[ testCase "500" case500
|
|
]
|
|
|
|
runner f = toWaiApp Y >>= runSession f
|
|
defaultRequest = Request
|
|
{ pathInfo = []
|
|
, requestHeaders = []
|
|
, queryString = []
|
|
, requestMethod = "GET"
|
|
}
|
|
|
|
case500 = runner $ do
|
|
res <- request defaultRequest
|
|
assertStatus 500 res
|
|
assertBody "FOOBAR" res
|