48 lines
1.3 KiB
Haskell
48 lines
1.3 KiB
Haskell
|
{-# LANGUAGE NoImplicitPrelude #-}
|
||
|
{-# LANGUAGE OverloadedStrings #-}
|
||
|
module Handler.CommentSpec (spec) where
|
||
|
|
||
|
import TestImport
|
||
|
import Data.Aeson
|
||
|
|
||
|
spec :: Spec
|
||
|
spec = withApp $ do
|
||
|
describe "valid request" $ do
|
||
|
it "gives a 200" $ do
|
||
|
get HomeR
|
||
|
statusIs 200
|
||
|
|
||
|
let message = "My message" :: Text
|
||
|
body = object [ "message" .= message ]
|
||
|
encoded = encode body
|
||
|
|
||
|
request $ do
|
||
|
setMethod "POST"
|
||
|
setUrl CommentR
|
||
|
setRequestBody encoded
|
||
|
addRequestHeader ("Content-Type", "application/json")
|
||
|
|
||
|
statusIs 200
|
||
|
|
||
|
comments <- runDB $ selectList [CommentMessage ==. message] []
|
||
|
Entity _id comment <-
|
||
|
case comments of
|
||
|
[ent] -> pure ent
|
||
|
_ -> error "needed 1 entity"
|
||
|
assertEq "Should have " comment (Comment message Nothing)
|
||
|
|
||
|
describe "invalid requests" $ do
|
||
|
it "400s when the JSON body is invalid" $ do
|
||
|
get HomeR
|
||
|
|
||
|
let body = object [ "foo" .= ("My message" :: Value) ]
|
||
|
|
||
|
request $ do
|
||
|
setMethod "POST"
|
||
|
setUrl CommentR
|
||
|
setRequestBody $ encode body
|
||
|
addRequestHeader ("Content-Type", "application/json")
|
||
|
|
||
|
statusIs 400
|
||
|
|