module ScoutApm::Instruments::Resque

Public Instance Methods

around_perform_with_scout_instruments(*args) { || ... } click to toggle source
# File lib/scout_apm/instruments/resque.rb, line 4
def around_perform_with_scout_instruments(*args)
  job_name = self.to_s
  queue = find_queue

  if job_name == "ActiveJob::QueueAdapters::ResqueAdapter::JobWrapper"
    job_name = args.first["job_class"] rescue job_name
    queue = args.first["queue_name"] rescue queue_name
  end

  req = ScoutApm::RequestManager.lookup

  begin
    req.start_layer(ScoutApm::Layer.new('Queue', queue))
    started_queue = true
    req.start_layer(ScoutApm::Layer.new('Job', job_name))
    started_job = true

    yield
  rescue => e
    req.error!
    raise
  ensure
    req.stop_layer if started_job
    req.stop_layer if started_queue
  end
end
find_queue() click to toggle source
# File lib/scout_apm/instruments/resque.rb, line 31
def find_queue
  return @queue if @queue
  return queue if self.respond_to?(:queue)
  return "unknown"
end