git-subtree-dir: yesod-core git-subtree-mainline:cd5ee0fb12git-subtree-split:982d6185be
79 lines
2.1 KiB
Haskell
79 lines
2.1 KiB
Haskell
{-# LANGUAGE QuasiQuotes, TypeFamilies, TemplateHaskell, MultiParamTypeClasses #-}
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
{-# LANGUAGE FlexibleInstances #-}
|
|
module Test.Widget (widgetTest) where
|
|
|
|
import Yesod.Core hiding (Request)
|
|
import Yesod.Content
|
|
import Yesod.Dispatch
|
|
import Yesod.Widget
|
|
import Text.Julius
|
|
|
|
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
|
|
|
|
mkMessage "Y" "test" "en"
|
|
|
|
mkYesod "Y" [$parseRoutes|
|
|
/ RootR GET
|
|
/foo/*Strings MultiR GET
|
|
/whamlet WhamletR GET
|
|
|]
|
|
|
|
instance Yesod Y where
|
|
approot _ = "http://test"
|
|
|
|
getRootR = defaultLayout $ addJuliusBody [$julius|<not escaped>|]
|
|
getMultiR _ = return ()
|
|
|
|
data Msg = Hello | Goodbye
|
|
instance RenderMessage Y Msg where
|
|
renderMessage _ ("en":_) Hello = "Hello"
|
|
renderMessage _ ("es":_) Hello = "Hola"
|
|
renderMessage _ ("en":_) Goodbye = "Goodbye"
|
|
renderMessage _ ("es":_) Goodbye = "Adios"
|
|
renderMessage a (_:xs) y = renderMessage a xs y
|
|
renderMessage a [] y = renderMessage a ["en"] y
|
|
|
|
getWhamletR = defaultLayout [$whamlet|
|
|
<h1>Test
|
|
<h2>@{WhamletR}
|
|
<h3>_{Goodbye}
|
|
<h3>_{MsgAnother}
|
|
^{embed}
|
|
|]
|
|
where
|
|
embed = [$whamlet|<h4>Embed|]
|
|
|
|
widgetTest :: Test
|
|
widgetTest = testGroup "Test.Widget"
|
|
[ testCase "addJuliusBody" case_addJuliusBody
|
|
, testCase "whamlet" case_whamlet
|
|
]
|
|
|
|
runner f = toWaiApp Y >>= runSession f
|
|
defaultRequest = Request
|
|
{ pathInfo = []
|
|
, requestHeaders = []
|
|
, queryString = []
|
|
, requestMethod = "GET"
|
|
}
|
|
|
|
case_addJuliusBody = runner $ do
|
|
res <- request defaultRequest
|
|
assertBody "<!DOCTYPE html>\n<html><head><title></title></head><body><script><not escaped></script></body></html>" res
|
|
|
|
case_whamlet = runner $ do
|
|
res <- request defaultRequest
|
|
{ pathInfo = ["whamlet"]
|
|
, requestHeaders = [("Accept-Language", "es")]
|
|
}
|
|
assertBody "<!DOCTYPE html>\n<html><head><title></title></head><body><h1>Test</h1><h2>http://test/whamlet</h2><h3>Adios</h3><h3>String</h3><h4>Embed</h4></body></html>" res
|