diff options
author | José Valim <jose.valim@gmail.com> | 2009-09-18 08:08:02 -0300 |
---|---|---|
committer | José Valim <jose.valim@gmail.com> | 2009-09-20 10:56:38 -0300 |
commit | 8f47f311b7665d74220baf1449b39dc4e70e13e2 (patch) | |
tree | 006f657e8147a72c88f3dbbc294d2aa7b1d9b5b3 /activerecord/lib/active_record/connection_adapters | |
parent | 3c9a37c9c474b9ae2be2cdb73a5ee0c3439d4e5e (diff) | |
download | rails-8f47f311b7665d74220baf1449b39dc4e70e13e2.tar.gz rails-8f47f311b7665d74220baf1449b39dc4e70e13e2.tar.bz2 rails-8f47f311b7665d74220baf1449b39dc4e70e13e2.zip |
Instrument process_action, render and sql.
Diffstat (limited to 'activerecord/lib/active_record/connection_adapters')
-rwxr-xr-x | activerecord/lib/active_record/connection_adapters/abstract_adapter.rb | 22 |
1 files changed, 9 insertions, 13 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/abstract_adapter.rb b/activerecord/lib/active_record/connection_adapters/abstract_adapter.rb index fab70f34b9..78c7a4b697 100755 --- a/activerecord/lib/active_record/connection_adapters/abstract_adapter.rb +++ b/activerecord/lib/active_record/connection_adapters/abstract_adapter.rb @@ -201,16 +201,12 @@ module ActiveRecord protected def log(sql, name) - if block_given? - result = nil - ms = Benchmark.ms { result = yield } - @runtime += ms - log_info(sql, name, ms) - result - else - log_info(sql, name, 0) - nil + event = ActiveSupport::Orchestra.instrument(:sql, :sql => sql, :name => name) do + yield if block_given? end + @runtime += event.duration + log_info(sql, name, event.duration) + event.result rescue Exception => e # Log message and raise exception. # Set last_verification to 0, so that connection gets verified @@ -221,10 +217,10 @@ module ActiveRecord raise translate_exception(e, message) end - def translate_exception(e, message) - # override in derived class - ActiveRecord::StatementInvalid.new(message) - end + def translate_exception(e, message) + # override in derived class + ActiveRecord::StatementInvalid.new(message) + end def format_log_entry(message, dump = nil) if ActiveRecord::Base.colorize_logging |