aboutsummaryrefslogtreecommitdiffstats
path: root/activejob/lib/active_job/queue_adapter.rb
diff options
context:
space:
mode:
authorTamir Duberstein <tamird@gmail.com>2015-03-11 14:57:13 -0700
committerTamir Duberstein <tamird@gmail.com>2015-03-11 15:58:41 -0700
commitfb26645c1ed9d3b74ec421839c9732706f74f5c0 (patch)
treedd2168bf01af4a55ec73353e6489d9e727d0710d /activejob/lib/active_job/queue_adapter.rb
parentc696cffcf62e29a1214b9bcf6353d047e4fbfef2 (diff)
downloadrails-fb26645c1ed9d3b74ec421839c9732706f74f5c0.tar.gz
rails-fb26645c1ed9d3b74ec421839c9732706f74f5c0.tar.bz2
rails-fb26645c1ed9d3b74ec421839c9732706f74f5c0.zip
`ActiveJob::QueueAdapters::*` are no longer singletons
Diffstat (limited to 'activejob/lib/active_job/queue_adapter.rb')
-rw-r--r--activejob/lib/active_job/queue_adapter.rb38
1 files changed, 29 insertions, 9 deletions
diff --git a/activejob/lib/active_job/queue_adapter.rb b/activejob/lib/active_job/queue_adapter.rb
index aa3ebdbc7b..23b5f7de75 100644
--- a/activejob/lib/active_job/queue_adapter.rb
+++ b/activejob/lib/active_job/queue_adapter.rb
@@ -14,20 +14,40 @@ module ActiveJob
# Specify the backend queue provider. The default queue adapter
# is the :inline queue. See QueueAdapters for more
# information.
- def queue_adapter=(name_or_adapter)
- @@queue_adapter = \
- case name_or_adapter
- when Symbol, String
- load_adapter(name_or_adapter)
+ def queue_adapter=(name_or_adapter_or_class)
+ case name_or_adapter_or_class
+ when Symbol, String
+ self.queue_adapter = load_adapter(name_or_adapter_or_class)
+ else
+ @@queue_adapter = if queue_adapter?(name_or_adapter_or_class)
+ name_or_adapter_or_class
+ elsif queue_adapter_class?(name_or_adapter_or_class)
+ ActiveSupport::Deprecation.warn "Passing an adapter class is deprecated " \
+ "and will be removed in Rails 5.1. Please pass an adapter name " \
+ "(.queue_adapter = :#{name_or_adapter_or_class.name.demodulize.remove('Adapter').underscore}) " \
+ "or an instance (.queue_adapter = #{name_or_adapter_or_class.name}.new) instead."
+ name_or_adapter_or_class.new
else
- name_or_adapter if name_or_adapter.respond_to?(:enqueue)
+ raise ArgumentError
end
+ end
end
private
- def load_adapter(name)
- "ActiveJob::QueueAdapters::#{name.to_s.camelize}Adapter".constantize
- end
+
+ QUEUE_ADAPTER_METHODS = [:enqueue, :enqueue_at].freeze
+
+ def queue_adapter?(object)
+ QUEUE_ADAPTER_METHODS.all? { |meth| object.respond_to?(meth) }
+ end
+
+ def queue_adapter_class?(object)
+ object.is_a?(Class) && QUEUE_ADAPTER_METHODS.all? { |meth| object.public_method_defined?(meth) }
+ end
+
+ def load_adapter(name)
+ "ActiveJob::QueueAdapters::#{name.to_s.camelize}Adapter".constantize.new
+ end
end
end
end