Sha256: bea8ee9cd59d099f2279567208ccdee5ff2e9d36d53b1f5cac8b2c84ad689e73

Contents?: true

Size: 853 Bytes

Versions: 15

Compression:

Stored size: 853 Bytes

Contents

#
# Copyright 2013-2014 Chef Software, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#

module Omnibus
  module Instrumentation
    include Logging

    def measure(label, &block)
      start = Time.now
      block.call
    ensure
      elapsed = Time.now - start
      log.info(log_key) { "#{label}: #{elapsed.to_f.round(4)}s" }
    end
  end
end

Version data entries

15 entries across 15 versions & 1 rubygems

Version Path
omnibus-5.4.0 lib/omnibus/instrumentation.rb
omnibus-5.3.0 lib/omnibus/instrumentation.rb
omnibus-5.2.0 lib/omnibus/instrumentation.rb
omnibus-5.1.0 lib/omnibus/instrumentation.rb
omnibus-5.0.0 lib/omnibus/instrumentation.rb
omnibus-4.1.0 lib/omnibus/instrumentation.rb
omnibus-4.0.0 lib/omnibus/instrumentation.rb
omnibus-4.0.0.rc.2 lib/omnibus/instrumentation.rb
omnibus-4.0.0.rc.1 lib/omnibus/instrumentation.rb
omnibus-3.2.2 lib/omnibus/instrumentation.rb
omnibus-4.0.0.beta.1 lib/omnibus/instrumentation.rb
omnibus-3.2.1 lib/omnibus/instrumentation.rb
omnibus-3.2.0 lib/omnibus/instrumentation.rb
omnibus-3.2.0.rc.3 lib/omnibus/instrumentation.rb
omnibus-3.2.0.rc.2 lib/omnibus/instrumentation.rb