Merge pull request #29503 from savroff/fix_current_page_engine_issue

Fix current_page? helper issue with engine root path
This commit is contained in:
Rafael França 2017-06-20 11:37:48 -04:00 committed by GitHub
commit 95ee77b3ae
3 changed files with 23 additions and 4 deletions

View File

@ -1,3 +1,9 @@
* Fix issues with scopes and engine on `current_page?` method.
Fixes #29401.
*Nikita Savrov*
* Generate field ids in `collection_check_boxes` and `collection_radio_buttons`.
This makes sure that the labels are linked up with the fields.

View File

@ -552,7 +552,10 @@ module ActionView
request_uri = url_string.index("?") || check_parameters ? request.fullpath : request.path
request_uri = URI.parser.unescape(request_uri).force_encoding(Encoding::BINARY)
url_string.chomp!("/") if url_string.start_with?("/") && url_string != "/"
if url_string.start_with?("/") && url_string != "/"
url_string.chomp!("/")
request_uri.chomp!("/")
end
if %r{^\w+://}.match?(url_string)
url_string == "#{request.protocol}#{request.host_with_port}#{request_uri}"

View File

@ -15,6 +15,10 @@ class UrlHelperTest < ActiveSupport::TestCase
get "/other" => "foo#other"
get "/article/:id" => "foo#article", :as => :article
get "/category/:category" => "foo#category"
scope :engine do
get "/" => "foo#bar"
end
end
include ActionView::Helpers::UrlHelper
@ -521,10 +525,10 @@ class UrlHelperTest < ActiveSupport::TestCase
assert current_page?("http://www.example.com/?order=desc&page=1")
end
def test_current_page_with_not_get_verb
@request = request_for_url("/events", method: :post)
def test_current_page_with_scope_that_match
@request = request_for_url("/engine/")
assert !current_page?("/events")
assert current_page?("/engine")
end
def test_current_page_with_escaped_params
@ -553,6 +557,12 @@ class UrlHelperTest < ActiveSupport::TestCase
assert current_page?("/posts/")
end
def test_current_page_with_not_get_verb
@request = request_for_url("/events", method: :post)
assert !current_page?("/events")
end
def test_link_unless_current
@request = request_for_url("/")