2018-06-27 07:23:28 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2020-02-19 18:09:10 +00:00
|
|
|
class UpdateMergeRequestsWorker # rubocop:disable Scalability/IdempotentWorker
|
2017-11-28 16:08:30 +00:00
|
|
|
include ApplicationWorker
|
2016-10-10 07:40:14 +00:00
|
|
|
|
2019-10-18 11:11:44 +00:00
|
|
|
feature_category :source_code_management
|
2020-03-02 18:07:42 +00:00
|
|
|
urgency :high
|
2019-10-30 15:14:17 +00:00
|
|
|
worker_resource_boundary :cpu
|
2020-01-24 18:09:00 +00:00
|
|
|
weight 3
|
2019-10-18 11:11:44 +00:00
|
|
|
|
2017-11-14 14:22:15 +00:00
|
|
|
LOG_TIME_THRESHOLD = 90 # seconds
|
|
|
|
|
2018-08-27 15:31:01 +00:00
|
|
|
# rubocop: disable CodeReuse/ActiveRecord
|
2016-10-10 07:40:14 +00:00
|
|
|
def perform(project_id, user_id, oldrev, newrev, ref)
|
|
|
|
project = Project.find_by(id: project_id)
|
|
|
|
return unless project
|
|
|
|
|
|
|
|
user = User.find_by(id: user_id)
|
|
|
|
return unless user
|
|
|
|
|
2017-11-13 19:56:08 +00:00
|
|
|
# TODO: remove this benchmarking when we have rich logging
|
|
|
|
time = Benchmark.measure do
|
|
|
|
MergeRequests::RefreshService.new(project, user).execute(oldrev, newrev, ref)
|
|
|
|
end
|
|
|
|
|
2017-11-14 14:22:15 +00:00
|
|
|
args_log = [
|
|
|
|
"elapsed=#{time.real}",
|
|
|
|
"project_id=#{project_id}",
|
|
|
|
"user_id=#{user_id}",
|
|
|
|
"oldrev=#{oldrev}",
|
|
|
|
"newrev=#{newrev}",
|
|
|
|
"ref=#{ref}"
|
|
|
|
].join(',')
|
2017-11-13 19:56:08 +00:00
|
|
|
|
2019-07-10 19:26:47 +00:00
|
|
|
Rails.logger.info("UpdateMergeRequestsWorker#perform #{args_log}") if time.real > LOG_TIME_THRESHOLD # rubocop:disable Gitlab/RailsLogger
|
2016-10-10 07:40:14 +00:00
|
|
|
end
|
2018-08-27 15:31:01 +00:00
|
|
|
# rubocop: enable CodeReuse/ActiveRecord
|
2016-10-10 07:40:14 +00:00
|
|
|
end
|