mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Broaden URI.unescape fix to all affected 1.9.x by checking for broken behavior instead of specific patchlevel
This commit is contained in:
parent
bfe7d518a7
commit
69bbbe9068
2 changed files with 18 additions and 11 deletions
|
@ -1,10 +1,16 @@
|
|||
if RUBY_VERSION == "1.9.1" && defined?(RUBY_PATCHLEVEL) && RUBY_PATCHLEVEL == 0
|
||||
if RUBY_VERSION >= '1.9'
|
||||
require 'uri'
|
||||
URI::Parser.class_eval do
|
||||
remove_method :unescape
|
||||
def unescape(str, escaped = @regexp[:ESCAPED])
|
||||
enc = (str.encoding == Encoding::US_ASCII) ? Encoding::UTF_8 : str.encoding
|
||||
str.gsub(escaped) { [$&[1, 2].hex].pack('C') }.force_encoding(enc)
|
||||
|
||||
str = "\xE6\x97\xA5\xE6\x9C\xAC\xE8\xAA\x9E" # Ni-ho-nn-go in UTF-8, means Japanese.
|
||||
str.force_encoding(Encoding::UTF_8) if str.respond_to?(:force_encoding)
|
||||
|
||||
unless str == URI.unescape(URI.escape(str))
|
||||
URI::Parser.class_eval do
|
||||
remove_method :unescape
|
||||
def unescape(str, escaped = @regexp[:ESCAPED])
|
||||
enc = (str.encoding == Encoding::US_ASCII) ? Encoding::UTF_8 : str.encoding
|
||||
str.gsub(escaped) { [$&[1, 2].hex].pack('C') }.force_encoding(enc)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,11 +1,12 @@
|
|||
require 'abstract_unit'
|
||||
require 'uri'
|
||||
|
||||
class URITest < Test::Unit::TestCase
|
||||
class URIExtTest < Test::Unit::TestCase
|
||||
def test_uri_decode_handle_multibyte
|
||||
str = "\xE6\x97\xA5\xE6\x9C\xAC\xE8\xAA\x9E" # Ni-ho-nn-go in UTF-8, means Japanese.
|
||||
str.force_encoding(Encoding::UTF_8) if(defined? Encoding::UTF_8)
|
||||
str = "\xE6\x97\xA5\xE6\x9C\xAC\xE8\xAA\x9E" # Ni-ho-nn-go in UTF-8, means Japanese.
|
||||
str.force_encoding(Encoding::UTF_8) if str.respond_to?(:force_encoding)
|
||||
|
||||
assert_equal str, ::URI.unescape( ::URI.escape(str) )
|
||||
assert_equal str, ::URI.decode( ::URI.escape(str) )
|
||||
assert_equal str, URI.unescape(URI.escape(str))
|
||||
assert_equal str, URI.decode(URI.escape(str))
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue