Route declaration must start with / fixes #242

This commit is contained in:
sdogruyol 2016-11-04 11:12:35 +03:00
parent 7dd834ad28
commit e6810c4516
5 changed files with 24 additions and 0 deletions

View file

@ -11,6 +11,7 @@ Request -> Middleware -> Filter -> Route
``` ```
- Rename `return_with` as `halt`. - Rename `return_with` as `halt`.
- Route declaration must start with `/`. Fixes [#242](https://github.com/sdogruyol/kemal/issues/242)
# 0.16.1 (12-10-2016) # 0.16.1 (12-10-2016)

View file

@ -13,5 +13,13 @@ describe "Route" do
client_response = call_request_on_app(request) client_response = call_request_on_app(request)
client_response.body.should eq("Route 2") client_response.body.should eq("Route 2")
end end
it "doesn't allow a route declaration start without /" do
expect_raises Kemal::Exceptions::PathStartInvalidException, "Route declaration get \"route\" needs to start with '/', should be get \"/route\"" do
get "route" do |env|
"Route 1"
end
end
end
end end
end end

View file

@ -5,11 +5,13 @@ HTTP_METHODS = %w(get post put patch delete options)
{% for method in HTTP_METHODS %} {% for method in HTTP_METHODS %}
def {{method.id}}(path, &block : HTTP::Server::Context -> _) def {{method.id}}(path, &block : HTTP::Server::Context -> _)
raise Kemal::Exceptions::PathStartInvalidException.new({{method}}, path) unless Kemal::Utils.path_starts_with_backslash?(path)
Kemal::RouteHandler::INSTANCE.add_route({{method}}.upcase, path, &block) Kemal::RouteHandler::INSTANCE.add_route({{method}}.upcase, path, &block)
end end
{% end %} {% end %}
def ws(path, &block : HTTP::WebSocket, HTTP::Server::Context -> Void) def ws(path, &block : HTTP::WebSocket, HTTP::Server::Context -> Void)
raise Kemal::Exceptions::PathStartInvalidException.new("ws", path) unless Kemal::Utils.path_starts_with_backslash?(path)
Kemal::WebSocketHandler.new path, &block Kemal::WebSocketHandler.new path, &block
end end

View file

@ -1,5 +1,11 @@
# Exceptions for 404 and custom errors are defined here. # Exceptions for 404 and custom errors are defined here.
module Kemal::Exceptions module Kemal::Exceptions
class PathStartInvalidException < Exception
def initialize(method, path)
super "Route declaration #{method} \"#{path}\" needs to start with '/', should be #{method} \"/#{path}\""
end
end
class RouteNotFound < Exception class RouteNotFound < Exception
def initialize(context) def initialize(context)
super "Requested path: '#{context.request.override_method.as(String)}:#{context.request.path}' was not found." super "Requested path: '#{context.request.override_method.as(String)}:#{context.request.path}' was not found."

View file

@ -0,0 +1,7 @@
module Kemal
class Utils
def self.path_starts_with_backslash?(path)
path.starts_with?("/")
end
end
end