Commit cc5691d5 authored by Mehmet Emin INAC's avatar Mehmet Emin INAC

Fix errors and make the migration more verbose

We had some exceptions with the first attempt to migrate the values for
vulnerabilities. These changes fixes those exceptions and add more log
messages to make it easier to check the migration result.
parent 787fdf92
fdcce45050f972d8edf2c645022f517ff6b9f4c76767e6cebe45a11fe34dd388
\ No newline at end of file
2564c387b727e557b2988996aa533ba5e4e6d7b01515407bd2692c09644ac2be
\ No newline at end of file
...@@ -90,6 +90,8 @@ module EE ...@@ -90,6 +90,8 @@ module EE
end end
def reports def reports
return [] unless default_branch
@reports ||= artifacts.to_a.map(&:reports).flatten @reports ||= artifacts.to_a.map(&:reports).flatten
end end
...@@ -345,6 +347,7 @@ module EE ...@@ -345,6 +347,7 @@ module EE
def root_ref def root_ref
raw_repository&.root_ref raw_repository&.root_ref
rescue Gitlab::Git::Repository::NoRepository
end end
def empty? def empty?
...@@ -392,6 +395,10 @@ module EE ...@@ -392,6 +395,10 @@ module EE
project.vulnerabilities project.vulnerabilities
.id_not_in(existing_vulnerability_ids) .id_not_in(existing_vulnerability_ids)
.update_all(resolved_on_default_branch: true) .update_all(resolved_on_default_branch: true)
log_info
rescue StandardError => e
log_error(e)
end end
private private
...@@ -400,16 +407,47 @@ module EE ...@@ -400,16 +407,47 @@ module EE
delegate :reports, to: :project, private: true delegate :reports, to: :project, private: true
def log_info
::Gitlab::BackgroundMigration::Logger.info(
migrator: 'PopulateResolvedOnDefaultBranchColumnForProject',
message: 'Project migrated',
stats: stats,
project_id: project_id
)
end
def stats
{
all_count: findings.length,
valid_count: all_valid_findings.length,
existing_count: existing_vulnerability_ids.length
}
end
def log_error(error)
::Gitlab::BackgroundMigration::Logger.error(
migrator: 'PopulateResolvedOnDefaultBranchColumnForProject',
message: error.message,
project_id: project_id
)
end
def project def project
@project ||= Project.find(project_id) @project ||= Project.find(project_id)
end end
def existing_vulnerability_ids def existing_vulnerability_ids
all_findings_with_scanner.map { |finding| find_saved_finding_for(finding)&.vulnerability_id }.compact @existing_vulnerability_ids ||= all_valid_findings.map { |finding| find_saved_finding_for(finding)&.vulnerability_id }.compact
end
def all_valid_findings
@all_valid_findings ||= findings.select(&:scanner)
.select(&:primary_identifier)
.select(&:location)
end end
def all_findings_with_scanner def findings
reports.flat_map(&:findings).select(&:scanner) @findings ||= reports.flat_map(&:findings)
end end
def find_saved_finding_for(finding) def find_saved_finding_for(finding)
......
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