52 lines
1.2 KiB
Ruby
52 lines
1.2 KiB
Ruby
|
require 'test_helper'
|
||
|
|
||
|
class SafeBufferTest < ActiveSupport::TestCase
|
||
|
def setup
|
||
|
@buffer = ActiveSupport::SafeBuffer.new
|
||
|
end
|
||
|
|
||
|
test "Should look like a string" do
|
||
|
assert @buffer.is_a?(String)
|
||
|
assert_equal "", @buffer
|
||
|
end
|
||
|
|
||
|
test "Should escape a raw string which is passed to them" do
|
||
|
@buffer << "<script>"
|
||
|
assert_equal "<script>", @buffer
|
||
|
end
|
||
|
|
||
|
test "Should NOT escape a safe value passed to it" do
|
||
|
@buffer << "<script>".html_safe
|
||
|
assert_equal "<script>", @buffer
|
||
|
end
|
||
|
|
||
|
test "Should not mess with an innocuous string" do
|
||
|
@buffer << "Hello"
|
||
|
assert_equal "Hello", @buffer
|
||
|
end
|
||
|
|
||
|
test "Should not mess with a previously escape test" do
|
||
|
@buffer << ERB::Util.html_escape("<script>")
|
||
|
assert_equal "<script>", @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
|
||
|
assert_equal ActiveSupport::SafeBuffer, new_buffer.class
|
||
|
end
|
||
|
|
||
|
test "Should not return a safe buffer when using sub" do
|
||
|
assert !@buffer.sub('', "asdf").html_safe?
|
||
|
end
|
||
|
|
||
|
test "Should raise argument error when using sub!" do
|
||
|
assert_raise TypeError do
|
||
|
@buffer.sub!('', "asdf")
|
||
|
end
|
||
|
end
|
||
|
end
|