summaryrefslogtreecommitdiff
path: root/app/workers/repository_remove_remote_worker.rb
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2021-08-19 09:08:42 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2021-08-19 09:08:42 +0000
commitb76ae638462ab0f673e5915986070518dd3f9ad3 (patch)
treebdab0533383b52873be0ec0eb4d3c66598ff8b91 /app/workers/repository_remove_remote_worker.rb
parent434373eabe7b4be9593d18a585fb763f1e5f1a6f (diff)
downloadgitlab-ce-b76ae638462ab0f673e5915986070518dd3f9ad3.tar.gz
Add latest changes from gitlab-org/gitlab@14-2-stable-eev14.2.0-rc42
Diffstat (limited to 'app/workers/repository_remove_remote_worker.rb')
-rw-r--r--app/workers/repository_remove_remote_worker.rb25
1 files changed, 9 insertions, 16 deletions
diff --git a/app/workers/repository_remove_remote_worker.rb b/app/workers/repository_remove_remote_worker.rb
index 48158cda857..c95393e7d21 100644
--- a/app/workers/repository_remove_remote_worker.rb
+++ b/app/workers/repository_remove_remote_worker.rb
@@ -3,6 +3,8 @@
class RepositoryRemoveRemoteWorker # rubocop:disable Scalability/IdempotentWorker
include ApplicationWorker
+ data_consistency :always
+
sidekiq_options retry: 3
include ExclusiveLeaseGuard
@@ -14,22 +16,13 @@ class RepositoryRemoveRemoteWorker # rubocop:disable Scalability/IdempotentWorke
attr_reader :project, :remote_name
def perform(project_id, remote_name)
- @remote_name = remote_name
- @project = Project.find_by_id(project_id)
-
- return unless @project
-
- logger.info("Removing remote #{remote_name} from project #{project.id}")
-
- try_obtain_lease do
- remove_remote = @project.repository.remove_remote(remote_name)
-
- if remove_remote
- logger.info("Remote #{remote_name} was successfully removed from project #{project.id}")
- else
- logger.error("Could not remove remote #{remote_name} from project #{project.id}")
- end
- end
+ # On-disk remotes are slated for removal, and GitLab doesn't create any of
+ # them anymore. For backwards compatibility, we need to keep the worker
+ # though such that we can be sure to drain all jobs on an update. Making
+ # this a no-op is fine though: the worst that can happen is that we still
+ # have old remotes lingering in the repository's config, but Gitaly will
+ # start to clean these up in repository maintenance.
+ # https://gitlab.com/gitlab-org/gitlab/-/issues/336745
end
def lease_timeout