Sha256: ee5bedd83958e4a8cba483bfdc096b076c85a96bc213b1959cf8d54b89153fb0

Contents?: true

Size: 1.91 KB

Versions: 5

Compression:

Stored size: 1.91 KB

Contents

require 'spec_helper'

describe Instrumental::Agent, "disabled" do
  before do
    random_port = Time.now.to_i % rand(2000)
    base_port = 4000
    @port = base_port + random_port
    TestServer.start(@port)
  end

  after do
    TestServer.stop
  end

  subject { Instrumental::Agent.new('test_token', :collector => "127.0.0.1:#{@port}", :enabled => false) }

  it 'should not connect to the server' do
    subject.gauge('gauge_test', 123)
    EM.next do
      TestServer.last.should be_nil
    end
  end

end

describe Instrumental::Agent do
  before do
    random_port = Time.now.to_i % rand(2000)
    base_port = 4000
    @port = base_port + random_port
    TestServer.start(@port)
  end

  after do
    TestServer.stop
  end

  subject { Instrumental::Agent.new('test_token', :collector => "127.0.0.1:#{@port}") }

  it 'should announce itself including version' do
    subject.gauge('gauge_test', 123)
    EM.next do
      TestServer.last.buffer.first.should match(/hello.*version/)
    end
  end

  it 'should authenticate using the token' do
    subject.gauge('gauge_test', 123)
    EM.next do
      TestServer.last.buffer[1].should == "authenticate test_token"
    end
  end

  it 'should report a gauge to the collector' do
    now = Time.now
    subject.gauge('gauge_test', 123)
    EM.next do
      TestServer.last.buffer.last.should == "gauge gauge_test 123 #{now.to_i}"
    end
  end

  it 'should report a gauge to the collector with a set time' do
    subject.gauge('gauge_test', 123, 555)
    EM.next do
      TestServer.last.buffer.last.should == 'gauge gauge_test 123 555'
    end
  end

  it "should automatically reconnect" do
    EM.next do
      subject.gauge('gauge_test', 123, 555)
    end
    EM.next do
      subject.connection.close_connection(false)
    end
    EM.next do
      subject.gauge('gauge_test', 444, 555)
    end
    EM.next do
      TestServer.last.buffer.last.should == 'gauge gauge_test 444 555'
    end
  end

end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
instrumental_agent-0.1.6 spec/agent_spec.rb
instrumental_agent-0.1.5 spec/agent_spec.rb
instrumental_agent-0.1.4 spec/agent_spec.rb
instrumental_agent-0.1.3 spec/agent_spec.rb
instrumental_agent-0.1.2 spec/agent_spec.rb