* 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
946 B
Ruby
23 lines
946 B
Ruby
# Copyright (c) 2010-2011, Diaspora Inc. This file is
|
|
# licensed under the Affero General Public License version 3 or later. See
|
|
# the COPYRIGHT file.
|
|
|
|
module Workers
|
|
class Base
|
|
include Sidekiq::Worker
|
|
sidekiq_options timeout: AppConfig.environment.sidekiq.timeout.to_i,
|
|
backtrace: ((bt = AppConfig.environment.sidekiq.backtrace.get) && bt.to_i),
|
|
retry: AppConfig.environment.sidekiq.retry.to_i
|
|
|
|
# In the long term we need to eliminate the cause of these
|
|
def suppress_annoying_errors(&block)
|
|
yield
|
|
rescue Diaspora::ContactRequiredUnlessRequest,
|
|
Diaspora::RelayableObjectWithoutParent => e
|
|
Rails.logger.info("error on receive: #{e.class}")
|
|
rescue ActiveRecord::RecordInvalid => e
|
|
Rails.logger.info("failed to save received object: #{e.record.errors.full_messages}")
|
|
raise e unless e.message.match(/already been taken/)
|
|
end
|
|
end
|
|
end
|