Commit 2b0a3380 authored by Mehmet Emin INAC's avatar Mehmet Emin INAC

Fix security report schema validation

`SAST` and `SECRET_DETECTION` report validation were failing due to
a logical error.

Changelog: fixed
EE: true
parent 48b17dba
......@@ -8,13 +8,14 @@ module EE
module SchemaValidator
module Schema
extend ::Gitlab::Utils::Override
CE_TYPES = %i(sast secret_detection).freeze
override :root_path
def root_path
if [:sast, :secret_detection].include?(report_type)
super
else
File.join(__dir__, 'schemas')
end
return super if CE_TYPES.include?(report_type)
File.join(__dir__, 'schemas')
end
end
end
......
......@@ -12,7 +12,7 @@ module Gitlab
end
def initialize(report_type)
@report_type = report_type
@report_type = report_type.to_sym
end
delegate :validate, to: :schemer
......
......@@ -6,7 +6,8 @@ RSpec.describe Gitlab::Ci::Parsers::Security::Validators::SchemaValidator do
using RSpec::Parameterized::TableSyntax
where(:report_type, :expected_errors, :valid_data) do
:sast | ['root is missing required keys: vulnerabilities'] | { 'version' => '10.0.0', 'vulnerabilities' => [] }
'sast' | ['root is missing required keys: vulnerabilities'] | { 'version' => '10.0.0', 'vulnerabilities' => [] }
:sast | ['root is missing required keys: vulnerabilities'] | { 'version' => '10.0.0', 'vulnerabilities' => [] }
:secret_detection | ['root is missing required keys: vulnerabilities'] | { 'version' => '10.0.0', 'vulnerabilities' => [] }
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