Commit 5ed7b3b0 authored by rossfuhrman's avatar rossfuhrman Committed by Sean McGivern

Sort SAST_DEFAULT_ANALYZERS to support comparison

We need to sort SAST_DEFAULT_ANALYZERS so we can deterministically
compare it to the list of analyzers provided to the class.
The provided list of analyzers is also now being sorted.
parent 263a9980
---
title: Resolve "SAST_DEFAULT_ANALYZERS is written with default value by SAST Config UI"
merge_request: 46388
author:
type: fixed
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
module Security module Security
module CiConfiguration module CiConfiguration
class SastBuildActions class SastBuildActions
SAST_DEFAULT_ANALYZERS = 'bandit, brakeman, gosec, spotbugs, flawfinder, phpcs-security-audit, security-code-scan, nodejs-scan, eslint, sobelow, pmd-apex, kubesec' SAST_DEFAULT_ANALYZERS = 'bandit, brakeman, eslint, flawfinder, gosec, kubesec, nodejs-scan, phpcs-security-audit, pmd-apex, security-code-scan, sobelow, spotbugs'
def initialize(auto_devops_enabled, params, existing_gitlab_ci_content) def initialize(auto_devops_enabled, params, existing_gitlab_ci_content)
@auto_devops_enabled = auto_devops_enabled @auto_devops_enabled = auto_devops_enabled
...@@ -55,6 +55,7 @@ module Security ...@@ -55,6 +55,7 @@ module Security
config['analyzers'] config['analyzers']
&.select {|a| a['enabled'] } &.select {|a| a['enabled'] }
&.collect {|a| a['name'] } &.collect {|a| a['name'] }
&.sort
&.join(', ') &.join(', ')
else else
SAST_DEFAULT_ANALYZERS SAST_DEFAULT_ANALYZERS
......
...@@ -64,11 +64,11 @@ RSpec.describe Security::CiConfiguration::SastBuildActions do ...@@ -64,11 +64,11 @@ RSpec.describe Security::CiConfiguration::SastBuildActions do
params.merge( { 'analyzers' => params.merge( { 'analyzers' =>
[ [
{ {
'name' => "brakeman", 'name' => "flawfinder",
'enabled' => true 'enabled' => true
}, },
{ {
'name' => "flawfinder", 'name' => "brakeman",
'enabled' => true 'enabled' => true
} }
] } ] }
...@@ -305,6 +305,20 @@ RSpec.describe Security::CiConfiguration::SastBuildActions do ...@@ -305,6 +305,20 @@ RSpec.describe Security::CiConfiguration::SastBuildActions do
end end
end end
describe 'Security::CiConfiguration::SastBuildActions::SAST_DEFAULT_ANALYZERS' do
subject(:variable) {Security::CiConfiguration::SastBuildActions::SAST_DEFAULT_ANALYZERS}
it 'is sorted alphabetically' do
sorted_variable = Security::CiConfiguration::SastBuildActions::SAST_DEFAULT_ANALYZERS
.split(',')
.map(&:strip)
.sort
.join(', ')
expect(variable).to eq(sorted_variable)
end
end
# stubbing this method allows this spec file to use fast_spec_helper # stubbing this method allows this spec file to use fast_spec_helper
def fast_auto_devops_stages def fast_auto_devops_stages
auto_devops_template = YAML.safe_load( File.read('lib/gitlab/ci/templates/Auto-DevOps.gitlab-ci.yml') ) auto_devops_template = YAML.safe_load( File.read('lib/gitlab/ci/templates/Auto-DevOps.gitlab-ci.yml') )
......
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