Make sure regexp chunks are grouped when the segment has a regexp constraint so that captures are counted correctly (closes #5267)

git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4434 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
Jamis Buck
2006-06-05 14:31:38 +00:00
parent 7d88146e9e
commit 332fcfaf6b
2 changed files with 24 additions and 1 deletions

View File

@@ -489,7 +489,7 @@ module ActionController
Regexp.new "\\A#{regexp.source}\\Z" if regexp
end
def regexp_chunk
regexp ? regexp.source : "([^#{Routing::SEPARATORS.join}]+)"
regexp ? "(#{regexp.source})" : "([^#{Routing::SEPARATORS.join}]+)"
end
def build_pattern(pattern)

View File

@@ -1230,6 +1230,29 @@ class RouteSetTest < Test::Unit::TestCase
ensure
Object.send(:remove_const, :PeopleController)
end
def test_typo_recognition
Object.const_set(:ArticlesController, Class.new)
set.draw do |map|
map.connect 'articles/:year/:month/:day/:title',
:controller => 'articles', :action => 'permalink',
:year => /\d{4}/, :day => /\d{1,2}/, :month => /\d{1,2}/
end
request.path = "/articles/2005/11/05/a-very-interesting-article"
request.method = :get
assert_nothing_raised { set.recognize(request) }
assert_equal("permalink", request.path_parameters[:action])
assert_equal("2005", request.path_parameters[:year])
assert_equal("11", request.path_parameters[:month])
assert_equal("05", request.path_parameters[:day])
assert_equal("a-very-interesting-article", request.path_parameters[:title])
ensure
Object.send(:remove_const, :ArticlesController)
end
def test_recognize_with_conditions_and_format
Object.const_set(:PeopleController, Class.new)