class MultiWorker::Adapters::Toro

Public Class Methods

configure(base, opts={}) click to toggle source
# File lib/multi_worker/adapters/toro.rb, line 4
def self.configure(base, opts={})
  base.class_eval do
    include ::Toro::Worker

    @queue = opts[:queue]
    @toro_options = {queue: @queue}

    if opts.has_key?(:retry)
      @retry = opts[:retry]
      case @retry
        when Hash
          @toro_options.merge!(retry_interval: @retry[:delay])
        when Fixnum, ActiveSupport::Duration
          @toro_options.merge!(retry_interval: @retry)
      end
    end

    toro_options @toro_options

    def self.perform(*args)
      self.new.perform(*args)
    end

    def perform_async(*args)
      self.class.perform_async(*args)
    end
  end
end
perform(*args) click to toggle source
# File lib/multi_worker/adapters/toro.rb, line 23
def self.perform(*args)
  self.new.perform(*args)
end
rake_task() click to toggle source
# File lib/multi_worker/adapters/toro.rb, line 33
def self.rake_task
  require 'rake'
  require 'toro'
  require 'tasks/tasks'
  ::Rake::Task["toro"]
end

Public Instance Methods

perform_async(*args) click to toggle source
# File lib/multi_worker/adapters/toro.rb, line 27
def perform_async(*args)
  self.class.perform_async(*args)
end