Class: MergeRequests::MergeabilityCheckBatchWorker

Inherits:
Object
  • Object
show all
Includes:
ApplicationWorker
Defined in:
app/workers/merge_requests/mergeability_check_batch_worker.rb

Constant Summary

Constants included from ApplicationWorker

ApplicationWorker::LOGGING_EXTRA_KEY, ApplicationWorker::SAFE_PUSH_BULK_LIMIT

Constants included from Gitlab::Loggable

Gitlab::Loggable::ANONYMOUS

Constants included from WorkerAttributes

WorkerAttributes::DEFAULT_DATA_CONSISTENCY, WorkerAttributes::DEFAULT_DEFER_DELAY, WorkerAttributes::NAMESPACE_WEIGHTS, WorkerAttributes::VALID_DATA_CONSISTENCIES, WorkerAttributes::VALID_RESOURCE_BOUNDARIES, WorkerAttributes::VALID_URGENCIES

Instance Method Summary collapse

Methods included from Gitlab::Loggable

#build_structured_payload

Methods included from Gitlab::SidekiqVersioning::Worker

#job_version

Methods included from WorkerContext

#with_context

Instance Method Details

#loggerObject



14
15
16
# File 'app/workers/merge_requests/mergeability_check_batch_worker.rb', line 14

def logger
  @logger ||= Sidekiq.logger
end

#perform(merge_request_ids, user_id) ⇒ Object



18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# File 'app/workers/merge_requests/mergeability_check_batch_worker.rb', line 18

def perform(merge_request_ids, user_id)
  merge_requests = MergeRequest.id_in(merge_request_ids)
  user = User.find_by_id(user_id)

  merge_requests.each do |merge_request|
    # Skip projects that user doesn't have update_merge_request access
    next if merge_status_recheck_not_allowed?(merge_request, user)

    merge_request.mark_as_checking

    result = merge_request.check_mergeability

    next unless result&.error?

    logger.error(
      worker: self.class.name,
      message: "Failed to check mergeability of merge request: #{result.message}",
      merge_request_id: merge_request.id
    )
  end
end