47 lines
1.3 KiB
Haskell
47 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
|
|
|