diff options
author | Xavier Noria <fxn@hashref.com> | 2010-03-16 21:05:01 +0100 |
---|---|---|
committer | Jeremy Kemper <jeremy@bitsweat.net> | 2010-03-16 13:16:44 -0700 |
commit | 9659d18c9b76f6383854af0cd3a75abb6b1784ea (patch) | |
tree | 50c8dea07ab3e8f8ab344016f03fad0c2ea2a7fe /actionpack | |
parent | 986cac73e3c56b3dfa22fd1464f6913e38d32cc3 (diff) | |
download | rails-9659d18c9b76f6383854af0cd3a75abb6b1784ea.tar.gz rails-9659d18c9b76f6383854af0cd3a75abb6b1784ea.tar.bz2 rails-9659d18c9b76f6383854af0cd3a75abb6b1784ea.zip |
adds tests for #flush_output_buffer
[#4196 state:committed]
Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/test/template/capture_helper_test.rb | 39 |
1 files changed, 37 insertions, 2 deletions
diff --git a/actionpack/test/template/capture_helper_test.rb b/actionpack/test/template/capture_helper_test.rb index c1e83fc04d..2216e6b578 100644 --- a/actionpack/test/template/capture_helper_test.rb +++ b/actionpack/test/template/capture_helper_test.rb @@ -18,7 +18,7 @@ class CaptureHelperTest < ActionView::TestCase assert_kind_of ActionView::NonConcattingString, string end - def test_capture_captures_the_value_returned_by_the_block_in_the_temporary_buffer_is_blank + def test_capture_captures_the_value_returned_by_the_block_if_the_temporary_buffer_is_blank string = @av.capture('foo', 'bar') do |a, b| a + b end @@ -70,7 +70,7 @@ class CaptureHelperTest < ActionView::TestCase @av.output_buffer = ActionView::OutputBuffer.new # Ensure we set the output buffer to an encoding different than the default one. - alt_encoding = @av.output_buffer.encoding == Encoding::US_ASCII ? Encoding::UTF_8 : Encoding::US_ASCII + alt_encoding = alt_encoding(@av.output_buffer) @av.output_buffer.force_encoding(alt_encoding) @av.with_output_buffer do @@ -83,4 +83,39 @@ class CaptureHelperTest < ActionView::TestCase assert_nil @av.output_buffer assert_equal "", @av.with_output_buffer {} end + + def test_flush_output_buffer_concats_output_buffer_to_response + view = view_with_controller + assert_equal [], view.response.body_parts + + view.output_buffer << 'OMG' + view.flush_output_buffer + assert_equal ['OMG'], view.response.body_parts + assert_equal '', view.output_buffer + + view.output_buffer << 'foobar' + view.flush_output_buffer + assert_equal ['OMG', 'foobar'], view.response.body_parts + assert_equal '', view.output_buffer + end + + unless RUBY_VERSION < '1.9' + def test_flush_output_buffer_preserves_the_encoding_of_the_output_buffer + view = view_with_controller + alt_encoding = alt_encoding(view.output_buffer) + view.output_buffer.force_encoding(alt_encoding) + flush_output_buffer + assert_equal alt_encoding, view.output_buffer.encoding + end + end + + def alt_encoding(output_buffer) + output_buffer.encoding == Encoding::US_ASCII ? Encoding::UTF_8 : Encoding::US_ASCII + end + + def view_with_controller + returning(ActionView::Base.for_controller(TestController.new)) do |view| + view.output_buffer = ActionView::OutputBuffer.new + end + end end |