Sha256: 126d2cb3cd6cb47c3093760f5c5145cd63e80c8500cb6f92ef14c88bfd231662
Contents?: true
Size: 1.79 KB
Versions: 8
Compression:
Stored size: 1.79 KB
Contents
require 'rhoconnect' require File.join(File.dirname(__FILE__),'..','spec_helper') require File.join(File.dirname(__FILE__),'..','..','lib','rhoconnect','server.rb') STATS_RECORD_RESOLUTION = 2 unless defined? STATS_RECORD_RESOLUTION STATS_RECORD_SIZE = 8 unless defined? STATS_RECORD_SIZE include Rhoconnect include Rhoconnect::Stats describe "Middleware" do before(:each) do @now = 10.0 Store.db.flushdb app = mock('app') app.stub!(:call) Rhoconnect.stats = true Rhoconnect::Server.enable :stats @middleware_new_routes = Middleware.new(app) Store.stub!(:lock).and_yield end after(:each) do Rhoconnect.stats = false Rhoconnect::Server.disable :stats end it "should compute http average" do Time.stub!(:now).and_return { @now += 0.3; @now } env = { 'rack.request.query_hash' => { 'source_name' => 'SampleAdapter' }, 'REQUEST_METHOD' => 'GET', 'PATH_INFO' => '/api/application/query' } 10.times { @middleware_new_routes.call(env) } metric = 'http:GET:/api/application/query:SampleAdapter' Record.key(metric).should == "stat:#{metric}" # The conversion algorithm (float to string) currently checks two precisions. # In Ruby 1.9, it tries 16 digits and if that's not enough it then uses 17. # In 1.8, it's the same but with 15 and 16. if RUBY_VERSION =~ /1.9/ Record.range(metric, 0, -1).should == [ "2.0,0.6000000000000014:12", "2.0,0.6000000000000014:14", "2.0,0.6000000000000014:16", "2.0,0.6000000000000014:18" ] else Record.range(metric, 0, -1).should == [ "2.0,0.600000000000002:12", "2.0,0.600000000000002:14", "2.0,0.600000000000002:16", "2.0,0.600000000000002:18" ] end end end
Version data entries
8 entries across 8 versions & 1 rubygems