aboutsummaryrefslogtreecommitdiffstats
path: root/actionview
diff options
context:
space:
mode:
authorStan Lo <a22301613@yahoo.com.tw>2016-06-25 11:29:39 +0800
committerStan Lo <a22301613@yahoo.com.tw>2016-07-20 10:57:26 +0800
commitef89331f0a397bc88d6e27480aa7562db70550f7 (patch)
treea3ef633cead7494d8e6d567e9bf5d63b867d6cb9 /actionview
parent40bf7a52d51498879d9b442663b7a23f37fb1204 (diff)
downloadrails-ef89331f0a397bc88d6e27480aa7562db70550f7.tar.gz
rails-ef89331f0a397bc88d6e27480aa7562db70550f7.tar.bz2
rails-ef89331f0a397bc88d6e27480aa7562db70550f7.zip
Fix ActionView::Helpers#current_page? with issue in https://github.com/rails/rails/issues/19472
Diffstat (limited to 'actionview')
-rw-r--r--actionview/lib/action_view/helpers/url_helper.rb2
-rw-r--r--actionview/test/template/url_helper_test.rb6
2 files changed, 8 insertions, 0 deletions
diff --git a/actionview/lib/action_view/helpers/url_helper.rb b/actionview/lib/action_view/helpers/url_helper.rb
index 11c7daf4da..fb6426b997 100644
--- a/actionview/lib/action_view/helpers/url_helper.rb
+++ b/actionview/lib/action_view/helpers/url_helper.rb
@@ -548,6 +548,8 @@ module ActionView
request_uri = url_string.index("?") ? 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 =~ /^\w+:\/\//
url_string == "#{request.protocol}#{request.host_with_port}#{request_uri}"
else
diff --git a/actionview/test/template/url_helper_test.rb b/actionview/test/template/url_helper_test.rb
index ab56d80de3..6060ea2f1e 100644
--- a/actionview/test/template/url_helper_test.rb
+++ b/actionview/test/template/url_helper_test.rb
@@ -503,6 +503,12 @@ class UrlHelperTest < ActiveSupport::TestCase
assert current_page?(controller: 'foo', action: 'category', category: 'administraĆ§Ć£o', callback_url: 'http://example.com/foo')
end
+ def test_current_page_with_trailing_slash
+ @request = request_for_url("/posts")
+
+ assert current_page?("/posts/")
+ end
+
def test_link_unless_current
@request = request_for_url("/")