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/lib | |
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/lib')
-rw-r--r-- | activesupport/lib/active_support/notifications/instrumenter.rb | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/activesupport/lib/active_support/notifications/instrumenter.rb b/activesupport/lib/active_support/notifications/instrumenter.rb index ab0b162ee0..1ee7ca06bb 100644 --- a/activesupport/lib/active_support/notifications/instrumenter.rb +++ b/activesupport/lib/active_support/notifications/instrumenter.rb @@ -7,7 +7,7 @@ module ActiveSupport attr_reader :id def initialize(notifier) - @id = unique_id + @id = unique_id @notifier = notifier end @@ -15,21 +15,32 @@ module ActiveSupport # and publish it. Notice that events get sent even if an error occurs # in the passed-in block. def instrument(name, payload={}) - @notifier.start(name, @id, payload) + start name, payload begin yield rescue Exception => e payload[:exception] = [e.class.name, e.message] raise e ensure - @notifier.finish(name, @id, payload) + finish name, payload end end + # Send a start notification with +name+ and +payload+. + def start(name, payload) + @notifier.start name, @id, payload + end + + # Send a finish notification with +name+ and +payload+. + def finish(name, payload) + @notifier.finish name, @id, payload + end + private - def unique_id - SecureRandom.hex(10) - end + + def unique_id + SecureRandom.hex(10) + end end class Event |