* Dropped all references to Resque * Moved all jobs under app/workers since that's the Sidekiq convention * Renamed Jobs module to Worker to match new location * Adapted all jobs to Sidekiq * Replaced all enqueue calls with perform_async * Dropped Resque hacks from specs and features, replaced with sidekig/testing in RSpec and sidekig/testing/inline in Cucumber * Updated scripts to start a Sidekiq server * Inline Sidekiq sinatra app * Let Sidekiq create the actual Redis instance * Workaround already initialized constant warnings in service models * Resolved ToDo in one job definition by creating proper exception clases for some errors in receiving posts * Added sidekiq section to configuration to make it completly configurable to the user * Add Sidekiq middleware for clean backtraces * Delay HttpMulti retry to give offline pods a chance to come back up * Do not retry on GUID already taken and alike errors * Be graceful about deleted posts in GatherOEmbedData
23 lines
509 B
Ruby
23 lines
509 B
Ruby
require 'spec_helper'
|
|
|
|
describe Workers::ReceiveEncryptedSalmon do
|
|
before do
|
|
@user = alice
|
|
@xml = '<xml></xml>'
|
|
User.stub(:find){ |id|
|
|
if id == @user.id
|
|
@user
|
|
else
|
|
nil
|
|
end
|
|
}
|
|
end
|
|
it 'calls receive_salmon' do
|
|
zord = mock
|
|
|
|
zord.should_receive(:perform!)
|
|
Postzord::Receiver::Private.should_receive(:new).with(@user, hash_including(:salmon_xml => @xml)).and_return(zord)
|
|
|
|
Workers::ReceiveEncryptedSalmon.new.perform(@user.id, @xml)
|
|
end
|
|
end
|