refactored message handler spec
This commit is contained in:
parent
ce805c8167
commit
7e7c4c3431
4 changed files with 64 additions and 61 deletions
|
|
@ -11,6 +11,10 @@ class MessageHandler
|
|||
@queue = EM::Queue.new
|
||||
end
|
||||
|
||||
def clear_queue
|
||||
@queue = EM::Queue.new
|
||||
end
|
||||
|
||||
def add_get_request(destinations)
|
||||
[*destinations].each{ |dest| @queue.push(Message.new(:get, dest))}
|
||||
end
|
||||
|
|
|
|||
|
|
@ -22,6 +22,10 @@ describe PublicsController do
|
|||
end
|
||||
|
||||
describe '#receive' do
|
||||
before do
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(FakeHttpRequest.new(:success))
|
||||
end
|
||||
|
||||
context 'success cases' do
|
||||
it 'should 200 on successful receipt of a request' do
|
||||
EM::run {
|
||||
|
|
|
|||
|
|
@ -5,58 +5,53 @@
|
|||
require 'spec_helper'
|
||||
|
||||
describe MessageHandler do
|
||||
before do
|
||||
unstub_mocha_stubs
|
||||
end
|
||||
after do
|
||||
stub_sockets
|
||||
MessageHandler.any_instance.stubs(:add_post_request)
|
||||
end
|
||||
let(:handler) {MessageHandler.new()}
|
||||
let(:message_body) {"I want to pump you up"}
|
||||
let(:message_urls) {["http://www.google.com/", "http://yahoo.com/", "http://foo.com/"]}
|
||||
let(:success) {FakeHttpRequest.new(:success)}
|
||||
let(:failure) {FakeHttpRequest.new(:failure)}
|
||||
|
||||
before do
|
||||
@handler = MessageHandler.new
|
||||
@message_body = "I want to pump you up"
|
||||
@message_urls = ["http://www.google.com/", "http://yahoo.com/", "http://foo.com/"]
|
||||
handler.clear_queue
|
||||
end
|
||||
|
||||
after(:all) do
|
||||
handler.clear_queue
|
||||
end
|
||||
|
||||
describe 'GET messages' do
|
||||
describe 'creating a GET query' do
|
||||
it 'should be able to add a GET query to the queue with required destinations' do
|
||||
EventMachine.run{
|
||||
@handler.add_get_request(@message_urls)
|
||||
@handler.size.should == @message_urls.size
|
||||
handler.add_get_request(message_urls)
|
||||
handler.size.should == message_urls.size
|
||||
EventMachine.stop
|
||||
}
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
describe 'processing a GET query' do
|
||||
it 'should remove sucessful http requests from the queue' do
|
||||
request = FakeHttpRequest.new(:success)
|
||||
request.should_receive(:get).and_return(request)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(request)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(success)
|
||||
|
||||
EventMachine.run {
|
||||
@handler.add_get_request("http://www.google.com/")
|
||||
@handler.size.should == 1
|
||||
@handler.process
|
||||
@handler.size.should == 0
|
||||
handler.add_get_request("http://www.google.com/")
|
||||
handler.size.should == 1
|
||||
handler.process
|
||||
handler.size.should == 0
|
||||
EventMachine.stop
|
||||
}
|
||||
end
|
||||
|
||||
it 'should only retry a bad request the correct number of times' do
|
||||
request = FakeHttpRequest.new(:failure)
|
||||
request.should_receive(:get).exactly(MessageHandler::NUM_TRIES).times.and_return(request)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(request)
|
||||
failure.should_receive(:get).exactly(MessageHandler::NUM_TRIES).times.and_return(failure)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(failure)
|
||||
|
||||
EventMachine.run {
|
||||
@handler.add_get_request("http://asdfsdajfsdfbasdj.com/")
|
||||
@handler.size.should == 1
|
||||
@handler.process
|
||||
@handler.size.should == 0
|
||||
handler.add_get_request("http://asdfsdajfsdfbasdj.com/")
|
||||
handler.size.should == 1
|
||||
handler.process
|
||||
handler.size.should == 0
|
||||
|
||||
EventMachine.stop
|
||||
}
|
||||
|
|
@ -66,34 +61,37 @@ describe MessageHandler do
|
|||
|
||||
describe 'POST messages' do
|
||||
it 'should be able to add a post message to the queue' do
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(success)
|
||||
|
||||
EventMachine.run {
|
||||
@handler.size.should ==0
|
||||
@handler.add_post_request(@message_urls.first, @message_body)
|
||||
@handler.size.should == 1
|
||||
handler.size.should ==0
|
||||
handler.add_post_request(message_urls.first, message_body)
|
||||
handler.size.should == 1
|
||||
|
||||
EventMachine.stop
|
||||
}
|
||||
end
|
||||
|
||||
it 'should be able to insert many posts into the queue' do
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(success)
|
||||
|
||||
EventMachine.run {
|
||||
@handler.size.should == 0
|
||||
@handler.add_post_request(@message_urls, @message_body)
|
||||
@handler.size.should == @message_urls.size
|
||||
handler.size.should == 0
|
||||
handler.add_post_request(message_urls, message_body)
|
||||
handler.size.should == message_urls.size
|
||||
EventMachine.stop
|
||||
}
|
||||
end
|
||||
|
||||
it 'should post a single message to a given URL' do
|
||||
request = FakeHttpRequest.new(:success)
|
||||
request.should_receive(:post).and_return(request)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(request)
|
||||
EventMachine.run{
|
||||
success.should_receive(:post).and_return(success)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(success)
|
||||
|
||||
@handler.add_post_request(@message_urls.first, @message_body)
|
||||
@handler.size.should == 1
|
||||
@handler.process
|
||||
@handler.size.should == 0
|
||||
EventMachine.run{
|
||||
handler.add_post_request(message_urls.first, message_body)
|
||||
handler.size.should == 1
|
||||
handler.process
|
||||
handler.size.should == 0
|
||||
|
||||
EventMachine.stop
|
||||
|
||||
|
|
@ -110,8 +108,8 @@ describe MessageHandler do
|
|||
feed_location = "http://google.com/"
|
||||
|
||||
EventMachine.run {
|
||||
@handler.add_hub_notification(destination, feed_location)
|
||||
q = @handler.instance_variable_get(:@queue)
|
||||
handler.add_hub_notification(destination, feed_location)
|
||||
q = handler.instance_variable_get(:@queue)
|
||||
|
||||
message = ""
|
||||
q.pop{|m| message = m}
|
||||
|
|
@ -127,35 +125,33 @@ describe MessageHandler do
|
|||
describe "Mixed Queries" do
|
||||
|
||||
it 'should process both POST and GET requests in the same queue' do
|
||||
request = FakeHttpRequest.new(:success)
|
||||
request.should_receive(:get).exactly(3).times.and_return(request)
|
||||
request.should_receive(:post).exactly(3).times.and_return(request)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(request)
|
||||
success.should_receive(:get).exactly(3).times.and_return(success)
|
||||
success.should_receive(:post).exactly(3).times.and_return(success)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(success)
|
||||
|
||||
EventMachine.run{
|
||||
@handler.add_post_request(@message_urls,@message_body)
|
||||
@handler.size.should == 3
|
||||
@handler.add_get_request(@message_urls)
|
||||
@handler.size.should == 6
|
||||
@handler.process
|
||||
handler.add_post_request(message_urls, message_body)
|
||||
handler.size.should == 3
|
||||
handler.add_get_request(message_urls)
|
||||
handler.size.should == 6
|
||||
handler.process
|
||||
timer = EventMachine::Timer.new(1) do
|
||||
@handler.size.should == 0
|
||||
handler.size.should == 0
|
||||
EventMachine.stop
|
||||
end
|
||||
}
|
||||
end
|
||||
|
||||
it 'should be able to have seperate POST and GET have different callbacks' do
|
||||
request = FakeHttpRequest.new(:success)
|
||||
request.should_receive(:get).exactly(1).times.and_return(request)
|
||||
request.should_receive(:post).exactly(1).times.and_return(request)
|
||||
success.should_receive(:get).exactly(1).times.and_return(success)
|
||||
success.should_receive(:post).exactly(1).times.and_return(success)
|
||||
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(request)
|
||||
EventMachine::HttpRequest.stub!(:new).and_return(success)
|
||||
|
||||
EventMachine.run{
|
||||
@handler.add_post_request(@message_urls.first,@message_body)
|
||||
@handler.add_get_request(@message_urls.first)
|
||||
@handler.process
|
||||
handler.add_post_request(message_urls.first, message_body)
|
||||
handler.add_get_request(message_urls.first)
|
||||
handler.process
|
||||
|
||||
EventMachine.stop
|
||||
}
|
||||
|
|
|
|||
|
|
@ -29,7 +29,6 @@ RSpec.configure do |config|
|
|||
|
||||
config.before(:each) do
|
||||
stub_sockets
|
||||
MessageHandler.any_instance.stubs(:add_post_request)
|
||||
DatabaseCleaner.clean
|
||||
end
|
||||
end
|
||||
|
|
|
|||
Loading…
Reference in a new issue