Commit ff5aa273 authored by Dmytro Zaporozhets (DZ)'s avatar Dmytro Zaporozhets (DZ)

Merge branch 'link-mrs-failed-deploys' into 'master'

Only link merge requests to successful deployments

See merge request gitlab-org/gitlab!58072
parents c43b7dcb 07a95915
...@@ -94,11 +94,6 @@ class Deployment < ApplicationRecord ...@@ -94,11 +94,6 @@ class Deployment < ApplicationRecord
after_transition any => :success do |deployment| after_transition any => :success do |deployment|
deployment.run_after_commit do deployment.run_after_commit do
Deployments::UpdateEnvironmentWorker.perform_async(id) Deployments::UpdateEnvironmentWorker.perform_async(id)
end
end
after_transition any => FINISHED_STATUSES do |deployment|
deployment.run_after_commit do
Deployments::LinkMergeRequestWorker.perform_async(id) Deployments::LinkMergeRequestWorker.perform_async(id)
end end
end end
......
...@@ -18,6 +18,21 @@ module Deployments ...@@ -18,6 +18,21 @@ module Deployments
# app deployments, as this is not useful. # app deployments, as this is not useful.
return if deployment.environment.environment_type return if deployment.environment.environment_type
# This service is triggered by a Sidekiq worker, which only runs when a
# deployment is successful. We add an extra check here in case we ever
# call this service elsewhere and forget to check the status there.
#
# The reason we only want to link successful deployments is as follows:
# when we link a merge request, we don't link it to future deployments for
# the same environment. If we were to link an MR to a failed deploy, we
# wouldn't be able to later on link it to a successful deploy (e.g. after
# the deploy is retried).
#
# In addition, showing failed deploys in the UI of a merge request isn't
# useful to users, as they can't act upon the information in any
# meaningful way (i.e. they can't just retry the deploy themselves).
return unless deployment.success?
if (prev = deployment.previous_environment_deployment) if (prev = deployment.previous_environment_deployment)
link_merge_requests_for_range(prev.sha, deployment.sha) link_merge_requests_for_range(prev.sha, deployment.sha)
else else
......
---
title: Only link merge requests to successful deployments
merge_request: 58072
author:
type: fixed
...@@ -161,9 +161,9 @@ RSpec.describe Deployment do ...@@ -161,9 +161,9 @@ RSpec.describe Deployment do
end end
end end
it 'executes Deployments::LinkMergeRequestWorker asynchronously' do it 'does not execute Deployments::LinkMergeRequestWorker' do
expect(Deployments::LinkMergeRequestWorker) expect(Deployments::LinkMergeRequestWorker)
.to receive(:perform_async).with(deployment.id) .not_to receive(:perform_async).with(deployment.id)
deployment.drop! deployment.drop!
end end
...@@ -188,9 +188,9 @@ RSpec.describe Deployment do ...@@ -188,9 +188,9 @@ RSpec.describe Deployment do
end end
end end
it 'executes Deployments::LinkMergeRequestWorker asynchronously' do it 'does not execute Deployments::LinkMergeRequestWorker' do
expect(Deployments::LinkMergeRequestWorker) expect(Deployments::LinkMergeRequestWorker)
.to receive(:perform_async).with(deployment.id) .not_to receive(:perform_async).with(deployment.id)
deployment.cancel! deployment.cancel!
end end
......
...@@ -32,6 +32,17 @@ RSpec.describe Deployments::LinkMergeRequestsService do ...@@ -32,6 +32,17 @@ RSpec.describe Deployments::LinkMergeRequestsService do
end end
end end
context 'when the deployment failed' do
it 'does nothing' do
environment = create(:environment, name: 'foo')
deploy = create(:deployment, :failed, environment: environment)
expect(deploy).not_to receive(:link_merge_requests)
described_class.new(deploy).execute
end
end
context 'when there is a previous deployment' do context 'when there is a previous deployment' do
it 'links all merge requests merged since the previous deployment' do it 'links all merge requests merged since the previous deployment' do
deploy1 = create( deploy1 = create(
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment