aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@basecamp.com>2014-08-06 15:11:22 -0700
committerDavid Heinemeier Hansson <david@basecamp.com>2014-08-06 15:11:22 -0700
commit06ccd5f405a004275915102eb3ccc42b952ba549 (patch)
treeea847a54322421e608da96440e6622dc5f20e28f
parent38ee4fd8d3c46616bc8a09f7486de4a5069df91a (diff)
parent6ff5972c0db45c192af9c0d056d786c61821f29f (diff)
downloadrails-06ccd5f405a004275915102eb3ccc42b952ba549.tar.gz
rails-06ccd5f405a004275915102eb3ccc42b952ba549.tar.bz2
rails-06ccd5f405a004275915102eb3ccc42b952ba549.zip
Merge pull request #103 from cristianbica/adapter-fixes
Fixed qu, queue_classic, sneakers adapters
-rw-r--r--lib/active_job/queue_adapters/qu_adapter.rb8
-rw-r--r--lib/active_job/queue_adapters/queue_classic_adapter.rb6
-rw-r--r--lib/active_job/queue_adapters/sneakers_adapter.rb8
3 files changed, 13 insertions, 9 deletions
diff --git a/lib/active_job/queue_adapters/qu_adapter.rb b/lib/active_job/queue_adapters/qu_adapter.rb
index 7e69229801..cdf4ae4ce9 100644
--- a/lib/active_job/queue_adapters/qu_adapter.rb
+++ b/lib/active_job/queue_adapters/qu_adapter.rb
@@ -5,7 +5,9 @@ module ActiveJob
class QuAdapter
class << self
def enqueue(job, *args)
- Qu::Payload.new(klass: JobWrapper, args: [job, *args], queue: job.queue_name).push
+ Qu::Payload.new(klass: JobWrapper, args: [job.name, *args]).tap do |payload|
+ payload.instance_variable_set(:@queue, job.queue_name)
+ end.push
end
def enqueue_at(job, timestamp, *args)
@@ -14,8 +16,8 @@ module ActiveJob
end
class JobWrapper < Qu::Job
- def initialize(job, *args)
- @job = job
+ def initialize(job_name, *args)
+ @job = job_name.constantize
@args = args
end
diff --git a/lib/active_job/queue_adapters/queue_classic_adapter.rb b/lib/active_job/queue_adapters/queue_classic_adapter.rb
index db7189f076..c61e0e30db 100644
--- a/lib/active_job/queue_adapters/queue_classic_adapter.rb
+++ b/lib/active_job/queue_adapters/queue_classic_adapter.rb
@@ -5,7 +5,7 @@ module ActiveJob
class QueueClassicAdapter
class << self
def enqueue(job, *args)
- QC::Queue.new(job.queue_name).enqueue("#{JobWrapper.name}.perform", job, *args)
+ QC::Queue.new(job.queue_name).enqueue("#{JobWrapper.name}.perform", job.name, *args)
end
def enqueue_at(job, timestamp, *args)
@@ -14,8 +14,8 @@ module ActiveJob
end
class JobWrapper
- def self.perform(job, *args)
- job.new.execute *args
+ def self.perform(job_name, *args)
+ job_name.constantize.new.execute *args
end
end
end
diff --git a/lib/active_job/queue_adapters/sneakers_adapter.rb b/lib/active_job/queue_adapters/sneakers_adapter.rb
index f7da691935..094b128547 100644
--- a/lib/active_job/queue_adapters/sneakers_adapter.rb
+++ b/lib/active_job/queue_adapters/sneakers_adapter.rb
@@ -10,7 +10,7 @@ module ActiveJob
def enqueue(job, *args)
@monitor.synchronize do
JobWrapper.from_queue job.queue_name
- JobWrapper.enqueue [ job, *args ]
+ JobWrapper.enqueue ActiveSupport::JSON.encode([ job.name, *args ])
end
end
@@ -22,8 +22,10 @@ module ActiveJob
class JobWrapper
include Sneakers::Worker
- def work(job, *args)
- job.new.execute *args
+ def work(msg)
+ job_name, *args = ActiveSupport::JSON.decode(msg)
+ job_name.constantize.new.execute *args
+ ack!
end
end
end