mirror of
https://gitea.invidious.io/iv-org/shard-kemal.git
synced 2024-08-15 00:53:36 +00:00
Add app reference to the handlers which are bound to the app
This commit is contained in:
parent
dc93bb2235
commit
72bcac6dd5
12 changed files with 58 additions and 49 deletions
|
@ -64,7 +64,6 @@ describe "Context" do
|
|||
io = IO::Memory.new
|
||||
response = HTTP::Server::Response.new(io)
|
||||
context = HTTP::Server::Context.new(request, response)
|
||||
context.app = app
|
||||
app.filter_handler.call(context)
|
||||
app.route_handler.call(context)
|
||||
context.store["key"].should eq "value"
|
||||
|
|
|
@ -12,11 +12,11 @@ class CustomLogHandler < Kemal::BaseLogHandler
|
|||
end
|
||||
end
|
||||
|
||||
def create_request_and_return_io(handler, request)
|
||||
def create_request_and_return_io(handler, request, app = Kemal.application)
|
||||
io = IO::Memory.new
|
||||
response = HTTP::Server::Response.new(io)
|
||||
context = HTTP::Server::Context.new(request, response)
|
||||
context.app = Kemal.application
|
||||
context.app = app
|
||||
handler.call(context)
|
||||
response.close
|
||||
io.rewind
|
||||
|
|
|
@ -26,9 +26,8 @@ describe "Kemal::ExceptionHandler" do
|
|||
app.get "/" do |env|
|
||||
env.response.status_code = 403
|
||||
end
|
||||
context.app = app
|
||||
subject = Kemal::ExceptionHandler.new(app)
|
||||
subject.next = Kemal::RouteHandler.new
|
||||
subject.next = app.route_handler
|
||||
subject.call(context)
|
||||
response.close
|
||||
io.rewind
|
||||
|
@ -50,9 +49,8 @@ describe "Kemal::ExceptionHandler" do
|
|||
app.get "/" do |env|
|
||||
env.response.status_code = 500
|
||||
end
|
||||
context.app = app
|
||||
subject = Kemal::ExceptionHandler.new(app)
|
||||
subject.next = Kemal::RouteHandler.new
|
||||
subject.next = app.route_handler
|
||||
subject.call(context)
|
||||
response.close
|
||||
io.rewind
|
||||
|
@ -75,9 +73,8 @@ describe "Kemal::ExceptionHandler" do
|
|||
env.response.content_type = "application/json"
|
||||
env.response.status_code = 500
|
||||
end
|
||||
context.app = app
|
||||
subject = Kemal::ExceptionHandler.new(app)
|
||||
subject.next = Kemal::RouteHandler.new
|
||||
subject.next = app.route_handler
|
||||
subject.call(context)
|
||||
response.close
|
||||
io.rewind
|
||||
|
@ -100,9 +97,8 @@ describe "Kemal::ExceptionHandler" do
|
|||
env.response.content_type = "application/json"
|
||||
env.response.status_code = 500
|
||||
end
|
||||
context.app = app
|
||||
subject = Kemal::ExceptionHandler.new(Kemal::Base.new)
|
||||
subject.next = Kemal::RouteHandler.new
|
||||
subject = Kemal::ExceptionHandler.new(app)
|
||||
subject.next = app.route_handler
|
||||
subject.call(context)
|
||||
response.close
|
||||
io.rewind
|
||||
|
|
|
@ -69,8 +69,8 @@ end
|
|||
|
||||
describe "Handler" do
|
||||
it "adds custom handler before before_*" do
|
||||
filter_middleware = Kemal::FilterHandler.new
|
||||
Kemal.application.add_filter_handler filter_middleware
|
||||
app = Kemal::Base.new
|
||||
filter_middleware = Kemal::FilterHandler.new(app)
|
||||
filter_middleware._add_route_filter("GET", "/", :before) do |env|
|
||||
env.response << " is"
|
||||
end
|
||||
|
@ -78,7 +78,6 @@ describe "Handler" do
|
|||
filter_middleware._add_route_filter("GET", "/", :before) do |env|
|
||||
env.response << " so"
|
||||
end
|
||||
app = Kemal::Base.new
|
||||
app.add_filter_handler filter_middleware
|
||||
|
||||
app.add_handler CustomTestHandler.new
|
||||
|
|
|
@ -5,7 +5,7 @@ describe "Kemal::FilterHandler" do
|
|||
test_filter = FilterTest.new
|
||||
test_filter.modified = "false"
|
||||
|
||||
filter_middleware = Kemal::FilterHandler.new
|
||||
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = "true" }
|
||||
|
||||
kemal = Kemal.application.route_handler
|
||||
|
@ -23,7 +23,7 @@ describe "Kemal::FilterHandler" do
|
|||
test_filter = FilterTest.new
|
||||
test_filter.modified = "false"
|
||||
|
||||
filter_middleware = Kemal::FilterHandler.new
|
||||
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
|
||||
kemal = Kemal.application.route_handler
|
||||
|
@ -49,7 +49,7 @@ describe "Kemal::FilterHandler" do
|
|||
test_filter = FilterTest.new
|
||||
test_filter.modified = "false"
|
||||
|
||||
filter_middleware = Kemal::FilterHandler.new
|
||||
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
filter_middleware._add_route_filter("GET", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
filter_middleware._add_route_filter("POST", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
|
@ -77,7 +77,7 @@ describe "Kemal::FilterHandler" do
|
|||
test_filter = FilterTest.new
|
||||
test_filter.modified = "false"
|
||||
|
||||
filter_middleware = Kemal::FilterHandler.new
|
||||
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = "true" }
|
||||
|
||||
kemal = Kemal.application.route_handler
|
||||
|
@ -95,7 +95,7 @@ describe "Kemal::FilterHandler" do
|
|||
test_filter = FilterTest.new
|
||||
test_filter.modified = "false"
|
||||
|
||||
filter_middleware = Kemal::FilterHandler.new
|
||||
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
|
||||
kemal = Kemal.application.route_handler
|
||||
|
@ -121,7 +121,7 @@ describe "Kemal::FilterHandler" do
|
|||
test_filter = FilterTest.new
|
||||
test_filter.modified = "false"
|
||||
|
||||
filter_middleware = Kemal::FilterHandler.new
|
||||
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||
filter_middleware._add_route_filter("ALL", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
filter_middleware._add_route_filter("GET", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
filter_middleware._add_route_filter("POST", "/greetings", :after) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
|
@ -152,7 +152,7 @@ describe "Kemal::FilterHandler" do
|
|||
test_filter_third = FilterTest.new
|
||||
test_filter_third.modified = "false"
|
||||
|
||||
filter_middleware = Kemal::FilterHandler.new
|
||||
filter_middleware = Kemal::FilterHandler.new(Kemal.application)
|
||||
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter.modified = test_filter.modified == "true" ? "false" : "true" }
|
||||
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter_second.modified = test_filter_second.modified == "true" ? "false" : "true" }
|
||||
filter_middleware._add_route_filter("ALL", "/greetings", :before) { test_filter_third.modified = test_filter_third.modified == "true" ? "false" : "true" }
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
require "./spec_helper"
|
||||
|
||||
private def create_ws_request_and_return_io(handler, request, app)
|
||||
private def create_ws_request_and_return_io(handler, request, app = Kemal.application)
|
||||
io = IO::Memory.new
|
||||
response = HTTP::Server::Response.new(io)
|
||||
context = HTTP::Server::Context.new(request, response)
|
||||
|
@ -16,8 +16,8 @@ end
|
|||
describe "Kemal::WebSocketHandler" do
|
||||
it "doesn't match on wrong route" do
|
||||
app = Kemal::Base.new
|
||||
handler = Kemal::WebSocketHandler.new
|
||||
handler.next = Kemal::RouteHandler.new
|
||||
handler = app.websocket_handler
|
||||
handler.next = app.route_handler
|
||||
app.ws "/" { }
|
||||
headers = HTTP::Headers{
|
||||
"Upgrade" => "websocket",
|
||||
|
@ -28,7 +28,6 @@ describe "Kemal::WebSocketHandler" do
|
|||
io = IO::Memory.new
|
||||
response = HTTP::Server::Response.new(io)
|
||||
context = HTTP::Server::Context.new(request, response)
|
||||
context.app = app
|
||||
|
||||
expect_raises(Kemal::Exceptions::RouteNotFound) do
|
||||
handler.call context
|
||||
|
@ -37,7 +36,7 @@ describe "Kemal::WebSocketHandler" do
|
|||
|
||||
it "matches on given route" do
|
||||
app = Kemal::Base.new
|
||||
handler = Kemal::WebSocketHandler.new
|
||||
handler = app.websocket_handler
|
||||
app.ws "/" { |socket, context| socket.send("Match") }
|
||||
app.ws "/no_match" { |socket, context| socket.send "No Match" }
|
||||
headers = HTTP::Headers{
|
||||
|
@ -54,7 +53,7 @@ describe "Kemal::WebSocketHandler" do
|
|||
|
||||
it "fetches named url parameters" do
|
||||
app = Kemal::Base.new
|
||||
handler = Kemal::WebSocketHandler.new
|
||||
handler = app.websocket_handler
|
||||
app.ws "/:id" { |s, c| c.params.url["id"] }
|
||||
headers = HTTP::Headers{
|
||||
"Upgrade" => "websocket",
|
||||
|
@ -69,15 +68,14 @@ describe "Kemal::WebSocketHandler" do
|
|||
|
||||
it "matches correct verb" do
|
||||
app = Kemal::Base.new
|
||||
handler = Kemal::WebSocketHandler.new
|
||||
handler.next = Kemal::RouteHandler.new
|
||||
handler = app.websocket_handler
|
||||
handler.next = app.route_handler
|
||||
app.ws "/" { }
|
||||
app.get "/" { "get" }
|
||||
request = HTTP::Request.new("GET", "/")
|
||||
io = IO::Memory.new
|
||||
response = HTTP::Server::Response.new(io)
|
||||
context = HTTP::Server::Context.new(request, response)
|
||||
context.app = app
|
||||
handler.call(context)
|
||||
response.close
|
||||
io.rewind
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue