Refactor specs
This commit is contained in:
parent
f464ab6d4f
commit
87df71a89a
7 changed files with 62 additions and 98 deletions
|
@ -26,6 +26,6 @@ describe "Config" do
|
||||||
it "adds a custom handler" do
|
it "adds a custom handler" do
|
||||||
config = Kemal.config
|
config = Kemal.config
|
||||||
config.add_handler CustomTestHandler.new
|
config.add_handler CustomTestHandler.new
|
||||||
config.handlers.size.should eq(1)
|
config.handlers.size.should eq(5)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -2,50 +2,42 @@ require "./spec_helper"
|
||||||
|
|
||||||
describe "Context" do
|
describe "Context" do
|
||||||
it "has a default content type" do
|
it "has a default content type" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do |env|
|
||||||
kemal.add_route "GET", "/" do |env|
|
|
||||||
"Hello"
|
"Hello"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/")
|
request = HTTP::Request.new("GET", "/")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.headers["Content-Type"].should eq("text/html")
|
client_response.headers["Content-Type"].should eq("text/html")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "sets content type" do
|
it "sets content type" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do |env|
|
||||||
kemal.add_route "GET", "/" do |env|
|
|
||||||
env.response.content_type = "application/json"
|
env.response.content_type = "application/json"
|
||||||
"Hello"
|
"Hello"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/")
|
request = HTTP::Request.new("GET", "/")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.headers["Content-Type"].should eq("application/json")
|
client_response.headers["Content-Type"].should eq("application/json")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "parses headers" do
|
it "parses headers" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do |env|
|
||||||
kemal.add_route "GET", "/" do |env|
|
|
||||||
name = env.request.headers["name"]
|
name = env.request.headers["name"]
|
||||||
"Hello #{name}"
|
"Hello #{name}"
|
||||||
end
|
end
|
||||||
headers = HTTP::Headers.new
|
headers = HTTP::Headers.new
|
||||||
headers["name"] = "kemal"
|
headers["name"] = "kemal"
|
||||||
request = HTTP::Request.new("GET", "/", headers)
|
request = HTTP::Request.new("GET", "/", headers)
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq "Hello kemal"
|
client_response.body.should eq "Hello kemal"
|
||||||
end
|
end
|
||||||
|
|
||||||
it "sets response headers" do
|
it "sets response headers" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do |env|
|
||||||
kemal.add_route "GET", "/" do |env|
|
|
||||||
env.response.headers.add "Accept-Language", "tr"
|
env.response.headers.add "Accept-Language", "tr"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/")
|
request = HTTP::Request.new("GET", "/")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.headers["Accept-Language"].should eq "tr"
|
client_response.headers["Accept-Language"].should eq "tr"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,7 +4,7 @@ describe "Macros" do
|
||||||
describe "#basic_auth" do
|
describe "#basic_auth" do
|
||||||
it "adds HTTPBasicAuthHandler" do
|
it "adds HTTPBasicAuthHandler" do
|
||||||
basic_auth "serdar", "123"
|
basic_auth "serdar", "123"
|
||||||
Kemal.config.handlers.size.should eq 1
|
Kemal.config.handlers.size.should eq 5
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ describe "Macros" do
|
||||||
describe "#add_handler" do
|
describe "#add_handler" do
|
||||||
it "adds a custom handler" do
|
it "adds a custom handler" do
|
||||||
add_handler CustomTestHandler.new
|
add_handler CustomTestHandler.new
|
||||||
Kemal.config.handlers.size.should eq 1
|
Kemal.config.handlers.size.should eq 5
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ describe "Macros" do
|
||||||
it "sets a custom logger" do
|
it "sets a custom logger" do
|
||||||
config = Kemal::Config::INSTANCE
|
config = Kemal::Config::INSTANCE
|
||||||
logger CustomLogHandler.new("production")
|
logger CustomLogHandler.new("production")
|
||||||
config.handlers.first.should be_a(CustomLogHandler)
|
config.handlers.last.should be_a(CustomLogHandler)
|
||||||
config.logger.should be_a(CustomLogHandler)
|
config.logger.should be_a(CustomLogHandler)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -2,52 +2,43 @@ require "./spec_helper"
|
||||||
|
|
||||||
describe "Kemal::RouteHandler" do
|
describe "Kemal::RouteHandler" do
|
||||||
it "routes" do
|
it "routes" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do
|
||||||
kemal.add_route "GET", "/" do
|
|
||||||
"hello"
|
"hello"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/")
|
request = HTTP::Request.new("GET", "/")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("hello")
|
client_response.body.should eq("hello")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "routes request with query string" do
|
it "routes request with query string" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do |env|
|
||||||
kemal.add_route "GET", "/" do |env|
|
|
||||||
"hello #{env.params.query["message"]}"
|
"hello #{env.params.query["message"]}"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/?message=world")
|
request = HTTP::Request.new("GET", "/?message=world")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("hello world")
|
client_response.body.should eq("hello world")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "routes request with multiple query strings" do
|
it "routes request with multiple query strings" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do |env|
|
||||||
kemal.add_route "GET", "/" do |env|
|
|
||||||
"hello #{env.params.query["message"]} time #{env.params.query["time"]}"
|
"hello #{env.params.query["message"]} time #{env.params.query["time"]}"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/?message=world&time=now")
|
request = HTTP::Request.new("GET", "/?message=world&time=now")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("hello world time now")
|
client_response.body.should eq("hello world time now")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "route parameter has more precedence than query string arguments" do
|
it "route parameter has more precedence than query string arguments" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/:message" do |env|
|
||||||
kemal.add_route "GET", "/:message" do |env|
|
|
||||||
"hello #{env.params.url["message"]}"
|
"hello #{env.params.url["message"]}"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/world?message=coco")
|
request = HTTP::Request.new("GET", "/world?message=coco")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("hello world")
|
client_response.body.should eq("hello world")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "parses simple JSON body" do
|
it "parses simple JSON body" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
post "/" do |env|
|
||||||
kemal.add_route "POST", "/" do |env|
|
|
||||||
name = env.params.json["name"]
|
name = env.params.json["name"]
|
||||||
age = env.params.json["age"]
|
age = env.params.json["age"]
|
||||||
"Hello #{name} Age #{age}"
|
"Hello #{name} Age #{age}"
|
||||||
|
@ -60,14 +51,12 @@ describe "Kemal::RouteHandler" do
|
||||||
body: json_payload.to_json,
|
body: json_payload.to_json,
|
||||||
headers: HTTP::Headers{"Content-Type": "application/json"},
|
headers: HTTP::Headers{"Content-Type": "application/json"},
|
||||||
)
|
)
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("Hello Serdar Age 26")
|
client_response.body.should eq("Hello Serdar Age 26")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "parses JSON with string array" do
|
it "parses JSON with string array" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
post "/" do |env|
|
||||||
kemal.add_route "POST", "/" do |env|
|
|
||||||
skills = env.params.json["skills"] as Array
|
skills = env.params.json["skills"] as Array
|
||||||
"Skills #{skills.each.join(',')}"
|
"Skills #{skills.each.join(',')}"
|
||||||
end
|
end
|
||||||
|
@ -79,14 +68,12 @@ describe "Kemal::RouteHandler" do
|
||||||
body: json_payload.to_json,
|
body: json_payload.to_json,
|
||||||
headers: HTTP::Headers{"Content-Type": "application/json"},
|
headers: HTTP::Headers{"Content-Type": "application/json"},
|
||||||
)
|
)
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("Skills ruby,crystal")
|
client_response.body.should eq("Skills ruby,crystal")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "parses JSON with json object array" do
|
it "parses JSON with json object array" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
post "/" do |env|
|
||||||
kemal.add_route "POST", "/" do |env|
|
|
||||||
skills = env.params.json["skills"] as Array
|
skills = env.params.json["skills"] as Array
|
||||||
skills_from_languages = skills.map do |skill|
|
skills_from_languages = skills.map do |skill|
|
||||||
skill = skill as Hash
|
skill = skill as Hash
|
||||||
|
@ -103,14 +90,12 @@ describe "Kemal::RouteHandler" do
|
||||||
headers: HTTP::Headers{"Content-Type": "application/json"},
|
headers: HTTP::Headers{"Content-Type": "application/json"},
|
||||||
)
|
)
|
||||||
|
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("Skills ruby,crystal")
|
client_response.body.should eq("Skills ruby,crystal")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "checks for _method param in POST request to simulate PUT" do
|
it "checks for _method param in POST request to simulate PUT" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
put "/" do |env|
|
||||||
kemal.add_route "PUT", "/" do |env|
|
|
||||||
"Hello World from PUT"
|
"Hello World from PUT"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new(
|
request = HTTP::Request.new(
|
||||||
|
@ -119,14 +104,12 @@ describe "Kemal::RouteHandler" do
|
||||||
body: "_method=PUT",
|
body: "_method=PUT",
|
||||||
headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded"}
|
headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded"}
|
||||||
)
|
)
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("Hello World from PUT")
|
client_response.body.should eq("Hello World from PUT")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "checks for _method param in POST request to simulate PATCH" do
|
it "checks for _method param in POST request to simulate PATCH" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
patch "/" do |env|
|
||||||
kemal.add_route "PATCH", "/" do |env|
|
|
||||||
"Hello World from PATCH"
|
"Hello World from PATCH"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new(
|
request = HTTP::Request.new(
|
||||||
|
@ -135,14 +118,12 @@ describe "Kemal::RouteHandler" do
|
||||||
body: "_method=PATCH",
|
body: "_method=PATCH",
|
||||||
headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"}
|
headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"}
|
||||||
)
|
)
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("Hello World from PATCH")
|
client_response.body.should eq("Hello World from PATCH")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "checks for _method param in POST request to simulate DELETE" do
|
it "checks for _method param in POST request to simulate DELETE" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
delete "/" do |env|
|
||||||
kemal.add_route "DELETE", "/" do |env|
|
|
||||||
"Hello World from DELETE"
|
"Hello World from DELETE"
|
||||||
end
|
end
|
||||||
json_payload = {"_method": "DELETE"}
|
json_payload = {"_method": "DELETE"}
|
||||||
|
@ -152,39 +133,25 @@ describe "Kemal::RouteHandler" do
|
||||||
body: "_method=DELETE",
|
body: "_method=DELETE",
|
||||||
headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"}
|
headers: HTTP::Headers{"Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"}
|
||||||
)
|
)
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("Hello World from DELETE")
|
client_response.body.should eq("Hello World from DELETE")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "can process HTTP HEAD requests for defined GET routes" do
|
it "can process HTTP HEAD requests for defined GET routes" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do |env|
|
||||||
kemal.add_route "GET", "/" do |env|
|
|
||||||
"Hello World from GET"
|
"Hello World from GET"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("HEAD", "/")
|
request = HTTP::Request.new("HEAD", "/")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.status_code.should eq(200)
|
client_response.status_code.should eq(200)
|
||||||
end
|
end
|
||||||
|
|
||||||
# Removed until there is a way to test multiple middlewares
|
|
||||||
# it "can't process HTTP HEAD requests for undefined GET routes" do
|
|
||||||
# kemal = Kemal::RouteHandler::INSTANCE
|
|
||||||
# request = HTTP::Request.new("HEAD", "/")
|
|
||||||
# io_with_context = create_request_and_return_io(kemal, request)
|
|
||||||
# client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
# client_response.status_code.should eq(404)
|
|
||||||
# end
|
|
||||||
|
|
||||||
it "redirects user to provided url" do
|
it "redirects user to provided url" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/" do |env|
|
||||||
kemal.add_route "GET", "/" do |env|
|
|
||||||
env.redirect "/login"
|
env.redirect "/login"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/")
|
request = HTTP::Request.new("GET", "/")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.status_code.should eq(302)
|
client_response.status_code.should eq(302)
|
||||||
client_response.headers.has_key?("Location").should eq(true)
|
client_response.headers.has_key?("Location").should eq(true)
|
||||||
end
|
end
|
||||||
|
|
|
@ -3,16 +3,14 @@ require "./spec_helper"
|
||||||
describe "Route" do
|
describe "Route" do
|
||||||
describe "match?" do
|
describe "match?" do
|
||||||
it "matches the correct route" do
|
it "matches the correct route" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/route1" do |env|
|
||||||
kemal.add_route "GET", "/route1" do |env|
|
|
||||||
"Route 1"
|
"Route 1"
|
||||||
end
|
end
|
||||||
kemal.add_route "GET", "/route2" do |env|
|
get "/route2" do |env|
|
||||||
"Route 2"
|
"Route 2"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/route2")
|
request = HTTP::Request.new("GET", "/route2")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should eq("Route 2")
|
client_response.body.should eq("Route 2")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
require "spec"
|
require "spec"
|
||||||
require "../src/kemal/*"
|
require "../src/*"
|
||||||
require "../src/kemal/middleware/*"
|
|
||||||
|
|
||||||
include Kemal
|
include Kemal
|
||||||
|
|
||||||
|
@ -35,10 +34,24 @@ def create_ws_request_and_return_io(handler, request)
|
||||||
io
|
io
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def call_request_on_app(request)
|
||||||
|
io = MemoryIO.new
|
||||||
|
response = HTTP::Server::Response.new(io)
|
||||||
|
context = HTTP::Server::Context.new(request, response)
|
||||||
|
Kemal::RouteHandler::INSTANCE.call(context)
|
||||||
|
response.close
|
||||||
|
io.rewind
|
||||||
|
HTTP::Client::Response.from_io(io, decompress: false)
|
||||||
|
end
|
||||||
|
|
||||||
Spec.before_each do
|
Spec.before_each do
|
||||||
config = Kemal.config
|
config = Kemal.config
|
||||||
config.env = "development"
|
config.env = "development"
|
||||||
config.setup_logging
|
config.setup
|
||||||
config.handlers.clear
|
config.add_handler Kemal::RouteHandler::INSTANCE
|
||||||
|
end
|
||||||
|
|
||||||
|
Spec.after_each do
|
||||||
|
Kemal.config.handlers.clear
|
||||||
Kemal::RouteHandler::INSTANCE.tree = Radix::Tree.new
|
Kemal::RouteHandler::INSTANCE.tree = Radix::Tree.new
|
||||||
end
|
end
|
||||||
|
|
|
@ -6,38 +6,32 @@ end
|
||||||
|
|
||||||
describe "Views" do
|
describe "Views" do
|
||||||
it "renders file" do
|
it "renders file" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/view/:name" do |env|
|
||||||
kemal.add_route "GET", "/view/:name" do |env|
|
|
||||||
name = env.params.url["name"]
|
name = env.params.url["name"]
|
||||||
render "spec/asset/hello.ecr"
|
render "spec/asset/hello.ecr"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/view/world")
|
request = HTTP::Request.new("GET", "/view/world")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should contain("Hello world")
|
client_response.body.should contain("Hello world")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "renders file with dynamic variables" do
|
it "renders file with dynamic variables" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/view/:name" do |env|
|
||||||
kemal.add_route "GET", "/view/:name" do |env|
|
|
||||||
name = env.params.url["name"]
|
name = env.params.url["name"]
|
||||||
render_with_base_and_layout "hello.ecr"
|
render_with_base_and_layout "hello.ecr"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/view/world")
|
request = HTTP::Request.new("GET", "/view/world")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should contain("Hello world")
|
client_response.body.should contain("Hello world")
|
||||||
end
|
end
|
||||||
|
|
||||||
it "renders layout" do
|
it "renders layout" do
|
||||||
kemal = Kemal::RouteHandler::INSTANCE
|
get "/view/:name" do |env|
|
||||||
kemal.add_route "GET", "/view/:name" do |env|
|
|
||||||
name = env.params.url["name"]
|
name = env.params.url["name"]
|
||||||
render "spec/asset/hello.ecr", "spec/asset/layout.ecr"
|
render "spec/asset/hello.ecr", "spec/asset/layout.ecr"
|
||||||
end
|
end
|
||||||
request = HTTP::Request.new("GET", "/view/world")
|
request = HTTP::Request.new("GET", "/view/world")
|
||||||
io_with_context = create_request_and_return_io(kemal, request)
|
client_response = call_request_on_app(request)
|
||||||
client_response = HTTP::Client::Response.from_io(io_with_context, decompress: false)
|
|
||||||
client_response.body.should contain("<html>Hello world")
|
client_response.body.should contain("<html>Hello world")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue