diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2013-01-08 10:45:44 -0800 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2013-01-09 15:34:58 -0800 |
commit | 56f3d05f4746c091827d7607f0afe2857959c73c (patch) | |
tree | c75c28c3ded1bac5607a467ccd9c8b9cdcf466e3 /activesupport/test/notifications | |
parent | f92c2b103ea675c6f88e7af107653860ebb8cff3 (diff) | |
download | rails-56f3d05f4746c091827d7607f0afe2857959c73c.tar.gz rails-56f3d05f4746c091827d7607f0afe2857959c73c.tar.bz2 rails-56f3d05f4746c091827d7607f0afe2857959c73c.zip |
adding start / finish on the instrumenter, adding tests for the class
Diffstat (limited to 'activesupport/test/notifications')
-rw-r--r-- | activesupport/test/notifications/instrumenter_test.rb | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/activesupport/test/notifications/instrumenter_test.rb b/activesupport/test/notifications/instrumenter_test.rb new file mode 100644 index 0000000000..62a9b61464 --- /dev/null +++ b/activesupport/test/notifications/instrumenter_test.rb @@ -0,0 +1,50 @@ +require 'abstract_unit' +require 'active_support/notifications/instrumenter' + +module ActiveSupport + module Notifications + class InstrumenterTest < ActiveSupport::TestCase + class TestNotifier + attr_reader :starts, :finishes + + def initialize + @starts = [] + @finishes = [] + end + + def start(*args); @starts << args; end + def finish(*args); @finishes << args; end + end + + attr_reader :instrumenter, :notifier, :payload + + def setup + super + @notifier = TestNotifier.new + @instrumenter = Instrumenter.new @notifier + @payload = { :foo => Object.new } + end + + def test_instrument + called = false + instrumenter.instrument("foo", payload) { + called = true + } + + assert called + end + + def test_start + instrumenter.start("foo", payload) + assert_equal [["foo", instrumenter.id, payload]], notifier.starts + assert_predicate notifier.finishes, :empty? + end + + def test_finish + instrumenter.finish("foo", payload) + assert_equal [["foo", instrumenter.id, payload]], notifier.finishes + assert_predicate notifier.starts, :empty? + end + end + end +end |