Commit c6c7f90b authored by Shinya Maeda's avatar Shinya Maeda

Use deployment relation to fetch environment

Add changelog

Improve comment

Add spec

Fix comments

Add changelog
parent c4eb609c
...@@ -48,13 +48,23 @@ module Ci ...@@ -48,13 +48,23 @@ module Ci
delegate :trigger_short_token, to: :trigger_request, allow_nil: true delegate :trigger_short_token, to: :trigger_request, allow_nil: true
## ##
# The "environment" field for builds is a String, and is the unexpanded name! # Since Gitlab 11.5, deployments records started being created right after
# `ci_builds` creation. We can look up a relevant `environment` through
# `deployment` relation today. This is much more efficient than expanding
# environment name with variables.
# (See more https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/22380)
# #
# However, we have to still expand environment name if it's a stop action,
# because `deployment` persists information for start action only.
#
# We will follow up this by persisting expanded name in build metadata or
# persisting stop action in database.
def persisted_environment def persisted_environment
return unless has_environment? return unless has_environment?
strong_memoize(:persisted_environment) do strong_memoize(:persisted_environment) do
Environment.find_by(name: expanded_environment_name, project: project) deployment&.environment ||
Environment.find_by(name: expanded_environment_name, project: project)
end end
end end
......
---
title: Use deployment relation to get an environment name
merge_request: 24890
author:
type: performance
...@@ -38,7 +38,7 @@ module EE ...@@ -38,7 +38,7 @@ module EE
# as evaluating `build.expanded_environment_name` is expensive. # as evaluating `build.expanded_environment_name` is expensive.
return true unless build.project.protected_environments_feature_available? return true unless build.project.protected_environments_feature_available?
build.project.protected_environment_accessible_to?(build.expanded_environment_name, user) build.project.protected_environment_accessible_to?(build.persisted_environment&.name, user)
end end
end end
end end
......
---
title: Optimize slow pipelines.js response
merge_request: 9387
author:
type: performance
...@@ -15,6 +15,22 @@ describe Ci::BuildPolicy do ...@@ -15,6 +15,22 @@ describe Ci::BuildPolicy do
subject { user.can?(:update_build, build) } subject { user.can?(:update_build, build) }
it_behaves_like 'protected environments access' it_behaves_like 'protected environments access'
context 'when a pipeline has manual deployment job' do
let!(:build) { create(:ee_ci_build, :manual, :deploy_to_production, pipeline: pipeline) }
before do
project.add_developer(user)
end
it 'does not expand environment name' do
allow(build.project).to receive(:protected_environments_feature_available?) { true }
expect(build.project).to receive(:protected_environment_accessible_to?)
expect(build).not_to receive(:expanded_environment_name)
subject
end
end
end end
describe 'manage a web ide terminal' do describe 'manage a web ide terminal' do
......
...@@ -1845,6 +1845,26 @@ describe Ci::Build do ...@@ -1845,6 +1845,26 @@ describe Ci::Build do
context 'when there is no environment' do context 'when there is no environment' do
it { is_expected.to be_nil } it { is_expected.to be_nil }
end end
context 'when build has a start environment' do
let(:build) { create(:ci_build, :deploy_to_production, pipeline: pipeline) }
it 'does not expand environment name' do
expect(build).not_to receive(:expanded_environment_name)
subject
end
end
context 'when build has a stop environment' do
let(:build) { create(:ci_build, :stop_review_app, pipeline: pipeline) }
it 'expands environment name' do
expect(build).to receive(:expanded_environment_name)
subject
end
end
end end
describe '#play' do describe '#play' do
......
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