aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_dispatch
diff options
context:
space:
mode:
authorAndrew White <andyw@pixeltrix.co.uk>2014-04-11 10:26:23 +0100
committerAndrew White <andyw@pixeltrix.co.uk>2014-04-11 10:26:23 +0100
commit142448259d7f450df49fdac06bf912edfecaa633 (patch)
tree2973e32dfe5545ab7d65707003a8d8e77acc55d5 /actionpack/lib/action_dispatch
parent856ffbe7058065a34a708fd5b398c0553f9f1f97 (diff)
parente10f26f9e90f2fe6c4cd18f70c1e559f2250da56 (diff)
downloadrails-142448259d7f450df49fdac06bf912edfecaa633.tar.gz
rails-142448259d7f450df49fdac06bf912edfecaa633.tar.bz2
rails-142448259d7f450df49fdac06bf912edfecaa633.zip
Merge pull request #14684 from Futurelearn/jc-deep-nested-shallow-url-helper-bug
Add a failing test for a URL helper that was broken by a6b9ea2.
Diffstat (limited to 'actionpack/lib/action_dispatch')
-rw-r--r--actionpack/lib/action_dispatch/routing/mapper.rb15
1 files changed, 14 insertions, 1 deletions
diff --git a/actionpack/lib/action_dispatch/routing/mapper.rb b/actionpack/lib/action_dispatch/routing/mapper.rb
index 6f0b49cf28..77718a14c1 100644
--- a/actionpack/lib/action_dispatch/routing/mapper.rb
+++ b/actionpack/lib/action_dispatch/routing/mapper.rb
@@ -995,6 +995,7 @@ module ActionDispatch
@as = options[:as]
@param = (options[:param] || :id).to_sym
@options = options
+ @shallow = false
end
def default_actions
@@ -1055,6 +1056,13 @@ module ActionDispatch
"#{path}/:#{nested_param}"
end
+ def shallow=(value)
+ @shallow = value
+ end
+
+ def shallow?
+ @shallow
+ end
end
class SingletonResource < Resource #:nodoc:
@@ -1361,7 +1369,7 @@ module ActionDispatch
end
with_scope_level(:nested) do
- if shallow? && nesting_depth > 1
+ if shallow? && shallow_nesting_depth > 1
shallow_scope(parent_resource.nested_scope, nested_options) { yield }
else
scope(parent_resource.nested_scope, nested_options) { yield }
@@ -1576,6 +1584,7 @@ module ActionDispatch
end
def resource_scope(kind, resource) #:nodoc:
+ resource.shallow = @scope[:shallow]
old_resource, @scope[:scope_level_resource] = @scope[:scope_level_resource], resource
@nesting.push(resource)
@@ -1600,6 +1609,10 @@ module ActionDispatch
@nesting.size
end
+ def shallow_nesting_depth #:nodoc:
+ @nesting.select(&:shallow?).size
+ end
+
def param_constraint? #:nodoc:
@scope[:constraints] && @scope[:constraints][parent_resource.param].is_a?(Regexp)
end