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
|
|
|
|
|
2016-01-10 15:59:33 +01:00
|
|
|
data Tag1
|
|
|
|
data Tag2
|
2016-01-09 17:22:52 +01:00
|
|
|
|
2016-01-10 15:59:33 +01:00
|
|
|
type OneEntryAPI =
|
|
|
|
CustomCombinator Tag1 :> Get '[JSON] String
|
2016-01-09 17:22:52 +01:00
|
|
|
|
2016-01-10 15:59:33 +01:00
|
|
|
testServer :: Server OneEntryAPI
|
2016-01-09 17:22:52 +01:00
|
|
|
testServer (CustomConfig s) = return s
|
|
|
|
|
2016-01-10 15:59:33 +01:00
|
|
|
oneEntryApp :: Application
|
|
|
|
oneEntryApp =
|
|
|
|
serve (Proxy :: Proxy OneEntryAPI) config testServer
|
2016-01-09 17:22:52 +01:00
|
|
|
where
|
2016-01-10 15:59:33 +01:00
|
|
|
config :: Config '[ConfigEntry Tag1 CustomConfig]
|
2016-01-10 15:39:55 +01:00
|
|
|
config = CustomConfig "configValue" .:. EmptyConfig
|
2016-01-09 17:22:52 +01:00
|
|
|
|
2016-01-10 15:59:33 +01:00
|
|
|
type OneEntryTwiceAPI =
|
|
|
|
"foo" :> CustomCombinator Tag1 :> Get '[JSON] String :<|>
|
|
|
|
"bar" :> CustomCombinator Tag1 :> Get '[JSON] String
|
|
|
|
|
|
|
|
oneEntryTwiceApp :: Application
|
|
|
|
oneEntryTwiceApp = serve (Proxy :: Proxy OneEntryTwiceAPI) config $
|
|
|
|
testServer :<|>
|
|
|
|
testServer
|
|
|
|
where
|
|
|
|
config :: Config '[ConfigEntry Tag1 CustomConfig]
|
|
|
|
config = CustomConfig "configValueTwice" .:. EmptyConfig
|
|
|
|
|
|
|
|
type TwoDifferentEntries =
|
|
|
|
"foo" :> CustomCombinator Tag1 :> Get '[JSON] String :<|>
|
|
|
|
"bar" :> CustomCombinator Tag2 :> Get '[JSON] String
|
|
|
|
|
|
|
|
twoDifferentEntries :: Application
|
|
|
|
twoDifferentEntries = serve (Proxy :: Proxy TwoDifferentEntries) config $
|
|
|
|
testServer :<|>
|
|
|
|
testServer
|
|
|
|
where
|
|
|
|
config :: Config '[ConfigEntry Tag1 CustomConfig, ConfigEntry Tag2 CustomConfig]
|
|
|
|
config =
|
|
|
|
CustomConfig "firstConfigValue" .:.
|
|
|
|
CustomConfig "secondConfigValue" .:.
|
|
|
|
EmptyConfig
|
|
|
|
|
2016-01-09 17:22:52 +01:00
|
|
|
-- * tests
|
|
|
|
|
|
|
|
spec :: Spec
|
|
|
|
spec = do
|
|
|
|
describe "using Config in a custom combinator" $ do
|
2016-01-10 15:59:33 +01:00
|
|
|
with (return oneEntryApp) $ do
|
|
|
|
it "allows to retrieve a ConfigEntry" $ do
|
2016-01-09 17:22:52 +01:00
|
|
|
get "/" `shouldRespondWith` "\"configValue\""
|
2016-01-10 15:59:33 +01:00
|
|
|
|
|
|
|
with (return oneEntryTwiceApp) $ do
|
|
|
|
it "allows to retrieve the same ConfigEntry twice" $ do
|
|
|
|
get "/foo" `shouldRespondWith` "\"configValueTwice\""
|
|
|
|
get "/bar" `shouldRespondWith` "\"configValueTwice\""
|
|
|
|
|
|
|
|
with (return twoDifferentEntries) $ do
|
|
|
|
it "allows to retrieve different ConfigEntries for the same combinator" $ do
|
|
|
|
get "/foo" `shouldRespondWith` "\"firstConfigValue\""
|
|
|
|
get "/bar" `shouldRespondWith` "\"secondConfigValue\""
|