|
require 'rails_helper'
describe Agents::HipchatAgent do
before(:each) do
@valid_params = {
'auth_token' => 'token',
'room_name' => 'test',
'username' => "{{username}}",
'message' => "{{message}}",
'notify' => 'false',
'color' => 'yellow',
}
@checker = Agents::HipchatAgent.new(:name => "somename", :options => @valid_params)
@checker.user = users(:jane)
@checker.save!
@event = Event.new
@event.agent = agents(:bob_weather_agent)
@event.payload = { :room_name => 'test room', :message => 'Looks like its going to rain', username: "Huggin user "}
@event.save!
end
describe "validating" do
before do
expect(@checker).to be_valid
end
it "should require the basecamp username" do
@checker.options['auth_token'] = nil
expect(@checker).not_to be_valid
end
it "should require the basecamp password" do
@checker.options['room_name'] = nil
expect(@checker).not_to be_valid
end
it "should require the basecamp user_id" do
@checker.options['room_name'] = nil
@checker.options['room_name_path'] = 'jsonpath'
expect(@checker).to be_valid
end
it "should also allow a credential" do
@checker.options['auth_token'] = nil
expect(@checker).not_to be_valid
@checker.user.user_credentials.create :credential_name => 'hipchat_auth_token', :credential_value => 'something'
expect(@checker.reload).to be_valid
end
end
describe "#validate_auth_token" do
it "should return true when valid" do
any_instance_of(HipChat::Client) do |klass|
stub(klass).rooms { true }
end
expect(@checker.validate_auth_token).to be true
end
it "should return false when invalid" do
any_instance_of(HipChat::Client) do |klass|
stub(klass).rooms { raise HipChat::UnknownResponseCode.new }
end
expect(@checker.validate_auth_token).to be false
end
end
describe "#complete_room_name" do
it "should return a array of hashes" do
any_instance_of(HipChat::Client) do |klass|
stub(klass).rooms { [OpenStruct.new(name: 'test'), OpenStruct.new(name: 'test1')] }
end
expect(@checker.complete_room_name).to eq [{text: 'test', id: 'test'},{text: 'test1', id: 'test1'}]
end
end
describe "#receive" do
it "send a message to the hipchat" do
any_instance_of(HipChat::Room) do |obj|
mock(obj).send(@event.payload[:username][0..14], @event.payload[:message], {:notify => false, :color => 'yellow'})
end
@checker.receive([@event])
end
end
describe "#working?" do
it "should not be working until the first event was received" do
expect(@checker).not_to be_working
@checker.last_receive_at = Time.now
expect(@checker).to be_working
end
it "should not be working when the last error occured after the last received event" do
@checker.last_receive_at = Time.now - 1.minute
@checker.last_error_log_at = Time.now
expect(@checker).not_to be_working
end
it "should be working when the last received event occured after the last error" do
@checker.last_receive_at = Time.now
@checker.last_error_log_at = Time.now - 1.minute
expect(@checker).to be_working
end
end
end
|