Module: Reqless::JobReservers::Strategies::Sources

Defined in:
lib/reqless/job_reservers/strategies/sources.rb

Overview

This module provides the different kinds of queue sources used by qmore

Defined Under Namespace

Classes: Background

Class Method Summary collapse

Class Method Details

.direct(client) ⇒ Object

Direct source uses a client to generate the queues we should pull work from. Ignores any queues that do not have tasks available.



12
13
14
15
16
17
18
19
20
21
22
# File 'lib/reqless/job_reservers/strategies/sources.rb', line 12

def self.direct(client)
  Enumerator.new do |yielder|
    queues = client.queues.counts.select do |queue|
      %w(waiting recurring depends stalled scheduled).any? {|state| queue[state].to_i > 0 }
    end

    queues.each do |queue|
      yielder << client.queues[queue['name']]
    end
  end
end