* 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
20 lines
664 B
Ruby
20 lines
664 B
Ruby
require 'spec_helper'
|
|
|
|
describe "Dispatching" do
|
|
context "a comment retraction on a public post" do
|
|
it "should trigger a private dispatch" do
|
|
luke, leia, raph = set_up_friends
|
|
# Luke has a public post and comments on it
|
|
post = FactoryGirl.create(:status_message, :public => true, :author => luke.person)
|
|
|
|
comment = luke.comment!(post, "awesomesauseum")
|
|
|
|
inlined_jobs do
|
|
# Luke now retracts his comment
|
|
Postzord::Dispatcher::Public.should_not_receive(:new)
|
|
Postzord::Dispatcher::Private.should_receive(:new).and_return(stub(:post => true))
|
|
luke.retract(comment)
|
|
end
|
|
end
|
|
end
|
|
end
|