Commit 8f03d62c authored by Fabio Pitino's avatar Fabio Pitino

Merge branch '300581-refactoring-yaml-variables' into 'master'

Remove the usage of yaml_variables in SastParser

See merge request gitlab-org/gitlab!62288
parents 78d15274 7baa1f32
...@@ -109,17 +109,17 @@ module Security ...@@ -109,17 +109,17 @@ module Security
yaml_result = Gitlab::Ci::YamlProcessor.new(content, options).execute yaml_result = Gitlab::Ci::YamlProcessor.new(content, options).execute
return {} unless yaml_result.valid? return {} unless yaml_result.valid?
sast_attributes = yaml_result.build_attributes(:sast) extract_required_attributes(yaml_result)
extract_required_attributes(sast_attributes)
end end
def extract_required_attributes(attributes) def extract_required_attributes(yaml_result)
result = {} result = {}
attributes[:yaml_variables].each do |variable|
yaml_result.yaml_variables_for(:sast).each do |variable|
result[variable[:key]] = variable[:value] result[variable[:key]] = variable[:value]
end end
result[:stage] = attributes[:stage] result[:stage] = yaml_result.stage_for(:sast)
result.with_indifferent_access result.with_indifferent_access
end end
end end
......
...@@ -111,6 +111,22 @@ module Gitlab ...@@ -111,6 +111,22 @@ module Gitlab
@ci_config.variables_with_data @ci_config.variables_with_data
end end
def yaml_variables_for(job_name)
job = jobs.fetch(job_name)
Gitlab::Ci::Variables::Helpers.inherit_yaml_variables(
from: root_variables,
to: transform_to_yaml_variables(job[:job_variables]),
inheritance: job.fetch(:root_variables_inheritance, true)
)
end
def stage_for(job_name)
job = jobs.fetch(job_name)
job[:stage]
end
private private
def variables def variables
......
...@@ -39,6 +39,45 @@ module Gitlab ...@@ -39,6 +39,45 @@ module Gitlab
expect(expanded_config).to include(*included_config.keys) expect(expanded_config).to include(*included_config.keys)
end end
end end
describe '#yaml_variables_for' do
let(:config_content) do
<<~YAML
variables:
VAR1: value 1
VAR2: value 2
job:
script: echo 'hello'
variables:
VAR1: value 11
YAML
end
subject(:yaml_variables_for) { result.yaml_variables_for(:job) }
it do
is_expected.to match_array([
{ key: 'VAR1', value: 'value 11', public: true },
{ key: 'VAR2', value: 'value 2', public: true }
])
end
end
describe '#stage_for' do
let(:config_content) do
<<~YAML
job:
script: echo 'hello'
YAML
end
subject(:stage_for) { result.stage_for(:job) }
it do
is_expected.to eq('test')
end
end
end end
end end
end end
......
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