2022-05-22 11:47:58 +00:00
|
|
|
module Test.HTTPurple.ResponseSpec 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.Either (Either(Right))
|
|
|
|
import Effect.Aff (makeAff, nonCanceler)
|
|
|
|
import Effect.Class (liftEffect)
|
2022-05-22 11:47:58 +00:00
|
|
|
import HTTPurple.Body (defaultHeaders)
|
2022-06-14 18:32:05 +00:00
|
|
|
import HTTPurple.Headers (header, toResponseHeaders)
|
2022-05-22 11:47:58 +00:00
|
|
|
import HTTPurple.Response (emptyResponse, emptyResponse', response, response', send)
|
2022-05-04 21:02:29 +00:00
|
|
|
import Node.Encoding (Encoding(UTF8))
|
|
|
|
import Node.HTTP (responseAsStream)
|
|
|
|
import Node.Stream (end, writeString)
|
2022-06-14 18:32:05 +00:00
|
|
|
import Test.HTTPurple.TestHelpers (Test, getResponseBody, getResponseHeader, getResponseStatus, mockResponse, (?=))
|
2022-05-04 21:02:29 +00:00
|
|
|
import Test.Spec (describe, it)
|
2017-07-14 06:28:57 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
sendSpec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
sendSpec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "send" do
|
|
|
|
let
|
|
|
|
mockResponse' =
|
|
|
|
{ status: 123
|
|
|
|
, headers: header "Test" "test"
|
|
|
|
, writeBody:
|
|
|
|
\response -> makeAff \done -> do
|
|
|
|
stream <- pure $ responseAsStream response
|
2022-05-04 21:02:29 +00:00
|
|
|
void $ writeString stream UTF8 "test" $ const $ end stream $ const $ done $ Right unit
|
2021-11-19 06:16:35 +00:00
|
|
|
pure nonCanceler
|
|
|
|
}
|
|
|
|
it "writes the headers" do
|
2021-03-22 19:02:36 +00:00
|
|
|
header <- do
|
2021-11-19 06:16:35 +00:00
|
|
|
httpResponse <- liftEffect mockResponse
|
|
|
|
send httpResponse mockResponse'
|
|
|
|
pure $ getResponseHeader "Test" httpResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
header ?= "test"
|
2021-11-19 06:16:35 +00:00
|
|
|
it "writes the status" do
|
2021-03-22 19:02:36 +00:00
|
|
|
status <- do
|
2021-11-19 06:16:35 +00:00
|
|
|
httpResponse <- liftEffect mockResponse
|
|
|
|
send httpResponse mockResponse'
|
|
|
|
pure $ getResponseStatus httpResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
status ?= 123
|
2021-11-19 06:16:35 +00:00
|
|
|
it "writes the body" do
|
2021-03-22 19:02:36 +00:00
|
|
|
body <- do
|
2021-11-19 06:16:35 +00:00
|
|
|
httpResponse <- liftEffect mockResponse
|
|
|
|
send httpResponse mockResponse'
|
|
|
|
pure $ getResponseBody httpResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
body ?= "test"
|
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
responseFunctionSpec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
responseFunctionSpec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "response" do
|
|
|
|
it "has the right status" do
|
|
|
|
resp <- response 123 "test"
|
2021-03-22 19:02:36 +00:00
|
|
|
resp.status ?= 123
|
2021-11-19 06:16:35 +00:00
|
|
|
it "has only default headers" do
|
|
|
|
resp <- response 123 "test"
|
|
|
|
defaultHeaders' <- liftEffect $ defaultHeaders "test"
|
2022-06-14 18:32:05 +00:00
|
|
|
resp.headers ?= toResponseHeaders defaultHeaders'
|
2021-11-19 06:16:35 +00:00
|
|
|
it "has the right writeBody function" do
|
2021-03-22 19:02:36 +00:00
|
|
|
body <- do
|
2021-11-19 06:16:35 +00:00
|
|
|
resp <- response 123 "test"
|
|
|
|
httpResponse <- liftEffect $ mockResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
resp.writeBody httpResponse
|
2021-11-19 06:16:35 +00:00
|
|
|
pure $ getResponseBody httpResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
body ?= "test"
|
2017-09-29 14:49:46 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
response'Spec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
response'Spec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "response'" do
|
|
|
|
let
|
|
|
|
mockHeaders = header "Test" "test"
|
|
|
|
mockResponse' = response' 123 mockHeaders "test"
|
|
|
|
it "has the right status" do
|
|
|
|
resp <- mockResponse'
|
2021-03-22 19:02:36 +00:00
|
|
|
resp.status ?= 123
|
2021-11-19 06:16:35 +00:00
|
|
|
it "has the right headers" do
|
|
|
|
resp <- mockResponse'
|
|
|
|
defaultHeaders' <- liftEffect $ defaultHeaders "test"
|
2022-06-14 18:32:05 +00:00
|
|
|
resp.headers ?= toResponseHeaders defaultHeaders' <> mockHeaders
|
2021-11-19 06:16:35 +00:00
|
|
|
it "has the right writeBody function" do
|
2021-03-22 19:02:36 +00:00
|
|
|
body <- do
|
2021-11-19 06:16:35 +00:00
|
|
|
resp <- mockResponse'
|
|
|
|
httpResponse <- liftEffect mockResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
resp.writeBody httpResponse
|
2021-11-19 06:16:35 +00:00
|
|
|
pure $ getResponseBody httpResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
body ?= "test"
|
2017-09-26 06:08:07 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
emptyResponseSpec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
emptyResponseSpec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "emptyResponse" do
|
|
|
|
it "has the right status" do
|
|
|
|
resp <- emptyResponse 123
|
2021-03-22 19:02:36 +00:00
|
|
|
resp.status ?= 123
|
2021-11-19 06:16:35 +00:00
|
|
|
it "has only default headers" do
|
|
|
|
resp <- emptyResponse 123
|
|
|
|
defaultHeaders' <- liftEffect $ defaultHeaders ""
|
2022-06-14 18:32:05 +00:00
|
|
|
resp.headers ?= toResponseHeaders defaultHeaders'
|
2021-11-19 06:16:35 +00:00
|
|
|
it "has the right writeBody function" do
|
2021-03-22 19:02:36 +00:00
|
|
|
body <- do
|
2021-11-19 06:16:35 +00:00
|
|
|
resp <- emptyResponse 123
|
|
|
|
httpResponse <- liftEffect $ mockResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
resp.writeBody httpResponse
|
2021-11-19 06:16:35 +00:00
|
|
|
pure $ getResponseBody httpResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
body ?= ""
|
2017-09-29 14:49:46 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
emptyResponse'Spec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
emptyResponse'Spec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "emptyResponse'" do
|
|
|
|
let
|
|
|
|
mockHeaders = header "Test" "test"
|
|
|
|
mockResponse' = emptyResponse' 123 mockHeaders
|
|
|
|
it "has the right status" do
|
|
|
|
resp <- mockResponse'
|
2021-03-22 19:02:36 +00:00
|
|
|
resp.status ?= 123
|
2021-11-19 06:16:35 +00:00
|
|
|
it "has the right headers" do
|
|
|
|
resp <- mockResponse'
|
|
|
|
defaultHeaders' <- liftEffect $ defaultHeaders ""
|
2022-06-14 18:32:05 +00:00
|
|
|
resp.headers ?= mockHeaders <> toResponseHeaders defaultHeaders'
|
2021-11-19 06:16:35 +00:00
|
|
|
it "has the right writeBody function" do
|
2021-03-22 19:02:36 +00:00
|
|
|
body <- do
|
2021-11-19 06:16:35 +00:00
|
|
|
resp <- mockResponse'
|
|
|
|
httpResponse <- liftEffect mockResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
resp.writeBody httpResponse
|
2021-11-19 06:16:35 +00:00
|
|
|
pure $ getResponseBody httpResponse
|
2021-03-22 19:02:36 +00:00
|
|
|
body ?= ""
|
2017-07-10 10:17:13 +00:00
|
|
|
|
2021-11-19 06:16:35 +00:00
|
|
|
responseSpec :: Test
|
2021-03-22 19:02:36 +00:00
|
|
|
responseSpec =
|
2021-11-19 06:16:35 +00:00
|
|
|
describe "Response" do
|
2021-03-22 19:02:36 +00:00
|
|
|
sendSpec
|
|
|
|
responseFunctionSpec
|
|
|
|
response'Spec
|
|
|
|
emptyResponseSpec
|
|
|
|
emptyResponse'Spec
|