2016-01-09 17:22:52 +01:00
|
|
|
{-# LANGUAGE DataKinds #-}
|
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
|
|
{-# LANGUAGE TypeOperators #-}
|
|
|
|
|
|
|
|
module Servant.Server.UsingConfigSpec where
|
|
|
|
|
|
|
|
import Network.Wai
|
|
|
|
import Test.Hspec (Spec, describe, it)
|
|
|
|
import Test.Hspec.Wai
|
|
|
|
|
|
|
|
import Servant
|
2016-01-10 15:39:55 +01:00
|
|
|
import Servant.Server.UsingConfigSpec.CustomCombinator
|
2016-01-09 17:22:52 +01:00
|
|
|
|
|
|
|
-- * API
|
|
|
|
|
|
|
|
type API =
|
|
|
|
CustomCombinator :> Get '[JSON] String
|
|
|
|
|
|
|
|
api :: Proxy API
|
|
|
|
api = Proxy
|
|
|
|
|
|
|
|
testServer :: Server API
|
|
|
|
testServer (CustomConfig s) = return s
|
|
|
|
|
|
|
|
app :: Application
|
|
|
|
app =
|
|
|
|
serve api config testServer
|
|
|
|
where
|
|
|
|
config :: Config '[ConfigEntry Tag CustomConfig]
|
2016-01-10 15:39:55 +01:00
|
|
|
config = CustomConfig "configValue" .:. EmptyConfig
|
2016-01-09 17:22:52 +01:00
|
|
|
|
|
|
|
-- * tests
|
|
|
|
|
|
|
|
spec :: Spec
|
|
|
|
spec = do
|
|
|
|
describe "using Config in a custom combinator" $ do
|
|
|
|
with (return app) $ do
|
|
|
|
it "allows to retrieve the ConfigEntry" $ do
|
|
|
|
get "/" `shouldRespondWith` "\"configValue\""
|