gitlab-org--gitlab-foss/app/models/deployment.rb

77 lines
2 KiB
Ruby
Raw Normal View History

2016-06-10 17:36:54 -04:00
class Deployment < ActiveRecord::Base
include InternalId
belongs_to :project, required: true, validate: true
belongs_to :environment, required: true, validate: true
2016-06-10 17:36:54 -04:00
belongs_to :user
belongs_to :deployable, polymorphic: true
2016-06-14 12:34:48 -04:00
validates :sha, presence: true
validates :ref, presence: true
2016-06-10 17:36:54 -04:00
delegate :name, to: :environment, prefix: true
after_save :keep_around_commit
2016-06-10 17:36:54 -04:00
def commit
project.commit(sha)
end
def commit_title
commit.try(:title)
end
def short_sha
2016-06-14 12:34:48 -04:00
Commit.truncate_sha(sha)
2016-06-10 17:36:54 -04:00
end
2016-06-14 08:47:00 -04:00
def last?
self == environment.last_deployment
end
def keep_around_commit
project.repository.keep_around(self.sha)
end
2016-07-16 12:39:58 -04:00
def manual_actions
deployable.try(:other_actions)
2016-07-16 12:39:58 -04:00
end
2016-08-02 08:01:22 -04:00
def includes_commit?(commit)
2016-08-02 08:01:22 -04:00
return false unless commit
2016-08-03 07:37:39 -04:00
project.repository.is_ancestor?(commit.id, sha)
2016-08-02 08:01:22 -04:00
end
def update_merge_request_metrics
if environment.update_merge_request_metrics?
query = project.merge_requests.
joins(:metrics).
where(target_branch: self.ref, merge_request_metrics: { first_deployed_to_production_at: nil })
merge_requests =
if previous_deployment
query.where("merge_request_metrics.merged_at <= ? AND merge_request_metrics.merged_at >= ?",
self.created_at,
previous_deployment.created_at)
else
query.where("merge_request_metrics.merged_at <= ?", self.created_at)
end
# Need to use `map` instead of `select` because MySQL doesn't allow `SELECT`ing from the same table
# that we're updating.
MergeRequest::Metrics.where(merge_request_id: merge_requests.map(&:id), first_deployed_to_production_at: nil).
update_all(first_deployed_to_production_at: self.created_at)
end
end
def previous_deployment
@previous_deployment ||=
project.deployments.joins(:environment).
where(environments: { name: self.environment.name }, ref: self.ref).
where.not(id: self.id).
take
end
2016-06-10 17:36:54 -04:00
end