Sha256: c24e622b4720a36971fcf5893bd9db34741454ab9c30309f2d318a08bfbb72cb

Contents?: true

Size: 838 Bytes

Versions: 18

Compression:

Stored size: 838 Bytes

Contents

module Staccato
  # Timing Hit type field definitions
  # @author Tony Pitale
  class Timing
    # Timing field definitions
    FIELDS = {
      category: 'utc',
      variable: 'utv',
      label: 'utl',
      time: 'utt',

      # more specific timings
      page_load_time: 'plt',
      dns_time: 'dns',
      page_download_time: 'pdt',
      redirect_response_time: 'rrt',
      tcp_connect_time: 'tcp',
      server_response_time: 'srt'
    }

    include Hit

    # timing hit type
    def type
      :timing
    end

    # tracks the timing hit type
    # @param block [#call] block is executed and time recorded
    def track!(&block)
      if block_given?
        start_at = Time.now
        block.call
        end_at = Time.now

        self.options.time = (end_at - start_at).to_i*1000
      end

      super
    end
  end
end

Version data entries

18 entries across 18 versions & 1 rubygems

Version Path
staccato-0.5.3 lib/staccato/timing.rb
staccato-0.5.2 lib/staccato/timing.rb
staccato-0.5.1 lib/staccato/timing.rb
staccato-0.5.0 lib/staccato/timing.rb
staccato-0.4.7 lib/staccato/timing.rb
staccato-0.4.6 lib/staccato/timing.rb
staccato-0.4.5 lib/staccato/timing.rb
staccato-0.4.4 lib/staccato/timing.rb
staccato-0.4.3 lib/staccato/timing.rb
staccato-0.4.2 lib/staccato/timing.rb
staccato-0.4.1 lib/staccato/timing.rb
staccato-0.4.0 lib/staccato/timing.rb
staccato-0.3.1 lib/staccato/timing.rb
staccato-0.3.0 lib/staccato/timing.rb
staccato-0.2.1 lib/staccato/timing.rb
staccato-0.2.0 lib/staccato/timing.rb
staccato-0.1.1 lib/staccato/timing.rb
staccato-0.1.0 lib/staccato/timing.rb