Sha256: 5e0d45c3c9d1ddd5022a99f8c2eecf85a464b2ccdbd3df5deac7e662c76fb2a8

Contents?: true

Size: 1.52 KB

Versions: 4

Compression:

Stored size: 1.52 KB

Contents

# encoding: utf-8

module OneApm
  module TransactionAnalysis
    # summarizes performance data for all calls to segments
    # with the same metric_name
    class SegmentSummary
      attr_accessor :metric_name, :total_time, :exclusive_time, :call_count, :current_nest_count
      def initialize(metric_name, sample)
        @metric_name = metric_name
        @total_time, @exclusive_time, @call_count = 0,0,0
        @sample = sample
        @current_nest_count = 0
      end

      def <<(segment)
        if metric_name != segment.metric_name
          raise ArgumentError, "Metric Name Mismatch: #{segment.metric_name} != #{metric_name}"
        end

        # a nested segment should use the sum of the top level totals
        @total_time += segment.duration if current_nest_count == 0
        @exclusive_time += segment.exclusive_duration
        @call_count += 1
      end

      def average_time
        @total_time / @call_count
      end

      def average_exclusive_time
        @exclusive_time / @call_count
      end

      def exclusive_time_percentage
        return 0 unless @exclusive_time && @sample.duration && @sample.duration > 0
        @exclusive_time / @sample.duration
      end

      def total_time_percentage
        return 0 unless @total_time && @sample.duration && @sample.duration > 0
        @total_time / @sample.duration
      end

      def ui_name
        return @metric_name if @metric_name == 'Remainder'
        OneApm::MetricParser::MetricParser.parse(@metric_name).developer_name
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
oneapm_rpm-1.1.3 lib/one_apm/transaction/segment_summary.rb
oneapm_rpm-1.1.2 lib/one_apm/transaction/segment_summary.rb
oneapm_rpm-1.1.1 lib/one_apm/transaction/segment_summary.rb
oneapm_rpm-1.1.0 lib/one_apm/transaction/segment_summary.rb