diff options
| -rw-r--r-- | activesupport/lib/active_support/notifications.rb | 16 | ||||
| -rw-r--r-- | activesupport/test/notifications_test.rb | 24 | 
2 files changed, 21 insertions, 19 deletions
| diff --git a/activesupport/lib/active_support/notifications.rb b/activesupport/lib/active_support/notifications.rb index 6304f496f5..7a9f76b26a 100644 --- a/activesupport/lib/active_support/notifications.rb +++ b/activesupport/lib/active_support/notifications.rb @@ -144,27 +144,21 @@ module ActiveSupport      class LittleFanout        def initialize          @listeners = [] -        @stream    = Queue.new -        Thread.new { consume }        end        def publish(*args) -        @stream.push(args) +        @listeners.each { |l| l.publish(*args) }        end        def subscribe(pattern=nil, &block)          @listeners << Listener.new(pattern, &block)        end -      def consume -        while args = @stream.shift -          @listeners.each { |l| l.publish(*args) } -        end +      def drained? +        @listeners.all? &:drained?        end        class Listener -        # attr_reader :thread -          def initialize(pattern, &block)            @pattern = pattern            @subscriber = block @@ -183,6 +177,10 @@ module ActiveSupport              @subscriber.call(*args)            end          end + +        def drained? +          @queue.size.zero? +        end        end      end    end diff --git a/activesupport/test/notifications_test.rb b/activesupport/test/notifications_test.rb index 466af49931..01106e83e9 100644 --- a/activesupport/test/notifications_test.rb +++ b/activesupport/test/notifications_test.rb @@ -75,7 +75,7 @@ class NotificationsMainTest < Test::Unit::TestCase        1 + 1      end -    sleep 1 +    drain      assert_equal 1, @events.size      assert_equal :awesome, @events.last.name @@ -88,19 +88,18 @@ class NotificationsMainTest < Test::Unit::TestCase          1 + 1        end -      sleep 1 +      drain        assert_equal 1, @events.size        assert_equal :wot, @events.first.name        assert_equal Hash[:payload => "child"], @events.first.payload      end -    sleep 1 +    drain      assert_equal 2, @events.size      assert_equal :awesome, @events.last.name      assert_equal Hash[:payload => "notifications"], @events.last.payload -    assert_in_delta 1000, @events.last.duration, 70    end    def test_event_is_pushed_even_if_block_fails @@ -108,7 +107,7 @@ class NotificationsMainTest < Test::Unit::TestCase        raise "OMG"      end rescue RuntimeError -    sleep 1 +    drain      assert_equal 1, @events.size      assert_equal :awesome, @events.last.name @@ -117,7 +116,7 @@ class NotificationsMainTest < Test::Unit::TestCase    def test_event_is_pushed_even_without_block      ActiveSupport::Notifications.instrument(:awesome, :payload => "notifications") -    sleep 1 +    drain      assert_equal 1, @events.size      assert_equal :awesome, @events.last.name @@ -137,7 +136,7 @@ class NotificationsMainTest < Test::Unit::TestCase      end      ActiveSupport::Notifications.instrument(:cache){ 1 } -    sleep 1 +    drain      assert_equal 3, @another.size      before, during, after = @another.map {|e| e.transaction_id } @@ -154,7 +153,7 @@ class NotificationsMainTest < Test::Unit::TestCase      ActiveSupport::Notifications.instrument(:cache){ 1 } -    sleep 1 +    drain      assert_equal 1, @another.size      assert_equal :cache, @another.first.name @@ -170,7 +169,7 @@ class NotificationsMainTest < Test::Unit::TestCase      ActiveSupport::Notifications.instrument(:something){ 0 }      ActiveSupport::Notifications.instrument(:cache){ 1 } -    sleep 1 +    drain      assert_equal 1, @another.size      assert_equal :cache, @another.first.name @@ -187,7 +186,7 @@ class NotificationsMainTest < Test::Unit::TestCase        ActiveSupport::Notifications.instrument(:value){ i }      end -    sleep 1 +    drain      assert_equal 100, @events.size      assert_equal :value, @events.first.name @@ -199,4 +198,9 @@ class NotificationsMainTest < Test::Unit::TestCase      assert_equal 1, @another.first.result      assert_equal 100, @another.last.result    end + +  private +    def drain +      sleep(0.1) until ActiveSupport::Notifications.queue.drained? +    end  end | 
