module Test.UrlSpec (spec) where import Test.Syd import Web.View.Types.Url spec :: Spec spec = do describe "Url" $ do describe "parsing" $ do it "scheme and domain" $ do url "https://www.google.com" `shouldBe` Url "https://" "www.google.com" [] [] it "path urls" $ do url "/my/path" `shouldBe` Url "" "" ["my", "path"] [] it "scheme, domain, and path" $ do url "http://woot.com/my/path" `shouldBe` Url "http://" "woot.com" ["my", "path"] [] it "no slash prefix" $ do url "hello/world" `shouldBe` Url "" "" ["hello", "world"] [] it "query" $ do url "/path?key=value" `shouldBe` Url "" "" ["path"] [("key", Just "value")] describe "render" $ do it "paths" $ do renderUrl (url "/hello/world") `shouldBe` "/hello/world" it "query" $ do renderUrl (url "/path?key=value") `shouldBe` "/path?key=value" it "full" $ do renderUrl (url "https://example.com/hello/world?hello&name=bob") `shouldBe` "https://example.com/hello/world?hello&name=bob" it "empty" $ do renderUrl (Url "" "" [] []) `shouldBe` "/" renderUrl (url "https://example.com/") `shouldBe` "https://example.com/" renderUrl (url "https://example.com") `shouldBe` "https://example.com/"