Commit 94700914 authored by celdem's avatar celdem

Don't parse undefined severity confidence from reports

parent 51813f5b
---
title: Do not parse undefined severity and confidence from reports
merge_request: 25884
author:
type: other
...@@ -93,7 +93,8 @@ module Gitlab ...@@ -93,7 +93,8 @@ module Gitlab
end end
def parse_level(input) def parse_level(input)
input.blank? ? 'undefined' : input.downcase input = input&.downcase
input.blank? || input == 'undefined' ? 'unknown' : input
end end
def create_location(location_data) def create_location(location_data)
......
...@@ -185,7 +185,7 @@ describe Security::PipelineVulnerabilitiesFinder do ...@@ -185,7 +185,7 @@ describe Security::PipelineVulnerabilitiesFinder do
subject { described_class.new(pipeline: pipeline).execute } subject { described_class.new(pipeline: pipeline).execute }
it 'returns all vulnerability severity levels' do it 'returns all vulnerability severity levels' do
expect(subject.occurrences.map(&:severity).uniq).to match_array(%w[undefined unknown low medium high critical info]) expect(subject.occurrences.map(&:severity).uniq).to match_array(%w[unknown low medium high critical info])
end end
end end
...@@ -203,7 +203,7 @@ describe Security::PipelineVulnerabilitiesFinder do ...@@ -203,7 +203,7 @@ describe Security::PipelineVulnerabilitiesFinder do
subject { described_class.new(pipeline: pipeline).execute } subject { described_class.new(pipeline: pipeline).execute }
it 'returns all vulnerability confidence levels' do it 'returns all vulnerability confidence levels' do
expect(subject.occurrences.map(&:confidence).uniq).to match_array %w[undefined unknown low medium high] expect(subject.occurrences.map(&:confidence).uniq).to match_array %w[unknown low medium high]
end end
end end
...@@ -222,8 +222,8 @@ describe Security::PipelineVulnerabilitiesFinder do ...@@ -222,8 +222,8 @@ describe Security::PipelineVulnerabilitiesFinder do
it 'filters by all params' do it 'filters by all params' do
expect(subject.occurrences.count).to eq(cs_count + dast_count + ds_count + sast_count) expect(subject.occurrences.count).to eq(cs_count + dast_count + ds_count + sast_count)
expect(subject.occurrences.map(&:confidence).uniq).to match_array(%w[undefined unknown low medium high]) expect(subject.occurrences.map(&:confidence).uniq).to match_array(%w[unknown low medium high])
expect(subject.occurrences.map(&:severity).uniq).to match_array(%w[undefined unknown low medium high critical info]) expect(subject.occurrences.map(&:severity).uniq).to match_array(%w[unknown low medium high critical info])
end end
end end
......
# frozen_string_literal: true
require 'spec_helper'
describe Gitlab::Ci::Parsers::Security::Common do
describe '#parse!' do
let(:artifact) { create(:ee_ci_job_artifact, :dependency_scanning) }
let(:report) { Gitlab::Ci::Reports::Security::Report.new(artifact.file_type, 'sha', 2.weeks.ago) }
let(:parser) { described_class.new }
before do
allow(parser).to receive(:create_location).and_return(nil)
artifact.each_blob do |blob|
blob.gsub!("Unknown", "Undefined")
parser.parse!(blob, report)
end
end
it "converts undefined severity and confidence" do
expect(report.occurrences.map(&:severity)).to include("unknown")
expect(report.occurrences.map(&:confidence)).to include("unknown")
expect(report.occurrences.map(&:severity)).not_to include("undefined")
expect(report.occurrences.map(&:confidence)).not_to include("undefined")
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