mirror of
https://github.com/edgurgel/httparrot
synced 2025-04-05 08:12:31 -04:00
commit
ca31d47221
27 changed files with 229 additions and 159 deletions
54
.github/workflows/main.yml
vendored
Normal file
54
.github/workflows/main.yml
vendored
Normal file
|
@ -0,0 +1,54 @@
|
|||
name: CI
|
||||
|
||||
on: [push, pull_request]
|
||||
|
||||
jobs:
|
||||
format:
|
||||
name: Format & credo
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v2.3.1
|
||||
|
||||
- name: Install OTP and Elixir
|
||||
uses: erlef/setup-beam@v1
|
||||
with:
|
||||
otp-version: 26.x
|
||||
elixir-version: 1.16.x
|
||||
|
||||
- name: Install dependencies
|
||||
run: mix deps.get
|
||||
|
||||
- name: Compile with --warnings-as-errors
|
||||
run: mix compile --warnings-as-errors
|
||||
|
||||
- name: Run "mix format"
|
||||
run: mix format --check-formatted
|
||||
|
||||
test:
|
||||
name: Test (Elixir ${{matrix.elixir}} | Erlang/OTP ${{matrix.otp}})
|
||||
runs-on: ubuntu-latest
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
include:
|
||||
- otp: 26.x
|
||||
elixir: 1.16.x
|
||||
coverage: true
|
||||
- otp: 27.x
|
||||
elixir: 1.17.x
|
||||
env:
|
||||
MIX_ENV: test
|
||||
steps:
|
||||
- uses: actions/checkout@v2.3.1
|
||||
|
||||
- name: Install OTP and Elixir
|
||||
uses: erlef/setup-beam@v1
|
||||
with:
|
||||
otp-version: ${{matrix.otp}}
|
||||
elixir-version: ${{matrix.elixir}}
|
||||
|
||||
- name: Install dependencies
|
||||
run: mix deps.get --only test
|
||||
|
||||
- name: Run tests
|
||||
run: mix test --trace
|
25
.travis.yml
25
.travis.yml
|
@ -1,25 +0,0 @@
|
|||
language: elixir
|
||||
notifications:
|
||||
recipients:
|
||||
- eduardo@gurgel.me
|
||||
cache:
|
||||
directories:
|
||||
- _build
|
||||
- deps
|
||||
sudo: false
|
||||
script: mix test
|
||||
matrix:
|
||||
include:
|
||||
otp_release: 21.0
|
||||
- elixir: 1.7
|
||||
otp_release: 19.3
|
||||
- elixir: 1.7
|
||||
otp_release: 20.3
|
||||
- elixir: 1.7
|
||||
otp_release: 21.0
|
||||
- elixir: 1.8
|
||||
otp_release: 20.3
|
||||
- elixir: 1.8
|
||||
otp_release: 21.0
|
||||
- elixir: 1.8
|
||||
otp_release: 22.0.1
|
|
@ -1,4 +1,4 @@
|
|||
import Mix.Config
|
||||
import Config
|
||||
|
||||
port = System.get_env("PORT", "8080")
|
||||
port = String.to_integer(port)
|
||||
|
@ -14,4 +14,3 @@ config :httparrot,
|
|||
https_port: ssl_port,
|
||||
unix_socket: unix_socket,
|
||||
socket_path: System.get_env("SOCKET_PATH", "httparrot.sock")
|
||||
|
||||
|
|
|
@ -14,4 +14,3 @@ config :httparrot,
|
|||
https_port: ssl_port,
|
||||
unix_socket: unix_socket,
|
||||
socket_path: System.get_env("SOCKET_PATH", "httparrot.sock")
|
||||
|
||||
|
|
|
@ -7,7 +7,7 @@ defmodule HTTParrot do
|
|||
end
|
||||
|
||||
def init(_) do
|
||||
supervise([], strategy: :simple_one_for_one)
|
||||
Supervisor.start_link([], strategy: :one_for_one)
|
||||
end
|
||||
|
||||
def start(_type, _args) do
|
||||
|
@ -71,9 +71,9 @@ defmodule HTTParrot do
|
|||
:https,
|
||||
[
|
||||
port: https_port,
|
||||
cacertfile: priv_dir ++ '/ssl/server-ca.crt',
|
||||
certfile: priv_dir ++ '/ssl/server.crt',
|
||||
keyfile: priv_dir ++ '/ssl/server.key'
|
||||
cacertfile: priv_dir ++ ~c"/ssl/server-ca.crt",
|
||||
certfile: priv_dir ++ ~c"/ssl/server.crt",
|
||||
keyfile: priv_dir ++ ~c"/ssl/server.key"
|
||||
],
|
||||
%{env: %{dispatch: dispatch}}
|
||||
)
|
||||
|
|
|
@ -13,7 +13,7 @@ defmodule HTTParrot.PHandler do
|
|||
"""
|
||||
def allowed_methods(req, state) do
|
||||
path = :cowboy_req.path(req)
|
||||
path = String.slice(path, 1..-1)
|
||||
path = String.slice(path, 1..-1//1)
|
||||
{[String.upcase(path)], req, state}
|
||||
end
|
||||
|
||||
|
|
|
@ -19,7 +19,11 @@ defmodule HTTParrot.RedirectHandler do
|
|||
def previously_existed(req, state), do: {true, req, state}
|
||||
|
||||
def moved_permanently(req, n) do
|
||||
host_url = IO.iodata_to_binary(:cowboy_req.uri(req, %{path: :undefined, qs: :undefined, fragment: :undefined}))
|
||||
host_url =
|
||||
IO.iodata_to_binary(
|
||||
:cowboy_req.uri(req, %{path: :undefined, qs: :undefined, fragment: :undefined})
|
||||
)
|
||||
|
||||
url = if n > 1, do: "/redirect/#{n - 1}", else: "/get"
|
||||
{{true, host_url <> url}, req, nil}
|
||||
end
|
||||
|
|
|
@ -23,7 +23,7 @@ defmodule HTTParrot.StoreRequestHandler do
|
|||
{info, req} = GeneralRequestInfo.retrieve(req)
|
||||
key = :cowboy_req.binding(:key, req)
|
||||
HTTParrot.RequestStore.store(key, info)
|
||||
{'{"saved": "true"}', req, state}
|
||||
{~c'{"saved": "true"}', req, state}
|
||||
end
|
||||
|
||||
def post_binary(req, _state) do
|
||||
|
|
|
@ -31,13 +31,15 @@ defmodule HTTParrot.StreamBytesHandler do
|
|||
end
|
||||
|
||||
defp stream_response!(n, chunk_size, req) do
|
||||
req = :cowboy_req.stream_reply(200, %{ "content-type" => "application/octet-stream" }, req)
|
||||
req = :cowboy_req.stream_reply(200, %{"content-type" => "application/octet-stream"}, req)
|
||||
|
||||
Stream.repeatedly(fn -> :rand.uniform(255) end)
|
||||
|> Stream.take(n)
|
||||
|> Enum.chunk_every(chunk_size, chunk_size, [])
|
||||
|> Enum.each(fn chunk ->
|
||||
:cowboy_req.stream_body(List.to_string(chunk), :nofin, req)
|
||||
end)
|
||||
|
||||
:cowboy_req.stream_body("", :fin, req)
|
||||
req
|
||||
end
|
||||
|
|
|
@ -25,11 +25,13 @@ defmodule HTTParrot.StreamHandler do
|
|||
|
||||
def get_json(req, n) do
|
||||
{info, req} = GeneralRequestInfo.retrieve(req)
|
||||
req = :cowboy_req.stream_reply(200, %{ "content-type" => "application/json" }, req)
|
||||
req = :cowboy_req.stream_reply(200, %{"content-type" => "application/json"}, req)
|
||||
|
||||
Enum.each(0..(n - 1), fn i ->
|
||||
body = JSX.encode!([id: i] ++ info)
|
||||
:cowboy_req.stream_body(body, :nofin, req)
|
||||
end)
|
||||
|
||||
:cowboy_req.stream_body("", :fin, req)
|
||||
{:stop, req, nil}
|
||||
end
|
||||
|
|
14
mix.exs
14
mix.exs
|
@ -2,13 +2,13 @@ defmodule Httparrot.Mixfile do
|
|||
use Mix.Project
|
||||
|
||||
@source_url "https://github.com/edgurgel/httparrot"
|
||||
@version "1.3.0"
|
||||
@version "1.4.0"
|
||||
|
||||
def project do
|
||||
[
|
||||
app: :httparrot,
|
||||
version: @version,
|
||||
elixir: "~> 1.7",
|
||||
elixir: "~> 1.16",
|
||||
name: "HTTParrot",
|
||||
package: package(),
|
||||
deps: deps(),
|
||||
|
@ -25,12 +25,12 @@ defmodule Httparrot.Mixfile do
|
|||
|
||||
defp deps do
|
||||
[
|
||||
{:cowboy, "~> 2.8.0"},
|
||||
{:cowboy, "~> 2.12"},
|
||||
{:exjsx, "~> 3.0 or ~> 4.0"},
|
||||
{:con_cache, "~> 0.14.0"},
|
||||
{:con_cache, "~> 1.1"},
|
||||
{:earmark, "~> 1.0", only: :dev},
|
||||
{:ex_doc, ">= 0.0.0", only: :dev, runtime: false},
|
||||
{:meck, "~> 0.8.13", only: :test}
|
||||
{:ex_doc, "~> 0.18", only: :dev},
|
||||
{:meck, "~> 0.9", only: :test}
|
||||
]
|
||||
end
|
||||
|
||||
|
@ -55,7 +55,7 @@ defmodule Httparrot.Mixfile do
|
|||
],
|
||||
main: "readme",
|
||||
source_url: @source_url,
|
||||
source_ref: "v{@version}",
|
||||
source_ref: "v#{@version}",
|
||||
formatters: ["html"]
|
||||
]
|
||||
end
|
||||
|
|
26
mix.lock
26
mix.lock
|
@ -1,17 +1,17 @@
|
|||
%{
|
||||
"con_cache": {:hex, :con_cache, "0.14.0", "863acb90fa08017be3129074993af944cf7a4b6c3ee7c06c5cd0ed6b94fbc223", [:mix], [], "hexpm", "50887a8949377d0b707a3c6653b7610de06074751b52d0f267f52135f391aece"},
|
||||
"cowboy": {:hex, :cowboy, "2.8.0", "f3dc62e35797ecd9ac1b50db74611193c29815401e53bac9a5c0577bd7bc667d", [:rebar3], [{:cowlib, "~> 2.9.1", [hex: :cowlib, repo: "hexpm", optional: false]}, {:ranch, "~> 1.7.1", [hex: :ranch, repo: "hexpm", optional: false]}], "hexpm", "4643e4fba74ac96d4d152c75803de6fad0b3fa5df354c71afdd6cbeeb15fac8a"},
|
||||
"cowlib": {:hex, :cowlib, "2.9.1", "61a6c7c50cf07fdd24b2f45b89500bb93b6686579b069a89f88cb211e1125c78", [:rebar3], [], "hexpm", "e4175dc240a70d996156160891e1c62238ede1729e45740bdd38064dad476170"},
|
||||
"earmark": {:hex, :earmark, "1.4.15", "2c7f924bf495ec1f65bd144b355d0949a05a254d0ec561740308a54946a67888", [:mix], [{:earmark_parser, ">= 1.4.13", [hex: :earmark_parser, repo: "hexpm", optional: false]}], "hexpm", "3b1209b85bc9f3586f370f7c363f6533788fb4e51db23aa79565875e7f9999ee"},
|
||||
"earmark_parser": {:hex, :earmark_parser, "1.4.15", "b29e8e729f4aa4a00436580dcc2c9c5c51890613457c193cc8525c388ccb2f06", [:mix], [], "hexpm", "044523d6438ea19c1b8ec877ec221b008661d3c27e3b848f4c879f500421ca5c"},
|
||||
"ex_doc": {:hex, :ex_doc, "0.25.1", "4b736fa38dc76488a937e5ef2944f5474f3eff921de771b25371345a8dc810bc", [:mix], [{:earmark_parser, "~> 1.4.0", [hex: :earmark_parser, repo: "hexpm", optional: false]}, {:makeup_elixir, "~> 0.14", [hex: :makeup_elixir, repo: "hexpm", optional: false]}, {:makeup_erlang, "~> 0.1", [hex: :makeup_erlang, repo: "hexpm", optional: false]}], "hexpm", "3200b0a69ddb2028365281fbef3753ea9e728683863d8cdaa96580925c891f67"},
|
||||
"exactor": {:hex, :exactor, "2.2.3", "a6972f43bb6160afeb73e1d8ab45ba604cd0ac8b5244c557093f6e92ce582786", [:mix], [], "hexpm"},
|
||||
"con_cache": {:hex, :con_cache, "1.1.0", "45c7c6cd6dc216e47636232e8c683734b7fe293221fccd9454fa1757bc685044", [:mix], [{:telemetry, "~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "8655f2ae13a1e56c8aef304d250814c7ed929c12810f126fc423ecc8e871593b"},
|
||||
"cowboy": {:hex, :cowboy, "2.12.0", "f276d521a1ff88b2b9b4c54d0e753da6c66dd7be6c9fca3d9418b561828a3731", [:make, :rebar3], [{:cowlib, "2.13.0", [hex: :cowlib, repo: "hexpm", optional: false]}, {:ranch, "1.8.0", [hex: :ranch, repo: "hexpm", optional: false]}], "hexpm", "8a7abe6d183372ceb21caa2709bec928ab2b72e18a3911aa1771639bef82651e"},
|
||||
"cowlib": {:hex, :cowlib, "2.13.0", "db8f7505d8332d98ef50a3ef34b34c1afddec7506e4ee4dd4a3a266285d282ca", [:make, :rebar3], [], "hexpm", "e1e1284dc3fc030a64b1ad0d8382ae7e99da46c3246b815318a4b848873800a4"},
|
||||
"earmark": {:hex, :earmark, "1.4.46", "8c7287bd3137e99d26ae4643e5b7ef2129a260e3dcf41f251750cb4563c8fb81", [:mix], [], "hexpm", "798d86db3d79964e759ddc0c077d5eb254968ed426399fbf5a62de2b5ff8910a"},
|
||||
"earmark_parser": {:hex, :earmark_parser, "1.4.39", "424642f8335b05bb9eb611aa1564c148a8ee35c9c8a8bba6e129d51a3e3c6769", [:mix], [], "hexpm", "06553a88d1f1846da9ef066b87b57c6f605552cfbe40d20bd8d59cc6bde41944"},
|
||||
"ex_doc": {:hex, :ex_doc, "0.34.1", "9751a0419bc15bc7580c73fde506b17b07f6402a1e5243be9e0f05a68c723368", [:mix], [{:earmark_parser, "~> 1.4.39", [hex: :earmark_parser, repo: "hexpm", optional: false]}, {:makeup_c, ">= 0.1.0", [hex: :makeup_c, repo: "hexpm", optional: true]}, {:makeup_elixir, "~> 0.14 or ~> 1.0", [hex: :makeup_elixir, repo: "hexpm", optional: false]}, {:makeup_erlang, "~> 0.1 or ~> 1.0", [hex: :makeup_erlang, repo: "hexpm", optional: false]}, {:makeup_html, ">= 0.1.0", [hex: :makeup_html, repo: "hexpm", optional: true]}], "hexpm", "d441f1a86a235f59088978eff870de2e815e290e44a8bd976fe5d64470a4c9d2"},
|
||||
"exjsx": {:hex, :exjsx, "4.0.0", "60548841e0212df401e38e63c0078ec57b33e7ea49b032c796ccad8cde794b5c", [:mix], [{:jsx, "~> 2.8.0", [hex: :jsx, repo: "hexpm", optional: false]}], "hexpm", "32e95820a97cffea67830e91514a2ad53b888850442d6d395f53a1ac60c82e07"},
|
||||
"jsx": {:hex, :jsx, "2.8.3", "a05252d381885240744d955fbe3cf810504eb2567164824e19303ea59eef62cf", [:mix, :rebar3], [], "hexpm", "fc3499fed7a726995aa659143a248534adc754ebd16ccd437cd93b649a95091f"},
|
||||
"makeup": {:hex, :makeup, "1.0.5", "d5a830bc42c9800ce07dd97fa94669dfb93d3bf5fcf6ea7a0c67b2e0e4a7f26c", [:mix], [{:nimble_parsec, "~> 0.5 or ~> 1.0", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "cfa158c02d3f5c0c665d0af11512fed3fba0144cf1aadee0f2ce17747fba2ca9"},
|
||||
"makeup_elixir": {:hex, :makeup_elixir, "0.15.1", "b5888c880d17d1cc3e598f05cdb5b5a91b7b17ac4eaf5f297cb697663a1094dd", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}, {:nimble_parsec, "~> 1.1", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "db68c173234b07ab2a07f645a5acdc117b9f99d69ebf521821d89690ae6c6ec8"},
|
||||
"makeup_erlang": {:hex, :makeup_erlang, "0.1.1", "3fcb7f09eb9d98dc4d208f49cc955a34218fc41ff6b84df7c75b3e6e533cc65f", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}], "hexpm", "174d0809e98a4ef0b3309256cbf97101c6ec01c4ab0b23e926a9e17df2077cbb"},
|
||||
"meck": {:hex, :meck, "0.8.13", "ffedb39f99b0b99703b8601c6f17c7f76313ee12de6b646e671e3188401f7866", [:rebar3], [], "hexpm", "d34f013c156db51ad57cc556891b9720e6a1c1df5fe2e15af999c84d6cebeb1a"},
|
||||
"nimble_parsec": {:hex, :nimble_parsec, "1.1.0", "3a6fca1550363552e54c216debb6a9e95bd8d32348938e13de5eda962c0d7f89", [:mix], [], "hexpm", "08eb32d66b706e913ff748f11694b17981c0b04a33ef470e33e11b3d3ac8f54b"},
|
||||
"ranch": {:hex, :ranch, "1.7.1", "6b1fab51b49196860b733a49c07604465a47bdb78aa10c1c16a3d199f7f8c881", [:rebar3], [], "hexpm", "451d8527787df716d99dc36162fca05934915db0b6141bbdac2ea8d3c7afc7d7"},
|
||||
"makeup": {:hex, :makeup, "1.1.2", "9ba8837913bdf757787e71c1581c21f9d2455f4dd04cfca785c70bbfff1a76a3", [:mix], [{:nimble_parsec, "~> 1.2.2 or ~> 1.3", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "cce1566b81fbcbd21eca8ffe808f33b221f9eee2cbc7a1706fc3da9ff18e6cac"},
|
||||
"makeup_elixir": {:hex, :makeup_elixir, "0.16.2", "627e84b8e8bf22e60a2579dad15067c755531fea049ae26ef1020cad58fe9578", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}, {:nimble_parsec, "~> 1.2.3 or ~> 1.3", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "41193978704763f6bbe6cc2758b84909e62984c7752b3784bd3c218bb341706b"},
|
||||
"makeup_erlang": {:hex, :makeup_erlang, "1.0.0", "6f0eff9c9c489f26b69b61440bf1b238d95badae49adac77973cbacae87e3c2e", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}], "hexpm", "ea7a9307de9d1548d2a72d299058d1fd2339e3d398560a0e46c27dab4891e4d2"},
|
||||
"meck": {:hex, :meck, "0.9.2", "85ccbab053f1db86c7ca240e9fc718170ee5bda03810a6292b5306bf31bae5f5", [:rebar3], [], "hexpm", "81344f561357dc40a8344afa53767c32669153355b626ea9fcbc8da6b3045826"},
|
||||
"nimble_parsec": {:hex, :nimble_parsec, "1.4.0", "51f9b613ea62cfa97b25ccc2c1b4216e81df970acd8e16e8d1bdc58fef21370d", [:mix], [], "hexpm", "9c565862810fb383e9838c1dd2d7d2c437b3d13b267414ba6af33e50d2d1cf28"},
|
||||
"ranch": {:hex, :ranch, "1.8.0", "8c7a100a139fd57f17327b6413e4167ac559fbc04ca7448e9be9057311597a1d", [:make, :rebar3], [], "hexpm", "49fbcfd3682fab1f5d109351b61257676da1a2fdbe295904176d5e521a2ddfe5"},
|
||||
"telemetry": {:hex, :telemetry, "1.2.1", "68fdfe8d8f05a8428483a97d7aab2f268aaff24b49e0f599faa091f1d4e7f61c", [:rebar3], [], "hexpm", "dad9ce9d8effc621708f99eac538ef1cbe05d6a874dd741de2e689c47feafed5"},
|
||||
}
|
||||
|
|
|
@ -1,16 +1,27 @@
|
|||
-----BEGIN CERTIFICATE-----
|
||||
MIICeDCCAeGgAwIBAgIJAOvpU0y2e5J4MA0GCSqGSIb3DQEBBQUAMFUxCzAJBgNV
|
||||
BAYTAlVTMQ4wDAYDVQQIDAVUZXhhczETMBEGA1UECgwKTmluZSBOaW5lczEPMA0G
|
||||
A1UECwwGQ293Ym95MRAwDgYDVQQDDAdST09UIENBMB4XDTEzMDIyODA1MTAwMVoX
|
||||
DTMzMDIyMzA1MTAwMVowVTELMAkGA1UEBhMCVVMxDjAMBgNVBAgMBVRleGFzMRMw
|
||||
EQYDVQQKDApOaW5lIE5pbmVzMQ8wDQYDVQQLDAZDb3dib3kxEDAOBgNVBAMMB1JP
|
||||
T1QgQ0EwgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAMzmY7Us06yjyUbpqwPx
|
||||
Iv+xh/g3V7we07ClC9GEYnvr3OQvdA1jFEHccMBUUjRoQ8DPd6uSyK5UkixABs08
|
||||
Tt5B3VsnGKr0DIN+IO4SN2PkmBqIU/BN3KdcwN65YNr3iM0KsKWeFtAZdYx4CakX
|
||||
7REbO0wjK20AH3xSBn3uFGiBAgMBAAGjUDBOMB0GA1UdDgQWBBRKfZ8KF2jlLBDm
|
||||
NL6IuEuGY0pdbzAfBgNVHSMEGDAWgBRKfZ8KF2jlLBDmNL6IuEuGY0pdbzAMBgNV
|
||||
HRMEBTADAQH/MA0GCSqGSIb3DQEBBQUAA4GBAG1I0kBxXiLkM1b7rl2zPLizREYg
|
||||
1m+ajb6rWzPOBg6TXjv58Be+H4tqoHIL/M/crixew5emftBkuAGjiKMhbIokjvan
|
||||
aPTCV8U6HHvNvz9c68HpESWbd+56cHqfsS5XCKp1OpW5tbL2UQYpFKMP4qmbv3Ea
|
||||
pBfPPmSFMBb1i2AI
|
||||
MIIEqjCCAxKgAwIBAgIRANXKM01Lqak+6N93VnHgkl4wDQYJKoZIhvcNAQELBQAw
|
||||
bTEeMBwGA1UEChMVbWtjZXJ0IGRldmVsb3BtZW50IENBMSEwHwYDVQQLDBhlZHVh
|
||||
cmRvQHBvcC1vcyAoRWR1YXJkbykxKDAmBgNVBAMMH21rY2VydCBlZHVhcmRvQHBv
|
||||
cC1vcyAoRWR1YXJkbykwHhcNMjQwNjIzMDU1MzA0WhcNMzQwNjIzMDU1MzA0WjBt
|
||||
MR4wHAYDVQQKExVta2NlcnQgZGV2ZWxvcG1lbnQgQ0ExITAfBgNVBAsMGGVkdWFy
|
||||
ZG9AcG9wLW9zIChFZHVhcmRvKTEoMCYGA1UEAwwfbWtjZXJ0IGVkdWFyZG9AcG9w
|
||||
LW9zIChFZHVhcmRvKTCCAaIwDQYJKoZIhvcNAQEBBQADggGPADCCAYoCggGBAK6p
|
||||
DThGWoUHwCVf8DqHDFthUTvNIKRJzyxArh4GF71dHehiLVBZQ9i/jA1nRASzsVcu
|
||||
UGyZT18N+XvCCeoPevHXOPjUJZtMkhPqlt55N9gzrniEsmRRQOPzIt8+BiFjJ5Jn
|
||||
RzRD9S+9AwNIaZKUjiQ1Oexxgvd7pbWy3S/IzXCyFsKIZqYcvvpBY6FroDSEZbrk
|
||||
xMA4Fhvy2370nTrlKzuoVTGZ8WdHOsh7Ef+mCZp1QwTtCkIPHdCa3OMs5F7u4q8P
|
||||
tB4QgaWnvEmRtDwsst/CCQr4nIrQzjDwCMS41x0DZwMrQ8lzSjnAHxayWoll9aJK
|
||||
38jaDviT9qvnIjjdMHN9jJ7fDBZeonrGqdGSs/754oxpSFAiErpBY6dPGYgzkjQM
|
||||
IxKi4zqYW9ZWPSYacAmRwZsYWp50tvtwxtdY63GslFrnVjtG7e+H1rJJWsQ2Eq5w
|
||||
sQekS/EqOpufBuoildwGMiyW1CEhXezW5lCiA++kyA6DkVA2zQRi0huJ4LPvDQID
|
||||
AQABo0UwQzAOBgNVHQ8BAf8EBAMCAgQwEgYDVR0TAQH/BAgwBgEB/wIBADAdBgNV
|
||||
HQ4EFgQUSGXO0OyaSJ4ztTJkQt8atnaqe7MwDQYJKoZIhvcNAQELBQADggGBAA6c
|
||||
pCJO1U2S79McbKZylJ13Nv+qMSWvTF5ax+/tSahAgvauaQiDInLa9wOUHfiTqNwH
|
||||
q42UUexfm04Yre+R9NR9jOVHCFwT9uq3MOPKDuRS3UUUCCUjy0b0CSDc1uCi9BGu
|
||||
jykYViGNCDvTeOI8AZfIEtD77TGJt/8kn7Z6Qe9EFe1N+k8PtbFJgt1/rjIOtFz0
|
||||
638iHBSky+U4ozznxQmwwseR3KSSNS0JWQDxm/gWqy4MP1m0pW5Pd543ms2BPUzO
|
||||
2P1PkEV4jz8J4j2C3EctdoiCudqa8BCFMXIE+t/hKQ+LgbW6phoIN6DLp65Yhs7Z
|
||||
DHPq64f8005EXB8GDHLoP/HL/wnO60e+hjjvsumvCWc7EZeZiHl2QwFMQ6csExeZ
|
||||
9bky+h1WiQeV2poEyJSPOVAXThaxf3GOV+V/zrnY+DHNio/IRa4Z+/1Fwxs26+o7
|
||||
Qnkf9UqSZrKr/B7ilQ/Cb1sv3dLzIPAmfNuDjqPWb4eYT+B26n264znHlhvmWw==
|
||||
-----END CERTIFICATE-----
|
||||
|
|
|
@ -1,17 +1,26 @@
|
|||
-----BEGIN CERTIFICATE-----
|
||||
MIICpTCCAg6gAwIBAgIJAOvpU0y2e5J5MA0GCSqGSIb3DQEBBQUAMFUxCzAJBgNV
|
||||
BAYTAlVTMQ4wDAYDVQQIDAVUZXhhczETMBEGA1UECgwKTmluZSBOaW5lczEPMA0G
|
||||
A1UECwwGQ293Ym95MRAwDgYDVQQDDAdST09UIENBMB4XDTEzMDIyODA1MjMzNFoX
|
||||
DTMzMDIyMzA1MjMzNFowVzELMAkGA1UEBhMCVVMxDjAMBgNVBAgMBVRleGFzMRMw
|
||||
EQYDVQQKDApOaW5lIE5pbmVzMQ8wDQYDVQQLDAZDb3dib3kxEjAQBgNVBAMMCWxv
|
||||
Y2FsaG9zdDCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAzbW1GjECzHUc/WST
|
||||
qLiAGqjCNccR5saVS+yoz2SPRhpoyf0/qBrX5BY0tzmgozoTiRfE4wCiVD99Cc+D
|
||||
rp/FM49r4EpZdocIovprmOmv/gwkoj95zaA6PKNn1OdmDp2hwJsX2Zm3kpbGUZTx
|
||||
jDkkccmgUb4EjL7qNHq7saQtivUCAwEAAaN7MHkwCQYDVR0TBAIwADAsBglghkgB
|
||||
hvhCAQ0EHxYdT3BlblNTTCBHZW5lcmF0ZWQgQ2VydGlmaWNhdGUwHQYDVR0OBBYE
|
||||
FB6jTEIWI8T1ckORA4GezbyYxtbvMB8GA1UdIwQYMBaAFEp9nwoXaOUsEOY0voi4
|
||||
S4ZjSl1vMA0GCSqGSIb3DQEBBQUAA4GBACMboVQjrx8u/fk3gl/sR0tbA0Wf/NcS
|
||||
2Dzsy2czndgVUAG4Sqb+hfgn0dqAyUKghRrj3JDcYxYksGPIklDfPzZb7yJ39l16
|
||||
6x5ZiIzhp8CAVdPvRxRznw5rZwaXesryXu1jVSZxTr3MYZdkG6KaAM0t90+YlGLZ
|
||||
UG8fAicx0Bf+
|
||||
MIIEZTCCAs2gAwIBAgIQIJarIG+LC7mjP0IRrFcI0zANBgkqhkiG9w0BAQsFADBt
|
||||
MR4wHAYDVQQKExVta2NlcnQgZGV2ZWxvcG1lbnQgQ0ExITAfBgNVBAsMGGVkdWFy
|
||||
ZG9AcG9wLW9zIChFZHVhcmRvKTEoMCYGA1UEAwwfbWtjZXJ0IGVkdWFyZG9AcG9w
|
||||
LW9zIChFZHVhcmRvKTAeFw0yNDA2MjMwNTU0MTBaFw0yNjA5MjMwNTU0MTBaMEwx
|
||||
JzAlBgNVBAoTHm1rY2VydCBkZXZlbG9wbWVudCBjZXJ0aWZpY2F0ZTEhMB8GA1UE
|
||||
CwwYZWR1YXJkb0Bwb3Atb3MgKEVkdWFyZG8pMIIBIjANBgkqhkiG9w0BAQEFAAOC
|
||||
AQ8AMIIBCgKCAQEAx8lf20sm9KkWh/u6ehJ4YpDlx7DGaebBok3JR6rdV42c9flu
|
||||
pXdi0Uu7tq4utk4rGu6gotIlPFDeRxokqNIaCUmpIW2msG6KzPBp2Lf+AR0EbdQS
|
||||
EvqiMLx5dU3yEafGKeH1z4qMobhEWIWU9F0V8zuuJvCeHRCdBkse1XQ64X6gyN1m
|
||||
5lYEEIlGfOj7rrAFdCkv63W5dUeph9yoIF//T9yhTx0yNGUeCOuqQEL5HsSdD6HL
|
||||
hqIsjmlI33uHWJd9fr72ZTjmxawRca3tS4ljR6QeZw8zE51lh5P4f1pTGa2vUPxX
|
||||
A11O8jmuXkflgLyDNlm1Pob0tuoNOpa2Zi+mAQIDAQABo4GhMIGeMA4GA1UdDwEB
|
||||
/wQEAwIFoDATBgNVHSUEDDAKBggrBgEFBQcDATAfBgNVHSMEGDAWgBRIZc7Q7JpI
|
||||
njO1MmRC3xq2dqp7szBWBgNVHREETzBNggtleGFtcGxlLmNvbYINKi5leGFtcGxl
|
||||
LmNvbYIMZXhhbXBsZS50ZXN0gglsb2NhbGhvc3SHBH8AAAGHEAAAAAAAAAAAAAAA
|
||||
AAAAAAEwDQYJKoZIhvcNAQELBQADggGBAKuzr0Vb6NZV5XlByLgMb1sddIhl3DWq
|
||||
RGcAf556am51zvZQFz9W/SBm0Ww7+W1fLx7lasyawsxNhfgNHgP05WKZqghodqIw
|
||||
1tQJAu8PRuXClrvADUnvMz4a3ELCkygSZNn1Oo84YXssEBe1vy70ZTGZS8hhq5qJ
|
||||
uKTwN0/UtJXXF0dapd4T+N0kuWuoB1xsf7U9Hdn0Bmw5idWe+U2xvb4/Eo0rPUKa
|
||||
+GJafosfJ17zV5D4oUbuf1uPg8MqQJzEcQDEOcVDgds7tyy3A3igQ+v1WYDkUcUZ
|
||||
IfOoQxMfHF7mGDbAETGnn0pSRztgKdobpg7MItbdiI04XSIwgGZL4puLJZfSkRDC
|
||||
ZLqZk9JJc8DpLRjGmH7lRcKkq8TkbrKGsYOQ3bWV6rLP1xH++rE7Sld7P8bLhapQ
|
||||
hIwcy1rg38v6u2OmApfEbp+VBa62h7RqBDsW0JSNo8Ut1d0VS2HxHMNZ+pr0WVqO
|
||||
nGcNj0IS+dchbyqN7WF4X9h1iqD09qWeaw==
|
||||
-----END CERTIFICATE-----
|
||||
|
|
|
@ -1,15 +1,28 @@
|
|||
-----BEGIN RSA PRIVATE KEY-----
|
||||
MIICXQIBAAKBgQDNtbUaMQLMdRz9ZJOouIAaqMI1xxHmxpVL7KjPZI9GGmjJ/T+o
|
||||
GtfkFjS3OaCjOhOJF8TjAKJUP30Jz4Oun8Uzj2vgSll2hwii+muY6a/+DCSiP3nN
|
||||
oDo8o2fU52YOnaHAmxfZmbeSlsZRlPGMOSRxyaBRvgSMvuo0eruxpC2K9QIDAQAB
|
||||
AoGAaD85c/h6bpq7Aj7CBbLaWKhFI3OqwsTITB22vsM7SE+B4zsP02UnG1OVi3UM
|
||||
zytTUxpUkKV1njQ+bYZYOVqGWF4Up8tTqUglHn0FTPok1AIemELWtz3sXvdSHC1T
|
||||
lqvFBAZ9kibn13qGyVOiyCFaMwfOM/05RvV7p3jfUMTWnNECQQDs7yCJZ8Ol8MyH
|
||||
TGZzvkjoN2zg1KwmTbSD1hkP6QAJtPdRuqFbjlEru0/PefgOXsWLRIa3/3v0qw2G
|
||||
xGkV6AXTAkEA3kNbFisqUydjPnZIYv/P6SvPdUimHJEjXbAbfNfzS9dzszrOVJd2
|
||||
XqGH7z5yzjoH3IyaIMW8GnubVzGDSjrHFwJAKSU5vELlygpwKkrNO+pelN0TLlQg
|
||||
dSJnZ8GlZorq88SWcn37iX/EftivenNO7YftvEqxLoDSkOGnnrC7Iw/A+wJBAIEe
|
||||
L/QY72WPJCBNJpAce/PA96vyoE1II3txqwZDjZspdpVQPDz4IFOpEwbxCFC1dYuy
|
||||
Qnd3Z2cbF4r3wIWGz9ECQQCJGNhUNtY+Om1ELdqPcquxE2VRV/pucnvJSTKwyo2C
|
||||
Rvm6H7kFDwPDuN23YnTOlTiho0zzCkclcIukhIVJ+dKz
|
||||
-----END RSA PRIVATE KEY-----
|
||||
-----BEGIN PRIVATE KEY-----
|
||||
MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQDHyV/bSyb0qRaH
|
||||
+7p6EnhikOXHsMZp5sGiTclHqt1XjZz1+W6ld2LRS7u2ri62Tisa7qCi0iU8UN5H
|
||||
GiSo0hoJSakhbaawborM8GnYt/4BHQRt1BIS+qIwvHl1TfIRp8Yp4fXPioyhuERY
|
||||
hZT0XRXzO64m8J4dEJ0GSx7VdDrhfqDI3WbmVgQQiUZ86PuusAV0KS/rdbl1R6mH
|
||||
3KggX/9P3KFPHTI0ZR4I66pAQvkexJ0PocuGoiyOaUjfe4dYl31+vvZlOObFrBFx
|
||||
re1LiWNHpB5nDzMTnWWHk/h/WlMZra9Q/FcDXU7yOa5eR+WAvIM2WbU+hvS26g06
|
||||
lrZmL6YBAgMBAAECggEAY2zlJnZdGa84hk4RfITKoornv5xK8hMj1EkP3Xm8E8Fn
|
||||
FsaeePxUEkK1VXGTz6hRLWMKUF1yqHS6Wfo5ukZtLKga4ob2SKGKs/kFRBQ09Yri
|
||||
VGIQ6J8Qrl5tt6Il0QGEzf0k3rddy3GvmbpI6d+Vd+oAfmKK3X4SFzq1SpdAYk1H
|
||||
RcC+VLfu60v7yFMtk0IMKMvtXBNY4TPmvJFKv439mLDyIRA5Dsk8P6TZrf473PVJ
|
||||
JpofVVIKtug8z++CFojhiQYX2bcyIxHWdbUer/snJq4UV+0pOjVYqtB+cVjToBSV
|
||||
BGNcR+qe8Sg0HXVjpSpKUl3d3GOmCTjKeFzHbu4yTQKBgQD498zP1pW4jH1RVxo8
|
||||
RVsZWKmZip7iD9MhrUakMW9G9pUrWzl6DG7Na8pnYi5TsZXXak/f5sWhhCPxkae0
|
||||
0x4Pp7qnSqPvGuTMZQsuG8bvFBWg5XwwrLbx8AzKQ6WggnRumamV5KEwQ8pHMa20
|
||||
b2fZWPEn3KNR5LASzp9QW3cS2wKBgQDNbfYZOmrEAZw9c53VJG9S1JiqClYHg99T
|
||||
oTlklsfdNfot78odTto29LO9Tr997ZX0w93jDrxSdLyyiIdZEDVSSkbS3HSdSjfm
|
||||
nqwlogNXf5TnH88j+EkVvQWs63Q7lyrFNcEftT44ebYXH5ehzPkVbKlocztY0AWw
|
||||
iVgD8AlrUwKBgQCHE8L+fJks0KRpTk3Ap4x+mvkhgfEkC5vsaJusF9oc8UoLhOoR
|
||||
Ss+PCk19e+pQpEf84QRHIWjWceAif3kzBVwI+GKvwzJgVwIN10CSmqV7LzVw3zFb
|
||||
I0n6x9fYoY0qIb1UCHDXD31Yt17284AgJlV8ueHVU8MUenQBMDOFoKphAwKBgGGc
|
||||
/5SLSpIqhbg5iOTvtCoytPwPf0OA6QyPDnt6nivB60gKqgp1HoGAkyvAEIPg8iFl
|
||||
NLkglmHD8KoQ7+dlKUEZ5D9r28mlq5xdB0W2j0nzaKjOV5oq72dx8xFwrEFomj0t
|
||||
RsAvWgpx4xFnxKBwimcgw/rKzodsCVgSWw078O3bAoGBAOyz3sgE9c6mv5jwg2bt
|
||||
59rqGfHZizMRH0gxiC8P1Ui9dlZfnvdeBLUR/FD6XBSb450vRdcgG4AQ+HPECKkb
|
||||
kECHkBb542ymb/GqgutNLPzQ8n0Q1zO92CSX5KKmY2B+lEfer5NSc2c9gY261YMH
|
||||
AApeuDGbws/XXVLWnR1fGbH0
|
||||
-----END PRIVATE KEY-----
|
||||
|
|
|
@ -4,8 +4,8 @@ defmodule HTTParrot.Base64HandlerTest do
|
|||
import HTTParrot.Base64Handler
|
||||
|
||||
setup do
|
||||
new :cowboy_req
|
||||
on_exit fn -> unload() end
|
||||
new(:cowboy_req)
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
|
|
|
@ -4,32 +4,33 @@ defmodule HTTParrot.BasicAuthHandlerTest do
|
|||
import HTTParrot.BasicAuthHandler
|
||||
|
||||
setup do
|
||||
new :cowboy_req
|
||||
new JSX
|
||||
on_exit fn -> unload() end
|
||||
new(:cowboy_req)
|
||||
new(JSX)
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
test "is_authorized returns true if user and passwd match" do
|
||||
expect(:cowboy_req, :binding, [{[:user, :req1], :user},
|
||||
{[:passwd, :req1], :passwd}])
|
||||
expect(:cowboy_req, :binding, [{[:user, :req1], :user}, {[:passwd, :req1], :passwd}])
|
||||
expect(:cowboy_req, :parse_header, [{["authorization", :req1], {:basic, :user, :passwd}}])
|
||||
|
||||
assert is_authorized(:req1, :state) == {true, :req1, :user}
|
||||
|
||||
assert validate :cowboy_req
|
||||
assert validate JSX
|
||||
assert validate(:cowboy_req)
|
||||
assert validate(JSX)
|
||||
end
|
||||
|
||||
test "is_authorized returns false if user and passwd doesn't match" do
|
||||
expect(:cowboy_req, :binding, [{[:user, :req1], :user},
|
||||
{[:passwd, :req1], :passwd}])
|
||||
expect(:cowboy_req, :parse_header, [{["authorization", :req1], {:basic, :not_the_user, :passwd}}])
|
||||
test "is_authorized returns false if user and passwd doesnt match" do
|
||||
expect(:cowboy_req, :binding, [{[:user, :req1], :user}, {[:passwd, :req1], :passwd}])
|
||||
|
||||
expect(:cowboy_req, :parse_header, [
|
||||
{["authorization", :req1], {:basic, :not_the_user, :passwd}}
|
||||
])
|
||||
|
||||
assert is_authorized(:req1, :state) == {{false, "Basic realm=\"Fake Realm\""}, :req1, :state}
|
||||
|
||||
assert validate :cowboy_req
|
||||
assert validate JSX
|
||||
assert validate(:cowboy_req)
|
||||
assert validate(JSX)
|
||||
end
|
||||
|
||||
test "returns user and if it's authenticated" do
|
||||
|
@ -37,6 +38,6 @@ defmodule HTTParrot.BasicAuthHandlerTest do
|
|||
|
||||
assert get_json(:req1, :user) == {:json, :req1, nil}
|
||||
|
||||
assert validate JSX
|
||||
assert validate(JSX)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -4,9 +4,9 @@ defmodule HTTParrot.CacheHandlerTest do
|
|||
import HTTParrot.CacheHandler
|
||||
|
||||
setup do
|
||||
new HTTParrot.GeneralRequestInfo
|
||||
new JSX
|
||||
on_exit fn -> unload() end
|
||||
new(HTTParrot.GeneralRequestInfo)
|
||||
new(JSX)
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
|
@ -16,7 +16,7 @@ defmodule HTTParrot.CacheHandlerTest do
|
|||
|
||||
assert get_json(:req1, :state) == {:json, :req2, :state}
|
||||
|
||||
assert validate HTTParrot.GeneralRequestInfo
|
||||
assert validate JSX
|
||||
assert validate(HTTParrot.GeneralRequestInfo)
|
||||
assert validate(JSX)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -4,9 +4,9 @@ defmodule HTTParrot.DeflateHandlerTest do
|
|||
import HTTParrot.DeflateHandler
|
||||
|
||||
setup do
|
||||
new HTTParrot.GeneralRequestInfo
|
||||
new JSX
|
||||
on_exit fn -> unload() end
|
||||
new(HTTParrot.GeneralRequestInfo)
|
||||
new(JSX)
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
|
@ -16,15 +16,15 @@ defmodule HTTParrot.DeflateHandlerTest do
|
|||
expect(JSX, :prettify!, [{[:json], "json"}])
|
||||
expect(:cowboy_req, :set_resp_header, 3, :req3)
|
||||
|
||||
opened_zlib = :zlib.open
|
||||
opened_zlib = :zlib.open()
|
||||
:zlib.deflateInit(opened_zlib)
|
||||
body = :zlib.deflate(opened_zlib, "json", :finish)
|
||||
:zlib.deflateEnd(opened_zlib)
|
||||
|
||||
assert get_json(:req1, :state) == {body, :req3, :state}
|
||||
|
||||
assert validate HTTParrot.GeneralRequestInfo
|
||||
assert validate JSX
|
||||
assert validate :cowboy_req
|
||||
assert validate(HTTParrot.GeneralRequestInfo)
|
||||
assert validate(JSX)
|
||||
assert validate(:cowboy_req)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -4,10 +4,10 @@ defmodule HTTParrot.DeleteHandlerTest do
|
|||
import HTTParrot.DeleteHandler
|
||||
|
||||
setup do
|
||||
new :cowboy_req
|
||||
new HTTParrot.GeneralRequestInfo
|
||||
new JSX
|
||||
on_exit fn -> unload() end
|
||||
new(:cowboy_req)
|
||||
new(HTTParrot.GeneralRequestInfo)
|
||||
new(JSX)
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
|
@ -18,8 +18,8 @@ defmodule HTTParrot.DeleteHandlerTest do
|
|||
|
||||
assert delete_resource(:req1, :state) == {true, :req3, :state}
|
||||
|
||||
assert validate :cowboy_req
|
||||
assert validate HTTParrot.GeneralRequestInfo
|
||||
assert validate JSX
|
||||
assert validate(:cowboy_req)
|
||||
assert validate(HTTParrot.GeneralRequestInfo)
|
||||
assert validate(JSX)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -4,9 +4,9 @@ defmodule HTTParrot.GetHandlerTest do
|
|||
import HTTParrot.GetHandler
|
||||
|
||||
setup do
|
||||
new HTTParrot.GeneralRequestInfo
|
||||
new JSX
|
||||
on_exit fn -> unload() end
|
||||
new(HTTParrot.GeneralRequestInfo)
|
||||
new(JSX)
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
|
@ -16,7 +16,7 @@ defmodule HTTParrot.GetHandlerTest do
|
|||
|
||||
assert get_json(:req1, :state) == {:json, :req2, :state}
|
||||
|
||||
assert validate HTTParrot.GeneralRequestInfo
|
||||
assert validate JSX
|
||||
assert validate(HTTParrot.GeneralRequestInfo)
|
||||
assert validate(JSX)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -4,9 +4,9 @@ defmodule HTTParrot.GzipHandlerTest do
|
|||
import HTTParrot.GzipHandler
|
||||
|
||||
setup do
|
||||
new HTTParrot.GeneralRequestInfo
|
||||
new JSX
|
||||
on_exit fn -> unload() end
|
||||
new(HTTParrot.GeneralRequestInfo)
|
||||
new(JSX)
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
|
@ -20,8 +20,8 @@ defmodule HTTParrot.GzipHandlerTest do
|
|||
|
||||
assert get_json(:req1, :state) == {body, :req3, :state}
|
||||
|
||||
assert validate HTTParrot.GeneralRequestInfo
|
||||
assert validate JSX
|
||||
assert validate :cowboy_req
|
||||
assert validate(HTTParrot.GeneralRequestInfo)
|
||||
assert validate(JSX)
|
||||
assert validate(:cowboy_req)
|
||||
end
|
||||
end
|
||||
|
|
|
@ -11,10 +11,10 @@ defmodule HTTParrotTest do
|
|||
|
||||
test "'prettify_json' prettifies body response if it's a JSON" do
|
||||
expect(:cowboy_req, :reply, [
|
||||
{[:status, %{"content-length" => '14'}, "{\n \"a\": \"b\"\n}", :req1], :req2}
|
||||
{[:status, %{"content-length" => ~c"14"}, "{\n \"a\": \"b\"\n}", :req1], :req2}
|
||||
])
|
||||
|
||||
assert prettify_json(:status, %{"content-length" => '12'}, "{\"a\":\"b\"}", :req1) == :req2
|
||||
assert prettify_json(:status, %{"content-length" => ~c"12"}, "{\"a\":\"b\"}", :req1) == :req2
|
||||
assert validate(:cowboy_req)
|
||||
end
|
||||
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
defmodule HTTParrot.RequestStoreTest do
|
||||
alias HTTParrot.RequestStore
|
||||
use ExUnit.Case
|
||||
|
||||
test "save, retrieve, clear" do
|
||||
request = %{req: 1}
|
||||
RequestStore.clear(:test)
|
||||
|
|
|
@ -5,7 +5,7 @@ defmodule HTTParrot.RetrieveRequestHandlerTests do
|
|||
|
||||
setup do
|
||||
HTTParrot.RequestStore.clear(:test)
|
||||
on_exit fn -> unload() end
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
|
|
|
@ -12,15 +12,15 @@ defmodule HTTParrot.StoreRequestHandlerTests do
|
|||
test "store a request" do
|
||||
expect(:cowboy_req, :binding, [:key, :req1], :test)
|
||||
expect(HTTParrot.GeneralRequestInfo, :retrieve, 1, {:info, :req1})
|
||||
assert get(:req1, :state) == {'{"saved": "true"}', :req1, :state}
|
||||
assert get(:req1, :state) == {~c'{"saved": "true"}', :req1, :state}
|
||||
assert HTTParrot.RequestStore.retrieve(:test) == [:info]
|
||||
end
|
||||
|
||||
test "store multiple requests" do
|
||||
expect(:cowboy_req, :binding, [:key, :req1], :test)
|
||||
expect(HTTParrot.GeneralRequestInfo, :retrieve, 1, {:info, :req1})
|
||||
assert get(:req1, :state) == {'{"saved": "true"}', :req1, :state}
|
||||
assert get(:req2, :state) == {'{"saved": "true"}', :req1, :state}
|
||||
assert get(:req1, :state) == {~c'{"saved": "true"}', :req1, :state}
|
||||
assert get(:req2, :state) == {~c'{"saved": "true"}', :req1, :state}
|
||||
assert HTTParrot.RequestStore.retrieve(:test) == [:info, :info]
|
||||
end
|
||||
end
|
||||
|
|
|
@ -4,9 +4,9 @@ defmodule HTTParrot.UserAgentHandlerTest do
|
|||
import HTTParrot.UserAgentHandler
|
||||
|
||||
setup do
|
||||
new :cowboy_req
|
||||
new JSX
|
||||
on_exit fn -> unload() end
|
||||
new(:cowboy_req)
|
||||
new(JSX)
|
||||
on_exit(fn -> unload() end)
|
||||
:ok
|
||||
end
|
||||
|
||||
|
@ -16,7 +16,7 @@ defmodule HTTParrot.UserAgentHandlerTest do
|
|||
|
||||
assert get_json(:req1, :state) == {:json, :req1, :state}
|
||||
|
||||
assert validate :cowboy_req
|
||||
assert validate JSX
|
||||
assert validate(:cowboy_req)
|
||||
assert validate(JSX)
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Reference in a new issue