1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Merge pull request #22371 from yui-knk/better_mount_error

Brush up errors of `ActionDispatch::Routing::Mapper#mount`
This commit is contained in:
Arthur Nogueira Neves 2015-11-28 11:29:46 -05:00
commit 3513f80e53
2 changed files with 22 additions and 7 deletions

View file

@ -600,17 +600,20 @@ module ActionDispatch
def mount(app, options = nil) def mount(app, options = nil)
if options if options
path = options.delete(:at) path = options.delete(:at)
else elsif Hash === app
unless Hash === app
raise ArgumentError, "must be called with mount point"
end
options = app options = app
app, path = options.find { |k, _| k.respond_to?(:call) } app, path = options.find { |k, _| k.respond_to?(:call) }
options.delete(app) if app options.delete(app) if app
end end
raise "A rack application must be specified" unless path raise ArgumentError, "A rack application must be specified" unless app.respond_to?(:call)
raise ArgumentError, <<-MSG.strip_heredoc unless path
Must be called with mount point
mount SomeRackApp, at: "some_route"
or
mount(SomeRackApp => "some_route")
MSG
rails_app = rails_app? app rails_app = rails_app? app
options[:as] ||= app_name(app, rails_app) options[:as] ||= app_name(app, rails_app)

View file

@ -158,7 +158,7 @@ module ActionDispatch
assert_equal '/*path.:format', fakeset.asts.first.to_s assert_equal '/*path.:format', fakeset.asts.first.to_s
end end
def test_raising_helpful_error_on_invalid_arguments def test_raising_error_when_path_is_not_passed
fakeset = FakeSet.new fakeset = FakeSet.new
mapper = Mapper.new fakeset mapper = Mapper.new fakeset
app = lambda { |env| [200, {}, [""]] } app = lambda { |env| [200, {}, [""]] }
@ -166,6 +166,18 @@ module ActionDispatch
mapper.mount app mapper.mount app
end end
end end
def test_raising_error_when_rack_app_is_not_passed
fakeset = FakeSet.new
mapper = Mapper.new fakeset
assert_raises ArgumentError do
mapper.mount 10, as: "exciting"
end
assert_raises ArgumentError do
mapper.mount as: "exciting"
end
end
end end
end end
end end