Sha256: 7a720edfe3b608c492d45869153467b79dab3fefd12c1ff21ae815a2b0f6a9d2

Contents?: true

Size: 1.87 KB

Versions: 17

Compression:

Stored size: 1.87 KB

Contents

require 'date'
require 'time'
require 'protobuf/logging'

module Protobuf
  module Rpc
    class Stat
      attr_accessor :mode, :start_time, :end_time, :request_size, :dispatcher
      attr_accessor :response_size, :client, :service, :method_name
      attr_reader   :server

      MODES = [:SERVER, :CLIENT].freeze

      def initialize(mode = :SERVER)
        @mode = mode
        @request_size = 0
        @response_size = 0
        start
      end

      attr_writer :client

      def client
        @client || nil
      end

      def elapsed_time
        (start_time && end_time ? "#{(end_time - start_time).round(4)}s" : nil)
      end

      def method_name
        @method_name ||= @dispatcher.try(:service).try(:method_name)
      end

      def server=(peer)
        case peer
        when Array
          @server = "#{peer[1]}:#{peer[0]}"
        when String
          @server = peer
        end
      end

      def service
        @service ||= @dispatcher.try(:service).class.name
      end

      def sizes
        if stopped?
          "#{@request_size}B/#{@response_size}B"
        else
          "#{@request_size}B/-"
        end
      end

      def start
        @start_time ||= ::Time.now
      end

      def stop
        start unless @start_time
        @end_time ||= ::Time.now
      end

      def stopped?
        !end_time.nil?
      end

      def rpc
        service && method_name ? "#{service}##{method_name}" : nil
      end

      def server?
        @mode == :SERVER
      end

      def client?
        @mode == :CLIENT
      end

      def to_s
        [
          server? ? "[SRV]" : "[CLT]",
          server? ? client : server,
          trace_id,
          rpc,
          sizes,
          elapsed_time,
          @end_time.try(:iso8601),
        ].compact.join(' - ')
      end

      def trace_id
        ::Thread.current.object_id.to_s(16)
      end

    end
  end
end

Version data entries

17 entries across 17 versions & 1 rubygems

Version Path
protobuf-3.10.0 lib/protobuf/rpc/stat.rb
protobuf-3.10.0.pre0 lib/protobuf/rpc/stat.rb
protobuf-3.9.0 lib/protobuf/rpc/stat.rb
protobuf-3.9.0.pre2 lib/protobuf/rpc/stat.rb
protobuf-3.9.0.pre lib/protobuf/rpc/stat.rb
protobuf-3.8.5 lib/protobuf/rpc/stat.rb
protobuf-3.8.5.pre0 lib/protobuf/rpc/stat.rb
protobuf-3.8.4 lib/protobuf/rpc/stat.rb
protobuf-3.8.3 lib/protobuf/rpc/stat.rb
protobuf-3.8.2 lib/protobuf/rpc/stat.rb
protobuf-3.8.1 lib/protobuf/rpc/stat.rb
protobuf-3.8.0 lib/protobuf/rpc/stat.rb
protobuf-3.8.0.pre1 lib/protobuf/rpc/stat.rb
protobuf-3.7.5 lib/protobuf/rpc/stat.rb
protobuf-3.7.4 lib/protobuf/rpc/stat.rb
protobuf-3.7.3 lib/protobuf/rpc/stat.rb
protobuf-3.7.2 lib/protobuf/rpc/stat.rb