Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2023-06-27 09:08:04 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2023-06-27 09:08:04 +0300
commit5849e597a070c4d5d37657569919150701ca70bd (patch)
treec70900a50dc2fd5570d72f09444c98dad11e78f6 /app/services/groups
parentf33d28f789f690bfc01c8b81d95259a9f1c68b79 (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'app/services/groups')
-rw-r--r--app/services/groups/update_shared_runners_service.rb46
1 files changed, 45 insertions, 1 deletions
diff --git a/app/services/groups/update_shared_runners_service.rb b/app/services/groups/update_shared_runners_service.rb
index c09dce0761f..91ba8924c0f 100644
--- a/app/services/groups/update_shared_runners_service.rb
+++ b/app/services/groups/update_shared_runners_service.rb
@@ -25,7 +25,14 @@ module Groups
end
def update_shared_runners
- group.update_shared_runners_setting!(params[:shared_runners_setting])
+ case params[:shared_runners_setting]
+ when Namespace::SR_DISABLED_AND_UNOVERRIDABLE
+ disable_shared_runners! # also disallows override
+ when Namespace::SR_DISABLED_WITH_OVERRIDE, Namespace::SR_DISABLED_AND_OVERRIDABLE
+ disable_shared_runners_and_allow_override!
+ when Namespace::SR_ENABLED
+ enable_shared_runners! # set both to true
+ end
end
def update_pending_builds?
@@ -41,5 +48,42 @@ module Groups
::Ci::UpdatePendingBuildService.new(group, pending_builds_params).execute
end
end
+
+ def disable_shared_runners!
+ group.update!(
+ shared_runners_enabled: false,
+ allow_descendants_override_disabled_shared_runners: false)
+
+ group_ids = group.descendants
+ unless group_ids.empty?
+ Group.by_id(group_ids).update_all(
+ shared_runners_enabled: false,
+ allow_descendants_override_disabled_shared_runners: false)
+ end
+
+ group.all_projects.update_all(shared_runners_enabled: false)
+ end
+
+ def disable_shared_runners_and_allow_override!
+ # enabled -> disabled_and_overridable
+ if group.shared_runners_enabled?
+ group.update!(
+ shared_runners_enabled: false,
+ allow_descendants_override_disabled_shared_runners: true)
+
+ group_ids = group.descendants
+ Group.by_id(group_ids).update_all(shared_runners_enabled: false) unless group_ids.empty?
+
+ group.all_projects.update_all(shared_runners_enabled: false)
+
+ # disabled_and_unoverridable -> disabled_and_overridable
+ else
+ group.update!(allow_descendants_override_disabled_shared_runners: true)
+ end
+ end
+
+ def enable_shared_runners!
+ group.update!(shared_runners_enabled: true)
+ end
end
end