diff options
author | Rafael França <rafaelmfranca@gmail.com> | 2017-05-26 18:16:33 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-05-26 18:16:33 -0400 |
commit | 70d6f400c24e38a33f79240ee49fc6470f48f8b3 (patch) | |
tree | f44fdf1fec583920d376aa458fdce84366de8962 /activejob/lib | |
parent | 4c940b2dbfb457f67c6250b720f63501d74a45fd (diff) | |
parent | 4b04f56146f3f4e158d2d8ef6d88ef6495778df8 (diff) | |
download | rails-70d6f400c24e38a33f79240ee49fc6470f48f8b3.tar.gz rails-70d6f400c24e38a33f79240ee49fc6470f48f8b3.tar.bz2 rails-70d6f400c24e38a33f79240ee49fc6470f48f8b3.zip |
Merge pull request #25037 from mohitnatoo/adapter-inquirer
Provides friendlier way to access queue adapters of a job.
Diffstat (limited to 'activejob/lib')
-rw-r--r-- | activejob/lib/active_job/queue_adapter.rb | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/activejob/lib/active_job/queue_adapter.rb b/activejob/lib/active_job/queue_adapter.rb index 9dae80ffc2..b22d8b8347 100644 --- a/activejob/lib/active_job/queue_adapter.rb +++ b/activejob/lib/active_job/queue_adapter.rb @@ -7,6 +7,7 @@ module ActiveJob extend ActiveSupport::Concern included do + class_attribute :_queue_adapter_name, instance_accessor: false, instance_predicate: false class_attribute :_queue_adapter, instance_accessor: false, instance_predicate: false self.queue_adapter = :async end @@ -19,11 +20,15 @@ module ActiveJob _queue_adapter end + def queue_adapter_name + _queue_adapter_name + end + # Specify the backend queue provider. The default queue adapter # is the +:async+ queue. See QueueAdapters for more # information. def queue_adapter=(name_or_adapter_or_class) - self._queue_adapter = interpret_adapter(name_or_adapter_or_class) + interpret_adapter(name_or_adapter_or_class) end private @@ -31,16 +36,24 @@ module ActiveJob def interpret_adapter(name_or_adapter_or_class) case name_or_adapter_or_class when Symbol, String - ActiveJob::QueueAdapters.lookup(name_or_adapter_or_class).new + assign_adapter(name_or_adapter_or_class.to_s, + ActiveJob::QueueAdapters.lookup(name_or_adapter_or_class).new) else if queue_adapter?(name_or_adapter_or_class) - name_or_adapter_or_class + adapter_name = "#{name_or_adapter_or_class.class.name.demodulize.remove('Adapter').underscore}" + assign_adapter(adapter_name, + name_or_adapter_or_class) else raise ArgumentError end end end + def assign_adapter(adapter_name, queue_adapter) + self._queue_adapter_name = adapter_name + self._queue_adapter = queue_adapter + end + QUEUE_ADAPTER_METHODS = [:enqueue, :enqueue_at].freeze def queue_adapter?(object) |