2009-11-30 19:38:34 -06:00
|
|
|
require 'abstract_unit'
|
|
|
|
|
2010-05-25 12:45:45 -05:00
|
|
|
class SafeBufferTest < ActiveSupport::TestCase
|
2009-11-30 19:38:34 -06:00
|
|
|
def setup
|
2010-05-25 12:45:45 -05:00
|
|
|
@buffer = ActiveSupport::SafeBuffer.new
|
2009-11-30 19:38:34 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
test "Should look like a string" do
|
|
|
|
assert @buffer.is_a?(String)
|
|
|
|
assert_equal "", @buffer
|
|
|
|
end
|
|
|
|
|
2010-09-05 15:24:15 -05:00
|
|
|
test "Should not escape a raw string unless using rails_xss" do
|
2009-11-30 19:38:34 -06:00
|
|
|
@buffer << "<script>"
|
2010-09-05 15:24:15 -05:00
|
|
|
assert_equal "<script>", @buffer
|
2009-11-30 19:38:34 -06:00
|
|
|
end
|
|
|
|
|
|
|
|
test "Should NOT escape a safe value passed to it" do
|
2010-05-25 12:45:45 -05:00
|
|
|
@buffer << "<script>".html_safe
|
2009-11-30 19:38:34 -06:00
|
|
|
assert_equal "<script>", @buffer
|
|
|
|
end
|
|
|
|
|
|
|
|
test "Should not mess with an innocuous string" do
|
|
|
|
@buffer << "Hello"
|
|
|
|
assert_equal "Hello", @buffer
|
|
|
|
end
|
|
|
|
|
|
|
|
test "Should be considered safe" do
|
|
|
|
assert @buffer.html_safe?
|
|
|
|
end
|
|
|
|
|
|
|
|
test "Should return a safe buffer when calling to_s" do
|
|
|
|
new_buffer = @buffer.to_s
|
2010-05-25 12:45:45 -05:00
|
|
|
assert_equal ActiveSupport::SafeBuffer, new_buffer.class
|
2009-11-30 19:38:34 -06:00
|
|
|
end
|
|
|
|
end
|