Added missing test file
This commit is contained in:
parent
22cd28b8f4
commit
ca49415938
40
yesod-core/test/YesodCoreTest/WaiSubsite.hs
Normal file
40
yesod-core/test/YesodCoreTest/WaiSubsite.hs
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
{-# LANGUAGE QuasiQuotes, TemplateHaskell, TypeFamilies, MultiParamTypeClasses, OverloadedStrings #-}
|
||||||
|
module YesodCoreTest.WaiSubsite (specs, Widget) where
|
||||||
|
|
||||||
|
import YesodCoreTest.YesodTest
|
||||||
|
import Yesod.Core
|
||||||
|
import qualified Network.HTTP.Types as H
|
||||||
|
import Network.Wai
|
||||||
|
|
||||||
|
myApp :: Application
|
||||||
|
myApp _ = return $ responseLBS H.status200 [("Content-type", "text/plain")] "WAI"
|
||||||
|
|
||||||
|
getApp :: a -> WaiSubsite
|
||||||
|
getApp _ = WaiSubsite myApp
|
||||||
|
|
||||||
|
data Y = Y
|
||||||
|
mkYesod "Y" [parseRoutes|
|
||||||
|
/ RootR GET
|
||||||
|
/sub WaiSubsiteR WaiSubsite getApp
|
||||||
|
|]
|
||||||
|
|
||||||
|
instance Yesod Y
|
||||||
|
|
||||||
|
app :: Session () -> IO ()
|
||||||
|
app = yesod Y
|
||||||
|
|
||||||
|
getRootR :: Handler ()
|
||||||
|
getRootR = return ()
|
||||||
|
|
||||||
|
specs :: [Spec]
|
||||||
|
specs = describe "WaiSubsite" [
|
||||||
|
it "root" $ app $ do
|
||||||
|
res <- request defaultRequest { pathInfo = [] }
|
||||||
|
assertStatus 200 res
|
||||||
|
assertBodyContains "" res
|
||||||
|
|
||||||
|
, it "subsite" $ app $ do
|
||||||
|
res <- request defaultRequest { pathInfo = ["sub", "foo"] }
|
||||||
|
assertStatus 200 res
|
||||||
|
assertBodyContains "WAI" res
|
||||||
|
]
|
||||||
Loading…
Reference in New Issue
Block a user