2017-10-26 21:19:30 +00:00
|
|
|
module Test.HTTPure.IntegrationSpec where
|
|
|
|
|
|
|
|
import Prelude
|
|
|
|
|
2018-07-08 23:16:48 +00:00
|
|
|
import Effect.Class as EffectClass
|
|
|
|
import Foreign.Object as Object
|
2018-08-20 02:50:07 +00:00
|
|
|
import Node.Buffer as Buffer
|
|
|
|
import Node.FS.Aff as FS
|
2017-10-26 21:19:30 +00:00
|
|
|
import Test.Spec as Spec
|
|
|
|
|
|
|
|
import Test.HTTPure.TestHelpers as TestHelpers
|
|
|
|
import Test.HTTPure.TestHelpers ((?=))
|
|
|
|
|
|
|
|
import Examples.AsyncResponse.Main as AsyncResponse
|
|
|
|
import Examples.Headers.Main as Headers
|
|
|
|
import Examples.HelloWorld.Main as HelloWorld
|
2018-08-20 02:50:07 +00:00
|
|
|
import Examples.Image.Main as Image
|
2017-10-26 21:19:30 +00:00
|
|
|
import Examples.Middleware.Main as Middleware
|
|
|
|
import Examples.MultiRoute.Main as MultiRoute
|
|
|
|
import Examples.PathSegments.Main as PathSegments
|
|
|
|
import Examples.QueryParameters.Main as QueryParameters
|
|
|
|
import Examples.Post.Main as Post
|
|
|
|
import Examples.SSL.Main as SSL
|
|
|
|
|
|
|
|
asyncResponseSpec :: TestHelpers.Test
|
|
|
|
asyncResponseSpec = Spec.it "runs the async response example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect AsyncResponse.main
|
|
|
|
response <- TestHelpers.get port Object.empty "/"
|
2017-10-26 21:19:30 +00:00
|
|
|
response ?= "hello world!"
|
|
|
|
where port = AsyncResponse.port
|
|
|
|
|
|
|
|
headersSpec :: TestHelpers.Test
|
|
|
|
headersSpec = Spec.it "runs the headers example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect Headers.main
|
|
|
|
header <- TestHelpers.getHeader port Object.empty "/" "X-Example"
|
2017-10-26 21:19:30 +00:00
|
|
|
header ?= "hello world!"
|
2018-07-08 23:16:48 +00:00
|
|
|
response <- TestHelpers.get port (Object.singleton "X-Input" "test") "/"
|
2017-10-26 21:19:30 +00:00
|
|
|
response ?= "test"
|
|
|
|
where port = Headers.port
|
|
|
|
|
|
|
|
helloWorldSpec :: TestHelpers.Test
|
|
|
|
helloWorldSpec = Spec.it "runs the hello world example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect HelloWorld.main
|
|
|
|
response <- TestHelpers.get port Object.empty "/"
|
2017-10-26 21:19:30 +00:00
|
|
|
response ?= "hello world!"
|
|
|
|
where port = HelloWorld.port
|
|
|
|
|
2018-08-20 02:50:07 +00:00
|
|
|
imageSpec :: TestHelpers.Test
|
|
|
|
imageSpec = Spec.it "runs the image example" do
|
|
|
|
imageBuf <- FS.readFile Image.filePath
|
|
|
|
expected <- EffectClass.liftEffect $ Buffer.toArray imageBuf
|
|
|
|
EffectClass.liftEffect Image.main
|
|
|
|
responseBuf <- TestHelpers.getBinary port Object.empty "/"
|
|
|
|
response <- EffectClass.liftEffect $ Buffer.toArray responseBuf
|
|
|
|
response ?= expected
|
|
|
|
where port = Image.port
|
|
|
|
|
2017-10-26 21:19:30 +00:00
|
|
|
middlewareSpec :: TestHelpers.Test
|
|
|
|
middlewareSpec = Spec.it "runs the middleware example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect Middleware.main
|
|
|
|
header <- TestHelpers.getHeader port Object.empty "/" "X-Middleware"
|
2017-10-26 21:19:30 +00:00
|
|
|
header ?= "router"
|
2018-07-08 23:16:48 +00:00
|
|
|
body <- TestHelpers.get port Object.empty "/"
|
2017-10-26 21:19:30 +00:00
|
|
|
body ?= "hello"
|
2018-07-08 23:16:48 +00:00
|
|
|
header' <- TestHelpers.getHeader port Object.empty "/middleware" "X-Middleware"
|
2018-02-25 03:57:46 +00:00
|
|
|
header' ?= "middleware"
|
2018-07-08 23:16:48 +00:00
|
|
|
body' <- TestHelpers.get port Object.empty "/middleware"
|
2017-10-26 21:19:30 +00:00
|
|
|
body' ?= "Middleware!"
|
|
|
|
where port = Middleware.port
|
|
|
|
|
|
|
|
multiRouteSpec :: TestHelpers.Test
|
|
|
|
multiRouteSpec = Spec.it "runs the multi route example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect MultiRoute.main
|
|
|
|
hello <- TestHelpers.get port Object.empty "/hello"
|
2017-10-26 21:19:30 +00:00
|
|
|
hello ?= "hello"
|
2018-07-08 23:16:48 +00:00
|
|
|
goodbye <- TestHelpers.get port Object.empty "/goodbye"
|
2017-10-26 21:19:30 +00:00
|
|
|
goodbye ?= "goodbye"
|
|
|
|
where port = MultiRoute.port
|
|
|
|
|
|
|
|
pathSegmentsSpec :: TestHelpers.Test
|
|
|
|
pathSegmentsSpec = Spec.it "runs the path segments example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect PathSegments.main
|
|
|
|
foo <- TestHelpers.get port Object.empty "/segment/foo"
|
2017-10-26 21:19:30 +00:00
|
|
|
foo ?= "foo"
|
2018-07-08 23:16:48 +00:00
|
|
|
somebars <- TestHelpers.get port Object.empty "/some/bars"
|
2017-10-26 21:19:30 +00:00
|
|
|
somebars ?= "[\"some\",\"bars\"]"
|
|
|
|
where port = PathSegments.port
|
|
|
|
|
|
|
|
queryParametersSpec :: TestHelpers.Test
|
|
|
|
queryParametersSpec = Spec.it "runs the query parameters example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect QueryParameters.main
|
|
|
|
foo <- TestHelpers.get port Object.empty "/?foo"
|
2017-10-26 21:19:30 +00:00
|
|
|
foo ?= "foo"
|
2018-07-08 23:16:48 +00:00
|
|
|
bar <- TestHelpers.get port Object.empty "/?bar=test"
|
2017-10-26 21:19:30 +00:00
|
|
|
bar ?= "bar"
|
2018-07-08 23:16:48 +00:00
|
|
|
notbar <- TestHelpers.get port Object.empty "/?bar=nottest"
|
2017-10-26 21:19:30 +00:00
|
|
|
notbar ?= ""
|
2018-07-08 23:16:48 +00:00
|
|
|
baz <- TestHelpers.get port Object.empty "/?baz=test"
|
2017-10-26 21:19:30 +00:00
|
|
|
baz ?= "test"
|
|
|
|
where port = QueryParameters.port
|
|
|
|
|
|
|
|
postSpec :: TestHelpers.Test
|
|
|
|
postSpec = Spec.it "runs the post example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect Post.main
|
|
|
|
response <- TestHelpers.post port Object.empty "/" "test"
|
2017-10-26 21:19:30 +00:00
|
|
|
response ?= "test"
|
|
|
|
where port = Post.port
|
|
|
|
|
|
|
|
sslSpec :: TestHelpers.Test
|
|
|
|
sslSpec = Spec.it "runs the ssl example" do
|
2018-07-08 23:16:48 +00:00
|
|
|
EffectClass.liftEffect SSL.main
|
|
|
|
response <- TestHelpers.get' port Object.empty "/"
|
2017-10-26 21:19:30 +00:00
|
|
|
response ?= "hello world!"
|
|
|
|
where port = SSL.port
|
|
|
|
|
|
|
|
integrationSpec :: TestHelpers.Test
|
|
|
|
integrationSpec = Spec.describe "Integration" do
|
|
|
|
asyncResponseSpec
|
|
|
|
headersSpec
|
|
|
|
helloWorldSpec
|
2018-08-20 02:50:07 +00:00
|
|
|
imageSpec
|
2017-10-26 21:19:30 +00:00
|
|
|
middlewareSpec
|
|
|
|
multiRouteSpec
|
|
|
|
pathSegmentsSpec
|
|
|
|
queryParametersSpec
|
|
|
|
postSpec
|
|
|
|
sslSpec
|