mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
49 lines
1.3 KiB
Ruby
49 lines
1.3 KiB
Ruby
module ResqueJobsManager
|
|
def setup
|
|
ActiveJob::Base.queue_adapter = :resque
|
|
Resque.redis = Redis::Namespace.new 'active_jobs_int_test', redis: Redis.connect(url: "tcp://127.0.0.1:6379/12", :thread_safe => true)
|
|
Resque.logger = Rails.logger
|
|
unless can_run?
|
|
puts "Cannot run integration tests for resque. To be able to run integration tests for resque you need to install and start redis.\n"
|
|
exit
|
|
end
|
|
end
|
|
|
|
def clear_jobs
|
|
Resque.queues.each { |queue_name| Resque.redis.del "queue:#{queue_name}" }
|
|
Resque.redis.keys("delayed:*").each { |key| Resque.redis.del "#{key}" }
|
|
Resque.redis.del "delayed_queue_schedule"
|
|
end
|
|
|
|
def start_workers
|
|
@resque_thread = Thread.new do
|
|
w = Resque::Worker.new("integration_tests")
|
|
w.term_child = true
|
|
w.work(0.5)
|
|
end
|
|
@scheduler_thread = Thread.new do
|
|
Resque::Scheduler.configure do |c|
|
|
c.poll_sleep_amount = 0.5
|
|
c.dynamic = true
|
|
c.quiet = true
|
|
c.logfile = nil
|
|
end
|
|
Resque::Scheduler.master_lock.release!
|
|
Resque::Scheduler.run
|
|
end
|
|
end
|
|
|
|
def stop_workers
|
|
@resque_thread.kill
|
|
@scheduler_thread.kill
|
|
end
|
|
|
|
def can_run?
|
|
begin
|
|
Resque.redis.client.connect
|
|
rescue
|
|
return false
|
|
end
|
|
true
|
|
end
|
|
end
|