module Test.HTTPurple.IntegrationSpec where import Prelude import Control.Monad.Trans.Class (lift) import Effect.Aff (Milliseconds(..), delay) import Effect.Class (liftEffect) import Examples.AsyncResponse.Main as AsyncResponse import Examples.BinaryRequest.Main as BinaryRequest import Examples.BinaryResponse.Main as BinaryResponse import Examples.Chunked.Main as Chunked import Examples.CustomStack.Main as CustomStack import Examples.ExtensibleMiddleware.Main as ExtensibleMiddleware import Examples.Headers.Main as Headers import Examples.HelloWorld.Main as HelloWorld import Examples.JsonParsing.Main as JsonParsing import Examples.Middleware.Main as Middleware import Examples.MultiRoute.Main as MultiRoute import Examples.NodeMiddleware.Main as NodeMiddleware import Examples.PathSegments.Main as PathSegments import Examples.Post.Main as Post import Examples.QueryParameters.Main as QueryParameters import Examples.SSL.Main as SSL import Foreign.Object (empty, singleton) import Foreign.Object as Object import Node.Buffer (toArray) import Node.FS.Aff (readFile) import Test.HTTPurple.TestHelpers (Test, get, get', getBinary, getHeader, post, postBinary, (?=)) import Test.Spec (Tree(..), describe, it) import Test.Spec.Assertions.String (shouldStartWith) asyncResponseSpec :: Test asyncResponseSpec = it "runs the async response example" do close <- liftEffect AsyncResponse.main response <- get 8080 empty "/" liftEffect $ close $ pure unit response ?= "hello world!" binaryRequestSpec :: Test binaryRequestSpec = it "runs the binary request example" do close <- liftEffect BinaryRequest.main binaryBuf <- readFile BinaryResponse.filePath response <- postBinary 8080 empty "/" binaryBuf liftEffect $ close $ pure unit response ?= "d5e776724dd545d8b54123b46362a553d10257cee688ef1be62166c984b34405" binaryResponseSpec :: Test binaryResponseSpec = it "runs the binary response example" do close <- liftEffect BinaryResponse.main responseBuf <- getBinary 8080 empty "/" liftEffect $ close $ pure unit binaryBuf <- readFile BinaryResponse.filePath expected <- liftEffect $ toArray binaryBuf response <- liftEffect $ toArray responseBuf response ?= expected chunkedSpec :: Test chunkedSpec = it "runs the chunked example" do close <- liftEffect Chunked.main response <- get 8080 empty "/" liftEffect $ close $ pure unit -- TODO this isn't a great way to validate this, we need a way of inspecting -- each individual chunk instead of just looking at the entire response response ?= "hello \nworld!\n" customStackSpec :: Test customStackSpec = it "runs the custom stack example" do close <- liftEffect CustomStack.main response <- get 8080 empty "/" liftEffect $ close $ pure unit response ?= "hello, joe" headersSpec :: Test headersSpec = it "runs the headers example" do close <- liftEffect Headers.main header <- getHeader 8080 empty "/" "X-Example" response <- get 8080 (singleton "X-Input" "test") "/" liftEffect $ close $ pure unit header ?= "hello world!" response ?= "test" helloWorldSpec :: Test helloWorldSpec = it "runs the hello world example" do close <- liftEffect HelloWorld.main response <- get 8080 empty "/" liftEffect $ close $ pure unit response ?= "hello world!" jsonParsingSpec :: Test jsonParsingSpec = it "runs the hello world example" do close <- liftEffect JsonParsing.main response <- post 8080 empty "/" "{\"name\":\"world\"}" liftEffect $ close $ pure unit response ?= "{\"hello\": \"world\" }" middlewareSpec :: Test middlewareSpec = it "runs the middleware example" do close <- liftEffect Middleware.main header <- getHeader 8080 empty "/" "X-Middleware" body <- get 8080 empty "/" header' <- getHeader 8080 empty "/middleware" "X-Middleware" body' <- get 8080 empty "/middleware" liftEffect $ close $ pure unit header ?= "router" body ?= "hello" header' ?= "middleware" body' ?= "Middleware!" multiRouteSpec :: Test multiRouteSpec = it "runs the multi route example" do close <- liftEffect MultiRoute.main hello <- get 8080 empty "/hello" goodbye <- get 8080 empty "/goodbye" liftEffect $ close $ pure unit hello ?= "hello" goodbye ?= "goodbye" pathSegmentsSpec :: Test pathSegmentsSpec = it "runs the path segments example" do close <- liftEffect PathSegments.main foo <- get 8080 empty "/segment/foo" somebars <- get 8080 empty "/some/bars" liftEffect $ close $ pure unit foo ?= "foo" somebars ?= "[\"some\",\"bars\"]" postSpec :: Test postSpec = it "runs the post example" do close <- liftEffect Post.main response <- post 8080 empty "/" "test" liftEffect $ close $ pure unit response ?= "test" queryParametersSpec :: Test queryParametersSpec = it "runs the query parameters example" do close <- liftEffect QueryParameters.main foo <- get 8080 empty "/?foo" bar <- get 8080 empty "/?bar=test" notbar <- get 8080 empty "/?bar=nottest" baz <- get 8080 empty "/?baz=test" liftEffect $ close $ pure unit foo ?= "foo" bar ?= "bar" notbar ?= "" baz ?= "test" sslSpec :: Test sslSpec = it "runs the ssl example" do close <- liftEffect SSL.main response <- get' 8080 empty "/" liftEffect $ close $ pure unit response ?= "hello world!" extensibleMiddlewareSpec :: Test extensibleMiddlewareSpec = it "runs the extensible middleware example" do close <- liftEffect ExtensibleMiddleware.main let headers = Object.singleton "X-Token" "123" body <- get 8080 headers "/" body' <- get 8080 empty "/" liftEffect $ close $ pure unit body `shouldStartWith` "hello John Doe, it is" body' `shouldStartWith` "hello anonymous, it is" nodeMiddlewareSpec :: Test nodeMiddlewareSpec = it "runs the node middleware example" do close <- liftEffect NodeMiddleware.main let headers = Object.singleton "X-Token" "123" body <- get 8080 headers "/" body' <- get 8080 empty "/" liftEffect $ close $ pure unit body `shouldStartWith` "hello John Doe" body' `shouldStartWith` "hello anonymous" integrationSpec :: Test integrationSpec = describe "Integration" do asyncResponseSpec binaryRequestSpec binaryResponseSpec chunkedSpec customStackSpec headersSpec helloWorldSpec middlewareSpec multiRouteSpec pathSegmentsSpec postSpec queryParametersSpec sslSpec jsonParsingSpec extensibleMiddlewareSpec nodeMiddlewareSpec