diff options
author | Abdelkader Boudih <terminale@gmail.com> | 2014-05-18 19:20:06 +0000 |
---|---|---|
committer | Abdelkader Boudih <terminale@gmail.com> | 2014-05-18 19:20:06 +0000 |
commit | 68543de83612049e3254f7243b575039f102cd49 (patch) | |
tree | 09a5d0ef639239f8cdf5f31785645668188cb360 | |
parent | 53f08f98686942a0335a1b5d5362dc442461bc2f (diff) | |
download | rails-68543de83612049e3254f7243b575039f102cd49.tar.gz rails-68543de83612049e3254f7243b575039f102cd49.tar.bz2 rails-68543de83612049e3254f7243b575039f102cd49.zip |
Add Sucker Punch adapter/wrapper
-rw-r--r-- | Gemfile | 1 | ||||
-rw-r--r-- | Rakefile | 4 | ||||
-rw-r--r-- | lib/active_job/base.rb | 1 | ||||
-rw-r--r-- | lib/active_job/job_wrappers/sucker_punch_wrapper.rb | 11 | ||||
-rw-r--r-- | lib/active_job/queue_adapters/sucker_punch_adapter.rb | 14 | ||||
-rw-r--r-- | test/adapters/sucker_punch.rb | 2 |
6 files changed, 31 insertions, 2 deletions
@@ -4,3 +4,4 @@ gemspec gem 'resque' gem 'sidekiq' +gem 'sucker_punch'
\ No newline at end of file @@ -22,12 +22,12 @@ task :default => :test desc 'Run all adapter tests' task :test do - tasks = %w(test_inline test_resque test_sidekiq) + tasks = %w(test_inline test_resque test_sidekiq test_sucker_punch) run_without_aborting(*tasks) end -%w( inline resque sidekiq ).each do |adapter| +%w( inline resque sidekiq sucker_punch).each do |adapter| Rake::TestTask.new("test_#{adapter}") do |t| t.libs << 'test' t.test_files = FileList['test/cases/**/*_test.rb'] diff --git a/lib/active_job/base.rb b/lib/active_job/base.rb index d1fff27a3a..6cce770466 100644 --- a/lib/active_job/base.rb +++ b/lib/active_job/base.rb @@ -1,6 +1,7 @@ require 'active_job/queue_adapters/inline_adapter' require 'active_job/queue_adapters/resque_adapter' require 'active_job/queue_adapters/sidekiq_adapter' +require 'active_job/queue_adapters/sucker_punch_adapter' module ActiveJob class Base diff --git a/lib/active_job/job_wrappers/sucker_punch_wrapper.rb b/lib/active_job/job_wrappers/sucker_punch_wrapper.rb new file mode 100644 index 0000000000..80648792ca --- /dev/null +++ b/lib/active_job/job_wrappers/sucker_punch_wrapper.rb @@ -0,0 +1,11 @@ +module ActiveJob + module JobWrappers + class SuckerPunchWrapper + include SuckerPunch::Job + + def perform(job_name, *args) + job_name.perform(*args) + end + end + end +end diff --git a/lib/active_job/queue_adapters/sucker_punch_adapter.rb b/lib/active_job/queue_adapters/sucker_punch_adapter.rb new file mode 100644 index 0000000000..8191e5a1df --- /dev/null +++ b/lib/active_job/queue_adapters/sucker_punch_adapter.rb @@ -0,0 +1,14 @@ +require 'sucker_punch' +require 'active_job/job_wrappers/sucker_punch_wrapper' + +module ActiveJob + module QueueAdapters + class SuckerPunchAdapter + class << self + def queue(job, *args) + JobWrappers::SuckerPunchWrapper.new.async.perform(job, *args) + end + end + end + end +end diff --git a/test/adapters/sucker_punch.rb b/test/adapters/sucker_punch.rb new file mode 100644 index 0000000000..a373552262 --- /dev/null +++ b/test/adapters/sucker_punch.rb @@ -0,0 +1,2 @@ +require 'sucker_punch/testing/inline' +ActiveJob::Base.queue_adapter = ActiveJob::QueueAdapters::SuckerPunchAdapter |