2017-10-26 21:19:30 +00:00
|
|
|
module Test.HTTPure.RequestSpec where
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2017-07-18 05:31:46 +00:00
|
|
|
import Prelude
|
2022-05-04 21:02:29 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
import Data.Tuple (Tuple(Tuple))
|
|
|
|
import Foreign.Object (singleton)
|
|
|
|
import HTTPure.Body (toString)
|
|
|
|
import HTTPure.Headers (headers)
|
|
|
|
import HTTPure.Method (Method(Post))
|
|
|
|
import HTTPure.Request (fromHTTPRequest, fullPath)
|
|
|
|
import HTTPure.Version (Version(HTTP1_1))
|
2022-05-04 21:02:29 +00:00
|
|
|
import Test.HTTPure.TestHelpers (Test, mockRequest, (?=))
|
|
|
|
import Test.Spec (describe, it)
|
2017-05-25 19:12:29 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
fromHTTPRequestSpec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
fromHTTPRequestSpec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "fromHTTPRequest" do
|
|
|
|
it "contains the correct method" do
|
|
|
|
mock <- mockRequest'
|
|
|
|
mock.method ?= Post
|
|
|
|
it "contains the correct path" do
|
|
|
|
mock <- mockRequest'
|
2021-03-22 19:02:36 +00:00
|
|
|
mock.path ?= [ "test" ]
|
2021-11-19 06:16:35 +00:00
|
|
|
it "contains the correct query" do
|
|
|
|
mock <- mockRequest'
|
|
|
|
mock.query ?= singleton "a" "b"
|
|
|
|
it "contains the correct headers" do
|
|
|
|
mock <- mockRequest'
|
|
|
|
mock.headers ?= headers mockHeaders
|
|
|
|
it "contains the correct body" do
|
|
|
|
mockBody <- mockRequest' >>= _.body >>> toString
|
2021-11-16 04:02:36 +00:00
|
|
|
mockBody ?= "body"
|
2021-11-19 06:16:35 +00:00
|
|
|
it "contains the correct httpVersion" do
|
|
|
|
mock <- mockRequest'
|
|
|
|
mock.httpVersion ?= HTTP1_1
|
2017-07-18 01:51:43 +00:00
|
|
|
where
|
2021-11-19 06:16:35 +00:00
|
|
|
mockHeaders = [ Tuple "Test" "test" ]
|
2021-03-22 19:02:36 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
mockHTTPRequest = mockRequest "1.1" "POST" "/test?a=b" "body" mockHeaders
|
2021-03-22 19:02:36 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
mockRequest' = mockHTTPRequest >>= fromHTTPRequest
|
2017-07-10 10:17:13 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
fullPathSpec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
fullPathSpec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "fullPath" do
|
|
|
|
describe "without query parameters" do
|
|
|
|
it "is correct" do
|
|
|
|
mock <- mockRequest' "/foo/bar"
|
|
|
|
fullPath mock ?= "/foo/bar"
|
|
|
|
describe "with empty path segments" do
|
|
|
|
it "strips the empty segments" do
|
|
|
|
mock <- mockRequest' "//foo////bar/"
|
|
|
|
fullPath mock ?= "/foo/bar"
|
|
|
|
describe "with only query parameters" do
|
|
|
|
it "is correct" do
|
|
|
|
mock <- mockRequest' "?a=b&c=d"
|
|
|
|
fullPath mock ?= "/?a=b&c=d"
|
|
|
|
describe "with only empty query parameters" do
|
|
|
|
it "is has the default value of '' for the empty parameters" do
|
|
|
|
mock <- mockRequest' "?a"
|
|
|
|
fullPath mock ?= "/?a="
|
|
|
|
describe "with query parameters that have special characters" do
|
|
|
|
it "percent encodes query params" do
|
|
|
|
mock <- mockRequest' "?a=%3Fx%3Dtest"
|
|
|
|
fullPath mock ?= "/?a=%3Fx%3Dtest"
|
|
|
|
describe "with empty query parameters" do
|
|
|
|
it "strips out the empty arameters" do
|
|
|
|
mock <- mockRequest' "?a=b&&&"
|
|
|
|
fullPath mock ?= "/?a=b"
|
|
|
|
describe "with a mix of segments and query parameters" do
|
|
|
|
it "is correct" do
|
|
|
|
mock <- mockRequest' "/foo///bar/?&a=b&&c"
|
|
|
|
fullPath mock ?= "/foo/bar?a=b&c="
|
2017-09-29 16:52:21 +00:00
|
|
|
where
|
2021-11-19 06:16:35 +00:00
|
|
|
mockHTTPRequest path = mockRequest "" "POST" path "body" []
|
2021-03-22 19:02:36 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
mockRequest' path = mockHTTPRequest path >>= fromHTTPRequest
|
2017-09-29 16:52:21 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
requestSpec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
requestSpec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "Request" do
|
2021-03-22 19:02:36 +00:00
|
|
|
fromHTTPRequestSpec
|
|
|
|
fullPathSpec
|