Merge pull request #1610 from sikachu/3-1-stable-javascript

Make sure `escape_javascript` return `SafeBuffer` if the incoming argumen
This commit is contained in:
Aaron Patterson
2011-06-09 11:39:09 -07:00
3 changed files with 6 additions and 1 deletions

View File

@@ -1,5 +1,7 @@
*Rails 3.1.0 (unreleased)*
* Make sure escape_js returns SafeBuffer string if it receives SafeBuffer string [Prem Sichanugrist]
* Fix escape_js to work correctly with the new SafeBuffer restriction [Paul Gallagher]
* Brought back alternative convention for namespaced models in i18n [thoefer]

View File

@@ -18,7 +18,8 @@ module ActionView
# $('some_element').replaceWith('<%=j render 'some/element_template' %>');
def escape_javascript(javascript)
if javascript
javascript.gsub(/(\\|<\/|\r\n|[\n\r"'])/) {|match| JS_ESCAPE_MAP[match] }
result = javascript.gsub(/(\\|<\/|\r\n|[\n\r"'])/) {|match| JS_ESCAPE_MAP[match] }
javascript.html_safe? ? result.html_safe : result
else
''
end

View File

@@ -35,6 +35,8 @@ class JavaScriptHelperTest < ActionView::TestCase
expect = %(\\'quoted\\' \\"double-quoted\\" new-line:\\n <\\/closed>)
assert_equal expect, escape_javascript(given)
assert_equal expect, escape_javascript(ActiveSupport::SafeBuffer.new(given))
assert_instance_of String, escape_javascript(given)
assert_instance_of ActiveSupport::SafeBuffer, escape_javascript(ActiveSupport::SafeBuffer.new(given))
end
def test_button_to_function