diff options
author | Tobias Lütke <tobias.luetke@gmail.com> | 2007-05-17 01:27:54 +0000 |
---|---|---|
committer | Tobias Lütke <tobias.luetke@gmail.com> | 2007-05-17 01:27:54 +0000 |
commit | 04823ff48fbde3ecf7849a1e1a3d3bcc4cc71aa8 (patch) | |
tree | f85eef6cfbac872e8bf8fa416781a9f946982e7d | |
parent | 40486288efea032808901a39787058f0d456cf16 (diff) | |
download | rails-04823ff48fbde3ecf7849a1e1a3d3bcc4cc71aa8.tar.gz rails-04823ff48fbde3ecf7849a1e1a3d3bcc4cc71aa8.tar.bz2 rails-04823ff48fbde3ecf7849a1e1a3d3bcc4cc71aa8.zip |
Allow nested namespaces in routing
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@6748 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r-- | actionpack/lib/action_controller/resources.rb | 6 | ||||
-rw-r--r-- | actionpack/test/controller/resources_test.rb | 18 |
2 files changed, 23 insertions, 1 deletions
diff --git a/actionpack/lib/action_controller/resources.rb b/actionpack/lib/action_controller/resources.rb index a8373677fd..df0c64d91c 100644 --- a/actionpack/lib/action_controller/resources.rb +++ b/actionpack/lib/action_controller/resources.rb @@ -351,7 +351,11 @@ module ActionController # It'll also create admin_product_tags_url pointing to "admin/products/#{product_id}/tags", which will look for # Admin::TagsController. def namespace(name, options = {}, &block) - with_options({ :path_prefix => name, :name_prefix => "#{name}_", :namespace => "#{name}/" }.merge(options), &block) + if options[:namespace] + with_options({:path_prefix => "#{options.delete(:path_prefix)}/#{name}", :name_prefix => "#{options.delete(:name_prefix)}#{name}_", :namespace => "#{options.delete(:namespace)}#{name}/" }.merge(options), &block) + else + with_options({ :path_prefix => name.to_s, :name_prefix => "#{name}_", :namespace => "#{name}/" }.merge(options), &block) + end end diff --git a/actionpack/test/controller/resources_test.rb b/actionpack/test/controller/resources_test.rb index 45e4003021..1f61377ad9 100644 --- a/actionpack/test/controller/resources_test.rb +++ b/actionpack/test/controller/resources_test.rb @@ -17,6 +17,10 @@ class AdminController < ResourcesController; end module Backoffice class ProductsController < ResourcesController; end + + module Admin + class ProductsController < ResourcesController; end + end end class ResourcesTest < Test::Unit::TestCase @@ -400,6 +404,20 @@ class ResourcesTest < Test::Unit::TestCase end end + def test_resources_in_nested_namespace + with_routing do |set| + set.draw do |map| + map.namespace :backoffice do |backoffice| + backoffice.namespace :admin do |admin| + admin.resources :products + end + end + end + + assert_simply_restful_for :products, :controller => "backoffice/admin/products", :name_prefix => 'backoffice_admin_', :path_prefix => 'backoffice/admin/' + end + end + def test_resources_using_namespace with_routing do |set| set.draw do |map| |