Commit e582dc8e authored by Fabio Pitino's avatar Fabio Pitino

Merge branch 'ci-cache-predefined-variables' into 'master'

Cache CI variables used for rules evaluation

See merge request gitlab-org/gitlab!72602
parents 03226ec9 084f1ad5
...@@ -684,8 +684,10 @@ module Ci ...@@ -684,8 +684,10 @@ module Ci
end end
def freeze_period? def freeze_period?
strong_memoize(:freeze_period) do
Ci::FreezePeriodStatus.new(project: project).execute Ci::FreezePeriodStatus.new(project: project).execute
end end
end
def has_warnings? def has_warnings?
number_of_warnings > 0 number_of_warnings > 0
...@@ -800,20 +802,7 @@ module Ci ...@@ -800,20 +802,7 @@ module Ci
variables.append(key: 'CI_PIPELINE_CREATED_AT', value: created_at&.iso8601) variables.append(key: 'CI_PIPELINE_CREATED_AT', value: created_at&.iso8601)
variables.concat(predefined_commit_variables) variables.concat(predefined_commit_variables)
variables.concat(predefined_merge_request_variables)
if merge_request?
variables.append(key: 'CI_MERGE_REQUEST_EVENT_TYPE', value: merge_request_event_type.to_s)
variables.append(key: 'CI_MERGE_REQUEST_SOURCE_BRANCH_SHA', value: source_sha.to_s)
variables.append(key: 'CI_MERGE_REQUEST_TARGET_BRANCH_SHA', value: target_sha.to_s)
diff = self.merge_request_diff
if diff.present?
variables.append(key: 'CI_MERGE_REQUEST_DIFF_ID', value: diff.id.to_s)
variables.append(key: 'CI_MERGE_REQUEST_DIFF_BASE_SHA', value: diff.base_commit_sha)
end
variables.concat(merge_request.predefined_variables)
end
if open_merge_requests_refs.any? if open_merge_requests_refs.any?
variables.append(key: 'CI_OPEN_MERGE_REQUESTS', value: open_merge_requests_refs.join(',')) variables.append(key: 'CI_OPEN_MERGE_REQUESTS', value: open_merge_requests_refs.join(','))
...@@ -829,6 +818,7 @@ module Ci ...@@ -829,6 +818,7 @@ module Ci
end end
def predefined_commit_variables def predefined_commit_variables
strong_memoize(:predefined_commit_variables) do
Gitlab::Ci::Variables::Collection.new.tap do |variables| Gitlab::Ci::Variables::Collection.new.tap do |variables|
variables.append(key: 'CI_COMMIT_SHA', value: sha) variables.append(key: 'CI_COMMIT_SHA', value: sha)
variables.append(key: 'CI_COMMIT_SHORT_SHA', value: short_sha) variables.append(key: 'CI_COMMIT_SHORT_SHA', value: short_sha)
...@@ -852,6 +842,27 @@ module Ci ...@@ -852,6 +842,27 @@ module Ci
variables.append(key: 'CI_BUILD_TAG', value: ref) if tag? variables.append(key: 'CI_BUILD_TAG', value: ref) if tag?
end end
end end
end
def predefined_merge_request_variables
strong_memoize(:predefined_merge_request_variables) do
Gitlab::Ci::Variables::Collection.new.tap do |variables|
next variables unless merge_request?
variables.append(key: 'CI_MERGE_REQUEST_EVENT_TYPE', value: merge_request_event_type.to_s)
variables.append(key: 'CI_MERGE_REQUEST_SOURCE_BRANCH_SHA', value: source_sha.to_s)
variables.append(key: 'CI_MERGE_REQUEST_TARGET_BRANCH_SHA', value: target_sha.to_s)
diff = self.merge_request_diff
if diff.present?
variables.append(key: 'CI_MERGE_REQUEST_DIFF_ID', value: diff.id.to_s)
variables.append(key: 'CI_MERGE_REQUEST_DIFF_BASE_SHA', value: diff.base_commit_sha)
end
variables.concat(merge_request.predefined_variables)
end
end
end
def queued_duration def queued_duration
return unless started_at return unless started_at
......
...@@ -2056,6 +2056,7 @@ class Project < ApplicationRecord ...@@ -2056,6 +2056,7 @@ class Project < ApplicationRecord
end end
def predefined_variables def predefined_variables
strong_memoize(:predefined_variables) do
Gitlab::Ci::Variables::Collection.new Gitlab::Ci::Variables::Collection.new
.concat(predefined_ci_server_variables) .concat(predefined_ci_server_variables)
.concat(predefined_project_variables) .concat(predefined_project_variables)
...@@ -2065,6 +2066,7 @@ class Project < ApplicationRecord ...@@ -2065,6 +2066,7 @@ class Project < ApplicationRecord
.concat(auto_devops_variables) .concat(auto_devops_variables)
.concat(api_variables) .concat(api_variables)
end end
end
def predefined_project_variables def predefined_project_variables
Gitlab::Ci::Variables::Collection.new Gitlab::Ci::Variables::Collection.new
......
...@@ -808,8 +808,10 @@ module EE ...@@ -808,8 +808,10 @@ module EE
override :predefined_variables override :predefined_variables
def predefined_variables def predefined_variables
strong_memoize(:ee_predefined_variables) do
super.concat(requirements_ci_variables) super.concat(requirements_ci_variables)
end end
end
def add_template_export_job(current_user:, after_export_strategy: nil, params: {}) def add_template_export_job(current_user:, after_export_strategy: nil, params: {})
job_id = ProjectTemplateExportWorker.perform_async(current_user.id, self.id, after_export_strategy, params) job_id = ProjectTemplateExportWorker.perform_async(current_user.id, self.id, after_export_strategy, params)
......
...@@ -22,7 +22,7 @@ RSpec.describe 'Jobs/DAST-Default-Branch-Deploy.gitlab-ci.yml' do ...@@ -22,7 +22,7 @@ RSpec.describe 'Jobs/DAST-Default-Branch-Deploy.gitlab-ci.yml' do
end end
describe 'the created pipeline' do describe 'the created pipeline' do
let_it_be(:project) do let_it_be_with_refind(:project) do
create(:project, :repository, variables: [ create(:project, :repository, variables: [
build(:ci_variable, key: 'CI_KUBERNETES_ACTIVE', value: 'true') build(:ci_variable, key: 'CI_KUBERNETES_ACTIVE', value: 'true')
]) ])
......
...@@ -6,7 +6,7 @@ RSpec.describe 'Cluster-Image-Scanning.gitlab-ci.yml' do ...@@ -6,7 +6,7 @@ RSpec.describe 'Cluster-Image-Scanning.gitlab-ci.yml' do
subject(:template) { Gitlab::Template::GitlabCiYmlTemplate.find('Cluster-Image-Scanning') } subject(:template) { Gitlab::Template::GitlabCiYmlTemplate.find('Cluster-Image-Scanning') }
describe 'the created pipeline' do describe 'the created pipeline' do
let_it_be(:project) { create(:project, :custom_repo, files: { 'README.txt' => '' }) } let_it_be_with_refind(:project) { create(:project, :custom_repo, files: { 'README.txt' => '' }) }
let(:default_branch) { 'master' } let(:default_branch) { 'master' }
let(:user) { project.owner } let(:user) { project.owner }
......
...@@ -6,11 +6,11 @@ RSpec.describe 'Container-Scanning.gitlab-ci.yml' do ...@@ -6,11 +6,11 @@ RSpec.describe 'Container-Scanning.gitlab-ci.yml' do
subject(:template) { Gitlab::Template::GitlabCiYmlTemplate.find('Container-Scanning') } subject(:template) { Gitlab::Template::GitlabCiYmlTemplate.find('Container-Scanning') }
describe 'the created pipeline' do describe 'the created pipeline' do
let_it_be(:project) { create(:project, :custom_repo, files: { 'README.txt' => '' }) } let_it_be_with_refind(:project) { create(:project, :custom_repo, files: { 'README.txt' => '' }) }
let(:default_branch) { 'master' } let(:default_branch) { 'master' }
let(:user) { project.owner } let(:user) { project.owner }
let(:service) { Ci::CreatePipelineService.new(project, user, ref: 'master' ) } let(:service) { Ci::CreatePipelineService.new(project, user, ref: 'master') }
let(:pipeline) { service.execute!(:push).payload } let(:pipeline) { service.execute!(:push).payload }
let(:build_names) { pipeline.builds.pluck(:name) } let(:build_names) { pipeline.builds.pluck(:name) }
......
...@@ -6,7 +6,7 @@ RSpec.describe 'License-Scanning.gitlab-ci.yml' do ...@@ -6,7 +6,7 @@ RSpec.describe 'License-Scanning.gitlab-ci.yml' do
subject(:template) { Gitlab::Template::GitlabCiYmlTemplate.find('License-Scanning') } subject(:template) { Gitlab::Template::GitlabCiYmlTemplate.find('License-Scanning') }
describe 'the created pipeline' do describe 'the created pipeline' do
let_it_be(:project) { create(:project, :custom_repo, files: { 'README.txt' => '' }) } let_it_be_with_refind(:project) { create(:project, :custom_repo, files: { 'README.txt' => '' }) }
let(:default_branch) { 'master' } let(:default_branch) { 'master' }
let(:user) { project.owner } let(:user) { project.owner }
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
require 'spec_helper' require 'spec_helper'
RSpec.describe Ci::CreatePipelineService do RSpec.describe Ci::CreatePipelineService do
let_it_be(:project) { create(:project, :custom_repo, files: { 'README.txt' => '' }) } let_it_be_with_refind(:project) { create(:project, :custom_repo, files: { 'README.txt' => '' }) }
let_it_be(:user) { create(:user, developer_projects: [project]) } let_it_be(:user) { create(:user, developer_projects: [project]) }
let_it_be(:dast_site_profile) { create(:dast_site_profile, project: project) } let_it_be(:dast_site_profile) { create(:dast_site_profile, project: project) }
let_it_be(:dast_scanner_profile) { create(:dast_scanner_profile, project: project) } let_it_be(:dast_scanner_profile) { create(:dast_scanner_profile, project: project) }
......
...@@ -5,8 +5,8 @@ require 'spec_helper' ...@@ -5,8 +5,8 @@ require 'spec_helper'
RSpec.describe Ci::CreatePipelineService do RSpec.describe Ci::CreatePipelineService do
include ProjectForksHelper include ProjectForksHelper
let_it_be(:project, reload: true) { create(:project, :repository) } let_it_be_with_refind(:project) { create(:project, :repository) }
let_it_be(:user, reload: true) { project.owner } let_it_be_with_reload(:user) { project.owner }
let(:ref_name) { 'refs/heads/master' } let(:ref_name) { 'refs/heads/master' }
......
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