2014-11-27 18:28:01 +01:00
|
|
|
{-# OPTIONS_GHC -fno-warn-orphans #-}
|
|
|
|
module Servant.Common.BaseUrlSpec where
|
|
|
|
|
2015-08-17 23:56:29 +02:00
|
|
|
import Control.DeepSeq
|
2016-10-15 17:43:21 -04:00
|
|
|
import Prelude ()
|
|
|
|
import Prelude.Compat
|
2015-08-17 23:56:29 +02:00
|
|
|
import Test.Hspec
|
|
|
|
import Test.QuickCheck
|
2014-11-27 18:28:01 +01:00
|
|
|
|
2015-08-17 23:56:29 +02:00
|
|
|
import Servant.Common.BaseUrl
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
spec :: Spec
|
|
|
|
spec = do
|
2015-10-07 18:01:47 +02:00
|
|
|
let parse = parseBaseUrl :: String -> Maybe BaseUrl
|
2014-11-27 18:28:01 +01:00
|
|
|
describe "showBaseUrl" $ do
|
|
|
|
it "shows a BaseUrl" $ do
|
2015-10-05 09:40:53 +02:00
|
|
|
showBaseUrl (BaseUrl Http "foo.com" 80 "") `shouldBe` "http://foo.com"
|
2014-11-27 18:28:01 +01:00
|
|
|
it "shows a https BaseUrl" $ do
|
2015-10-05 09:40:53 +02:00
|
|
|
showBaseUrl (BaseUrl Https "foo.com" 443 "") `shouldBe` "https://foo.com"
|
|
|
|
it "shows the path of a BaseUrl" $ do
|
|
|
|
showBaseUrl (BaseUrl Http "foo.com" 80 "api") `shouldBe` "http://foo.com/api"
|
|
|
|
it "shows the path of an https BaseUrl" $ do
|
2015-10-07 21:07:07 +02:00
|
|
|
showBaseUrl (BaseUrl Https "foo.com" 443 "api") `shouldBe` "https://foo.com/api"
|
|
|
|
it "handles leading slashes in path" $ do
|
|
|
|
showBaseUrl (BaseUrl Https "foo.com" 443 "/api") `shouldBe` "https://foo.com/api"
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
describe "httpBaseUrl" $ do
|
|
|
|
it "allows to construct default http BaseUrls" $ do
|
2015-10-05 09:40:53 +02:00
|
|
|
BaseUrl Http "bar" 80 "" `shouldBe` BaseUrl Http "bar" 80 ""
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
describe "parseBaseUrl" $ do
|
|
|
|
it "is total" $ do
|
|
|
|
property $ \ string ->
|
2015-10-07 18:01:47 +02:00
|
|
|
deepseq (fmap show (parse string )) True
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
it "is the inverse of showBaseUrl" $ do
|
2015-10-07 21:07:07 +02:00
|
|
|
property $ \ baseUrl -> counterexample (showBaseUrl baseUrl) $
|
|
|
|
parse (showBaseUrl baseUrl) === Just baseUrl
|
2014-11-27 18:28:01 +01:00
|
|
|
|
2015-10-05 09:40:53 +02:00
|
|
|
context "trailing slashes" $ do
|
|
|
|
it "allows trailing slashes" $ do
|
2015-10-07 18:01:47 +02:00
|
|
|
parse "foo.com/" `shouldBe` Just (BaseUrl Http "foo.com" 80 "")
|
2015-10-06 14:32:25 +02:00
|
|
|
|
2015-10-05 09:40:53 +02:00
|
|
|
it "allows trailing slashes in paths" $ do
|
2015-10-07 18:01:47 +02:00
|
|
|
parse "foo.com/api/" `shouldBe` Just (BaseUrl Http "foo.com" 80 "api")
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
context "urls without scheme" $ do
|
|
|
|
it "assumes http" $ do
|
2015-10-07 18:01:47 +02:00
|
|
|
parse "foo.com" `shouldBe` Just (BaseUrl Http "foo.com" 80 "")
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
it "allows port numbers" $ do
|
2015-10-07 18:01:47 +02:00
|
|
|
parse "foo.com:8080" `shouldBe` Just (BaseUrl Http "foo.com" 8080 "")
|
2015-10-05 09:40:53 +02:00
|
|
|
|
|
|
|
it "can parse paths" $ do
|
2015-10-07 18:01:47 +02:00
|
|
|
parse "http://foo.com/api" `shouldBe` Just (BaseUrl Http "foo.com" 80 "api")
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
it "rejects ftp urls" $ do
|
2015-10-07 21:07:07 +02:00
|
|
|
parse "ftp://foo.com" `shouldBe` Nothing
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
instance Arbitrary BaseUrl where
|
|
|
|
arbitrary = BaseUrl <$>
|
|
|
|
elements [Http, Https] <*>
|
|
|
|
hostNameGen <*>
|
2015-10-05 09:40:53 +02:00
|
|
|
portGen <*>
|
|
|
|
pathGen
|
2014-11-27 18:28:01 +01:00
|
|
|
where
|
2015-10-05 09:40:53 +02:00
|
|
|
letters = ['a' .. 'z'] ++ ['A' .. 'Z']
|
2014-11-27 18:28:01 +01:00
|
|
|
-- this does not perfectly mirror the url standard, but I hope it's good
|
|
|
|
-- enough.
|
|
|
|
hostNameGen = do
|
|
|
|
first <- elements letters
|
|
|
|
middle <- listOf1 $ elements (letters ++ ['0' .. '9'] ++ ['.', '-'])
|
2015-10-07 18:01:47 +02:00
|
|
|
last' <- elements letters
|
|
|
|
return (first : middle ++ [last'])
|
2014-11-27 18:28:01 +01:00
|
|
|
portGen = frequency $
|
|
|
|
(1, return 80) :
|
|
|
|
(1, return 443) :
|
|
|
|
(1, choose (1, 20000)) :
|
|
|
|
[]
|
2015-10-05 09:40:53 +02:00
|
|
|
pathGen = listOf1 . elements $ letters
|
2014-11-27 18:28:01 +01:00
|
|
|
|
|
|
|
isLeft :: Either a b -> Bool
|
|
|
|
isLeft = either (const True) (const False)
|