Sha256: 96ec71825f6d1a566cd102196f84043220634c619d712e2e79e8ba77ca7e47ff

Contents?: true

Size: 1.62 KB

Versions: 4

Compression:

Stored size: 1.62 KB

Contents

# typed: true

module Datadog
  module Core
    module Utils
      # Common database-related utility functions.
      module Time
        include Kernel # Ensure that kernel methods are always available (https://sorbet.org/docs/error-reference#7003)

        module_function

        # Current monotonic time
        #
        # @param unit [Symbol] unit for the resulting value, same as ::Process#clock_gettime, defaults to :float_second
        # @return [Numeric] timestamp in the requested unit, since some unspecified starting point
        def get_time(unit = :float_second)
          Process.clock_gettime(Process::CLOCK_MONOTONIC, unit)
        end

        # Current wall time.
        #
        # @return [Time] current time object
        def now
          ::Time.now
        end

        # Overrides the implementation of `#now
        # with the provided callable.
        #
        # Overriding the method `#now` instead of
        # indirectly calling `block` removes
        # one level of method call overhead.
        #
        # @param block [Proc] block that returns a `Time` object representing the current wall time
        def now_provider=(block)
          define_singleton_method(:now, &block)
        end

        def measure
          before = get_time
          yield
          after = get_time
          after - before
        end

        def as_utc_epoch_ns(time)
          # we use #to_r instead of #to_f because Float doesn't have enough precision to represent exact nanoseconds, see
          # https://rubyapi.org/3.0/o/time#method-i-to_f
          (time.to_r * 1_000_000_000).to_i
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
ddtrace-1.2.0 lib/datadog/core/utils/time.rb
ddtrace-1.1.0 lib/datadog/core/utils/time.rb
ddtrace-1.0.0 lib/datadog/core/utils/time.rb
ddtrace-1.0.0.beta2 lib/datadog/core/utils/time.rb