Commit 42a4f238 authored by Michał Zając's avatar Michał Zając

Use FactoryBot to create objects

parent 66e8b9af
...@@ -36,55 +36,55 @@ class Gitlab::Seeder::Vulnerabilities ...@@ -36,55 +36,55 @@ class Gitlab::Seeder::Vulnerabilities
private private
def create_vulnerability def create_vulnerability
vulnerability = project.vulnerabilities.build( state_symbol = ::Vulnerability.states.keys.sample.to_sym
vulnerability = build_vulnerability(state_symbol)
case state_symbol
when :resolved
vulnerability.resolved_by = author
when :dismissed
vulnerability.closed_by = author
end
vulnerability.tap(&:save!)
end
def build_vulnerability(state_symbol)
FactoryBot.build(
:vulnerability,
state_symbol,
project: project,
author: author, author: author,
title: 'Cypher with no integrity', title: 'Cypher with no integrity',
severity: random_severity_level, severity: random_severity_level,
confidence: random_confidence_level, confidence: random_confidence_level,
report_type: random_report_type report_type: random_report_type
) )
vulnerability = set_random_vulnerability_state(vulnerability)
vulnerability.save!
vulnerability
end
def set_random_vulnerability_state(vulnerability)
state = ::Vulnerability.states.keys.sample
vulnerability.state = state
case state
when "resolved"
vulnerability.resolved_by = vulnerability.author
vulnerability.resolved_at = Time.now
when "dismissed"
vulnerability.closed_by = vulnerability.author
vulnerability.closed_at = Time.now
end
vulnerability
end end
def create_occurrence(vulnerability, rank, primary_identifier) def create_occurrence(vulnerability, rank, primary_identifier)
project.vulnerability_findings.create!( FactoryBot.create(
:vulnerabilities_occurrence,
project: project,
vulnerability: vulnerability, vulnerability: vulnerability,
uuid: random_uuid,
name: 'Cipher with no integrity',
report_type: :sast,
severity: random_severity_level, severity: random_severity_level,
confidence: random_confidence_level, confidence: random_confidence_level,
primary_identifier: primary_identifier,
project_fingerprint: random_fingerprint, project_fingerprint: random_fingerprint,
location_fingerprint: random_fingerprint, location_fingerprint: random_fingerprint,
primary_identifier: primary_identifier, raw_metadata: metadata(rank).to_json
raw_metadata: metadata(rank).to_json, )
metadata_version: 'sast:1.0',
scanner: scanner)
end end
def create_identifier(rank) def create_identifier(rank)
project.vulnerability_identifiers.create!( FactoryBot.create(
:vulnerability_identifier,
external_type: "SECURITY_ID", external_type: "SECURITY_ID",
external_id: "SECURITY_#{rank}", external_id: "SECURITY_#{rank}",
fingerprint: random_fingerprint, fingerprint: random_fingerprint,
name: "SECURITY_IDENTIFIER #{rank}", name: "SECURITY_IDENTIFIER #{rank}",
url: "https://security.example.com/#{rank}" url: "https://security.example.com/#{rank}",
project: project
) )
end end
...@@ -94,33 +94,33 @@ class Gitlab::Seeder::Vulnerabilities ...@@ -94,33 +94,33 @@ class Gitlab::Seeder::Vulnerabilities
create_vulnerability_issue_link(vulnerability, issue) create_vulnerability_issue_link(vulnerability, issue)
end end
project.vulnerability_feedback.create!( FactoryBot.create(
:vulnerability_feedback,
feedback_type: type, feedback_type: type,
category: 'sast', project: project,
author: author, author: author,
issue: issue, issue: issue,
pipeline: pipeline, pipeline: pipeline,
project_fingerprint: occurrence.project_fingerprint, project_fingerprint: occurrence.project_fingerprint
vulnerability_data: { category: 'sast' })
end
def create_vulnerability_issue_link(vulnerability, issue)
::Vulnerabilities::IssueLink.create!(
vulnerability: vulnerability,
issue: issue,
link_type: :created
) )
end end
def scanner def create_issue(title)
@scanner ||= project.vulnerability_scanners.create!( FactoryBot.create(
:issue,
project: project, project: project,
external_id: 'security-scanner', author: author,
name: 'Security Scanner') title: title
)
end end
def create_issue(title) def create_vulnerability_issue_link(vulnerability, issue)
project.issues.create!(author: author, title: title) FactoryBot.create(
:vulnerabilities_issue_link,
:created,
vulnerability: vulnerability,
issue: issue
)
end end
def random_confidence_level def random_confidence_level
...@@ -155,10 +155,6 @@ class Gitlab::Seeder::Vulnerabilities ...@@ -155,10 +155,6 @@ class Gitlab::Seeder::Vulnerabilities
} }
end end
def random_uuid
SecureRandom.hex(18)
end
def random_fingerprint def random_fingerprint
SecureRandom.hex(20) SecureRandom.hex(20)
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