提交 d919fd88 编写于 作者: R Rafael Mendonça França

Merge pull request #11352 from xaviershay/dispatcher-api

Allow a custom dispatcher to be provided to routing.
......@@ -62,13 +62,17 @@ def controller(params, default_controller=true)
raise ActionController::RoutingError, e.message, e.backtrace if default_controller
end
private
protected
attr_reader :controller_class_names
def controller_reference(controller_param)
const_name = @controller_class_names[controller_param] ||= "#{controller_param.camelize}Controller"
const_name = controller_class_names[controller_param] ||= "#{controller_param.camelize}Controller"
ActiveSupport::Dependencies.constantize(const_name)
end
private
def dispatch(controller, action, req)
controller.action(action).call(req.env)
end
......@@ -313,7 +317,7 @@ def define_url_helper(mod, route, name, opts, route_key, url_strategy)
attr_accessor :formatter, :set, :named_routes, :default_scope, :router
attr_accessor :disable_clear_and_finalize, :resources_path_names
attr_accessor :default_url_options
attr_accessor :default_url_options, :dispatcher_class
attr_reader :env_key
alias :routes :set
......@@ -356,6 +360,7 @@ def initialize(config = DEFAULT_CONFIG)
@set = Journey::Routes.new
@router = Journey::Router.new @set
@formatter = Journey::Formatter.new @set
@dispatcher_class = Routing::RouteSet::Dispatcher
end
def relative_url_root
......@@ -414,7 +419,7 @@ def clear!
end
def dispatcher(defaults)
Routing::RouteSet::Dispatcher.new(defaults)
dispatcher_class.new(defaults)
end
module MountedHelpers
......
......@@ -130,14 +130,10 @@ def dispatch(controller, action, env)
end
end
def self.stub_controllers
old_dispatcher = ActionDispatch::Routing::RouteSet::Dispatcher
ActionDispatch::Routing::RouteSet.module_eval { remove_const :Dispatcher }
ActionDispatch::Routing::RouteSet.module_eval { const_set :Dispatcher, StubDispatcher }
yield ActionDispatch::Routing::RouteSet.new
ensure
ActionDispatch::Routing::RouteSet.module_eval { remove_const :Dispatcher }
ActionDispatch::Routing::RouteSet.module_eval { const_set :Dispatcher, old_dispatcher }
def self.stub_controllers(config = nil)
route_set = ActionDispatch::Routing::RouteSet.new(*[config].compact)
route_set.dispatcher_class = StubDispatcher
yield route_set
end
def with_routing(&block)
......
......@@ -19,6 +19,10 @@ def request_class
ActionDispatch::Request
end
def dispatcher_class
RouteSet::Dispatcher
end
def add_route(*args)
routes << args
end
......
......@@ -168,12 +168,10 @@ def test_session_singleton_resource
end
def test_session_singleton_resource_for_api_app
self.class.stub_controllers do |_|
config = ActionDispatch::Routing::RouteSet::Config.new
config.api_only = true
routes = ActionDispatch::Routing::RouteSet.new(config)
config = ActionDispatch::Routing::RouteSet::Config.new
config.api_only = true
self.class.stub_controllers(config) do |routes|
routes.draw do
resource :session do
get :create
......@@ -550,11 +548,10 @@ def test_projects
end
def test_projects_for_api_app
self.class.stub_controllers do |_|
config = ActionDispatch::Routing::RouteSet::Config.new
config.api_only = true
config = ActionDispatch::Routing::RouteSet::Config.new
config.api_only = true
routes = ActionDispatch::Routing::RouteSet.new(config)
self.class.stub_controllers(config) do |routes|
routes.draw do
resources :projects, controller: :project
end
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册