aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/test/dispatch/callbacks_test.rb
diff options
context:
space:
mode:
authorJosé Valim <jose.valim@gmail.com>2010-01-15 14:16:52 +0100
committerJosé Valim <jose.valim@gmail.com>2010-01-15 14:16:52 +0100
commit4598d8874948268e1162c1ef75d0bd565b1e0e64 (patch)
tree3f24f8073b41af215e4e45f2200eb30d2338f678 /actionpack/test/dispatch/callbacks_test.rb
parent5252f5c1c96001795d3e723ad8e48117e34c045b (diff)
downloadrails-4598d8874948268e1162c1ef75d0bd565b1e0e64.tar.gz
rails-4598d8874948268e1162c1ef75d0bd565b1e0e64.tar.bz2
rails-4598d8874948268e1162c1ef75d0bd565b1e0e64.zip
Ensure log is flushed and tailed on failures.
Diffstat (limited to 'actionpack/test/dispatch/callbacks_test.rb')
-rw-r--r--actionpack/test/dispatch/callbacks_test.rb37
1 files changed, 34 insertions, 3 deletions
diff --git a/actionpack/test/dispatch/callbacks_test.rb b/actionpack/test/dispatch/callbacks_test.rb
index 8a2d56cfcc..f3ea5209f4 100644
--- a/actionpack/test/dispatch/callbacks_test.rb
+++ b/actionpack/test/dispatch/callbacks_test.rb
@@ -17,7 +17,7 @@ class DispatcherTest < Test::Unit::TestCase
ActionDispatch::Callbacks.reset_callbacks(:call)
end
- def test_prepare_callbacks
+ def test_prepare_callbacks_with_cache_classes
a = b = c = nil
ActionDispatch::Callbacks.to_prepare { |*args| a = b = c = 1 }
ActionDispatch::Callbacks.to_prepare { |*args| b = c = 2 }
@@ -39,6 +39,30 @@ class DispatcherTest < Test::Unit::TestCase
assert_nil a || b || c
end
+ def test_prepare_callbacks_without_cache_classes
+ a = b = c = nil
+ ActionDispatch::Callbacks.to_prepare { |*args| a = b = c = 1 }
+ ActionDispatch::Callbacks.to_prepare { |*args| b = c = 2 }
+ ActionDispatch::Callbacks.to_prepare { |*args| c = 3 }
+
+ # Ensure to_prepare callbacks are not run when defined
+ assert_nil a || b || c
+
+ # Run callbacks
+ dispatch(false)
+
+ assert_equal 1, a
+ assert_equal 2, b
+ assert_equal 3, c
+
+ # Make sure they are run again
+ a = b = c = nil
+ dispatch(false)
+ assert_equal 1, a
+ assert_equal 2, b
+ assert_equal 3, c
+ end
+
def test_to_prepare_with_identifier_replaces
ActionDispatch::Callbacks.to_prepare(:unique_id) { |*args| Foo.a, Foo.b = 1, 1 }
ActionDispatch::Callbacks.to_prepare(:unique_id) { |*args| Foo.a = 2 }
@@ -66,10 +90,17 @@ class DispatcherTest < Test::Unit::TestCase
dispatch
end
+ def test_should_send_an_instrumentation_callback_for_async_processing_even_on_failure
+ ActiveSupport::Notifications.notifier.expects(:publish)
+ assert_raise RuntimeError do
+ dispatch { |env| raise "OMG" }
+ end
+ end
+
private
- def dispatch(cache_classes = true)
- @dispatcher ||= ActionDispatch::Callbacks.new(DummyApp.new, !cache_classes)
+ def dispatch(cache_classes = true, &block)
+ @dispatcher ||= ActionDispatch::Callbacks.new(block || DummyApp.new, !cache_classes)
@dispatcher.call({'rack.input' => StringIO.new('')})
end