Sha256: 4b3c272f3c9f72536b8419245dee467f25ad5ab9a36796935c5f04585b3ef5f9

Contents?: true

Size: 1.93 KB

Versions: 6

Compression:

Stored size: 1.93 KB

Contents

module Bench
  class Statistics
    include Logging
    
    def initialize(concurrency,iterations,total_time,sessions)
      @sessions = sessions
      @rows = {} # row key is result.marker;
      @total_count = 0
      @total_time = total_time
      @concurrency,@iterations = concurrency,iterations
    end
    
    def process
      @sessions.each do |session|
        session.results.each do |marker,results|
          results.each do |result|
            @rows[result.marker] ||= {}
            row = @rows[result.marker]
            row[:min] ||= 0.0
            row[:max] ||= 0.0
            row[:count] ||= 0
            row[:total_time] ||= 0.0
            row[:errors] ||= 0
            row[:verification_errors] ||= 0
            row[:min] = result.time if result.time < row[:min] || row[:min] == 0
            row[:max] = result.time if result.time > row[:max]
            row[:count] += 1.0
            row[:total_time] += result.time            
            row[:errors] += 1 if result.error
            row[:verification_errors] += result.verification_error
            @total_count += 1
          end
        end
      end
      self
    end
    
    def average(row)
      row[:total_time] / row[:count]
    end
    
    def print_stats
      logger.info "Statistics:"
      @rows.each do |marker,row|
        logger.info "Request %-15s: min: %0.4f, max: %0.4f, avg: %0.4f, err: %d, verification err: %d" % [marker, row[:min], row[:max], average(row), row[:errors], row[:verification_errors]]
      end
      logger.info "Verify Error       : #{Bench.verify_error}"
      logger.info "Concurrency        : #{@concurrency}"
      logger.info "Iterations         : #{@iterations}"
      logger.info "Total Count        : #{@total_count}"
      logger.info "Total Time         : #{@total_time}"
      logger.info "Throughput(req/s)  : #{@total_count / @total_time}"
      logger.info "Throughput(req/min): #{(@total_count / @total_time) * 60.0}"
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
rhosync-2.0.0.beta7 bench/lib/bench/statistics.rb
rhosync-2.0.0.beta6 bench/lib/bench/statistics.rb
rhosync-2.0.0.beta4 bench/lib/bench/statistics.rb
rhosync-2.0.0.beta3 bench/lib/bench/statistics.rb
rhosync-2.0.0.beta2 bench/lib/bench/statistics.rb
rhosync-2.0.0.beta1 bench/lib/bench/statistics.rb