summaryrefslogtreecommitdiff
path: root/app/models/project.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/models/project.rb')
-rw-r--r--app/models/project.rb21
1 files changed, 20 insertions, 1 deletions
diff --git a/app/models/project.rb b/app/models/project.rb
index f8a54324341..d4cd398c934 100644
--- a/app/models/project.rb
+++ b/app/models/project.rb
@@ -28,6 +28,8 @@ class Project < ActiveRecord::Base
:merge_requests_enabled?, :issues_enabled?, to: :project_feature,
allow_nil: true
+ delegate :shared_runners_minutes, to: :project_metrics, allow_nil: true
+
default_value_for :archived, false
default_value_for :visibility_level, gitlab_config_features.visibility_level
default_value_for :container_registry_enabled, gitlab_config_features.container_registry
@@ -146,6 +148,7 @@ class Project < ActiveRecord::Base
has_one :import_data, dependent: :destroy, class_name: "ProjectImportData"
has_one :project_feature, dependent: :destroy
+ has_one :project_metrics, dependent: :destroy
has_many :commit_statuses, dependent: :destroy, foreign_key: :gl_project_id
has_many :pipelines, dependent: :destroy, class_name: 'Ci::Pipeline', foreign_key: :gl_project_id
@@ -1165,7 +1168,9 @@ class Project < ActiveRecord::Base
return true
end
- shared_runners_enabled? && Ci::Runner.shared.active.any?(&block)
+ shared_runners_enabled? &&
+ !shared_runners_minutes_used? &&
+ Ci::Runner.shared.active.any?(&block)
end
def valid_runners_token?(token)
@@ -1346,6 +1351,20 @@ class Project < ActiveRecord::Base
end
end
+ def shared_runners_minutes_limit
+ read_attribute(:shared_runners_minutes_limit) || current_application_settings.shared_runners_minutes
+ end
+
+ def shared_runners_minutes_limit_enabled?
+ shared_runners_minutes_limit.nonzero?
+ end
+
+ def shared_runners_minutes_used?
+ shared_runners_enabled? &&
+ shared_runners_minutes_limit_enabled? &&
+ shared_runners_minutes.to_i < shared_runners_minutes_limit
+ end
+
private
def pushes_since_gc_redis_key