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