debian-mirror-gitlab/spec/factories/ci/job_artifacts.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

462 lines
13 KiB
Ruby
Raw Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
2018-03-17 18:26:18 +05:30
FactoryBot.define do
2020-03-13 15:44:24 +05:30
factory :ci_job_artifact, class: 'Ci::JobArtifact' do
2018-03-17 18:26:18 +05:30
job factory: :ci_build
2019-12-21 20:55:43 +05:30
file_type { :archive }
file_format { :zip }
2018-03-17 18:26:18 +05:30
2019-12-04 20:38:33 +05:30
trait :expired do
2022-04-01 21:47:47 +05:30
expire_at { Time.current.yesterday.change(minute: 9) }
2019-12-04 20:38:33 +05:30
end
2022-03-02 08:16:31 +05:30
trait :locked do
locked { Ci::JobArtifact.lockeds[:artifacts_locked] }
end
2018-05-09 12:01:36 +05:30
trait :remote_store do
2019-12-21 20:55:43 +05:30
file_store { JobArtifactUploader::Store::REMOTE}
2018-05-09 12:01:36 +05:30
end
2018-03-17 18:26:18 +05:30
after :build do |artifact|
artifact.project ||= artifact.job.project
end
2018-12-05 23:21:45 +05:30
trait :raw do
2019-12-21 20:55:43 +05:30
file_format { :raw }
2018-12-05 23:21:45 +05:30
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/trace/sample_trace'), 'text/plain')
end
end
trait :zip do
2019-12-21 20:55:43 +05:30
file_format { :zip }
2018-12-05 23:21:45 +05:30
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/ci_build_artifacts.zip'), 'application/zip')
end
end
trait :gzip do
2019-12-21 20:55:43 +05:30
file_format { :gzip }
2018-12-05 23:21:45 +05:30
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/ci_build_artifacts_metadata.gz'), 'application/x-gzip')
end
end
2018-03-17 18:26:18 +05:30
trait :archive do
2019-12-21 20:55:43 +05:30
file_type { :archive }
file_format { :zip }
2018-03-17 18:26:18 +05:30
2019-09-04 21:01:54 +05:30
transient do
file { fixture_file_upload(Rails.root.join('spec/fixtures/ci_build_artifacts.zip'), 'application/zip') }
end
after(:build) do |artifact, evaluator|
artifact.file = evaluator.file
2018-03-17 18:26:18 +05:30
end
end
2018-11-20 20:47:30 +05:30
trait :legacy_archive do
archive
2019-12-21 20:55:43 +05:30
file_location { :legacy_path }
2018-11-20 20:47:30 +05:30
end
2018-03-17 18:26:18 +05:30
trait :metadata do
2019-12-21 20:55:43 +05:30
file_type { :metadata }
file_format { :gzip }
2018-03-17 18:26:18 +05:30
2019-09-04 21:01:54 +05:30
transient do
file { fixture_file_upload(Rails.root.join('spec/fixtures/ci_build_artifacts_metadata.gz'), 'application/x-gzip') }
end
after(:build) do |artifact, evaluator|
artifact.file = evaluator.file
2018-03-17 18:26:18 +05:30
end
end
trait :trace do
2019-12-21 20:55:43 +05:30
file_type { :trace }
file_format { :raw }
2018-03-17 18:26:18 +05:30
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/trace/sample_trace'), 'text/plain')
end
end
2018-05-09 12:01:36 +05:30
2021-12-11 22:18:48 +05:30
trait :unarchived_trace_artifact do
file_type { :trace }
file_format { :raw }
after(:build) do |artifact, evaluator|
file = double('file', path: '/path/to/job.log')
artifact.file = file
allow(artifact.file).to receive(:file).and_return(CarrierWave::SanitizedFile.new(file))
end
end
2018-11-18 11:00:15 +05:30
trait :junit do
2019-12-21 20:55:43 +05:30
file_type { :junit }
file_format { :gzip }
2018-11-18 11:00:15 +05:30
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/junit/junit.xml.gz'), 'application/x-gzip')
end
end
2020-04-22 19:07:51 +05:30
trait :junit_with_attachment do
file_type { :junit }
file_format { :gzip }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/junit/junit_with_attachment.xml.gz'), 'application/x-gzip')
end
end
2021-01-29 00:20:46 +05:30
trait :junit_with_duplicate_failed_test_names do
file_type { :junit }
file_format { :gzip }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/junit/junit_with_duplicate_failed_test_names.xml.gz'), 'application/x-gzip')
end
end
2018-11-18 11:00:15 +05:30
trait :junit_with_ant do
2019-12-21 20:55:43 +05:30
file_type { :junit }
file_format { :gzip }
2018-11-18 11:00:15 +05:30
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/junit/junit_ant.xml.gz'), 'application/x-gzip')
end
end
trait :junit_with_three_testsuites do
2019-12-21 20:55:43 +05:30
file_type { :junit }
file_format { :gzip }
2018-11-18 11:00:15 +05:30
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/junit/junit_with_three_testsuites.xml.gz'), 'application/x-gzip')
end
end
trait :junit_with_corrupted_data do
2019-12-21 20:55:43 +05:30
file_type { :junit }
file_format { :gzip }
2018-11-18 11:00:15 +05:30
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/junit/junit_with_corrupted_data.xml.gz'), 'application/x-gzip')
end
end
2021-01-29 00:20:46 +05:30
trait :junit_with_three_failures do
file_type { :junit }
file_format { :gzip }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/junit/junit_with_three_failures.xml.gz'), 'application/x-gzip')
end
end
2020-05-24 23:13:21 +05:30
trait :accessibility do
file_type { :accessibility }
file_format { :raw }
after(:build) do |artifact, _evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/accessibility/pa11y_with_errors.json'), 'application/json')
end
end
trait :accessibility_with_invalid_url do
file_type { :accessibility }
file_format { :raw }
after(:build) do |artifact, _evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/accessibility/pa11y_with_invalid_url.json'), 'application/json')
end
end
trait :accessibility_without_errors do
file_type { :accessibility }
file_format { :raw }
after(:build) do |artifact, _evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/accessibility/pa11y_without_errors.json'), 'application/json')
end
end
2020-04-08 14:13:33 +05:30
trait :cobertura do
file_type { :cobertura }
file_format { :gzip }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/cobertura/coverage.xml.gz'), 'application/x-gzip')
end
end
2020-05-24 23:13:21 +05:30
trait :terraform do
file_type { :terraform }
file_format { :raw }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/terraform/tfplan.json'), 'application/json')
end
end
trait :terraform_with_corrupted_data do
file_type { :terraform }
file_format { :raw }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/terraform/tfplan_with_corrupted_data.json'), 'application/json')
end
end
2020-04-08 14:13:33 +05:30
trait :coverage_gocov_xml do
file_type { :cobertura }
file_format { :gzip }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/cobertura/coverage_gocov_xml.xml.gz'), 'application/x-gzip')
end
end
2021-02-22 17:27:13 +05:30
trait :coverage_with_paths_not_relative_to_project_root do
file_type { :cobertura }
file_format { :gzip }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/cobertura/coverage_with_paths_not_relative_to_project_root.xml.gz'), 'application/x-gzip')
end
end
2020-04-08 14:13:33 +05:30
trait :coverage_with_corrupted_data do
file_type { :cobertura }
file_format { :gzip }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/cobertura/coverage_with_corrupted_data.xml.gz'), 'application/x-gzip')
end
end
2018-12-05 23:21:45 +05:30
trait :codequality do
2019-12-21 20:55:43 +05:30
file_type { :codequality }
file_format { :raw }
2018-12-05 23:21:45 +05:30
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
2021-02-22 17:27:13 +05:30
Rails.root.join('spec/fixtures/codequality/codeclimate.json'), 'application/json')
end
end
trait :codequality_without_errors do
file_type { :codequality }
file_format { :raw }
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/codequality/codeclimate_without_errors.json'), 'application/json')
2018-12-05 23:21:45 +05:30
end
end
2021-03-11 19:13:27 +05:30
trait :sast do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-sast-report.json'), 'application/json')
end
end
2021-06-08 01:23:25 +05:30
trait :sast_minimal do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-sast-report-minimal.json'), 'application/json')
end
end
2022-06-21 17:19:12 +05:30
# Bandit reports are correctly de-duplicated when ran in the same pipeline
# as a corresponding semgrep report.
# This report does not include signature tracking.
trait :sast_bandit do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-sast-report-bandit.json'), 'application/json')
end
end
# Equivalent Semgrep report for :sast_bandit report.
# This report includes signature tracking.
trait :sast_semgrep_for_bandit do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-sast-report-semgrep-for-bandit.json'), 'application/json')
end
end
# Gosec reports are not correctly de-duplicated when ran in the same pipeline
# as a corresponding semgrep report.
# This report includes signature tracking.
trait :sast_gosec do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-sast-report-gosec.json'), 'application/json')
end
end
# Equivalent Semgrep report for :sast_gosec report.
# This report includes signature tracking.
trait :sast_semgrep_for_gosec do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-sast-report-semgrep-for-gosec.json'), 'application/json')
end
end
2021-10-27 15:23:28 +05:30
trait :common_security_report do
file_format { :raw }
file_type { :dependency_scanning }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-common-scanning-report.json'), 'application/json')
end
end
trait :common_security_report_with_blank_names do
file_format { :raw }
file_type { :dependency_scanning }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-common-scanning-report-names.json'), 'application/json')
end
end
trait :sast_deprecated do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/deprecated/gl-sast-report.json'), 'application/json')
end
end
trait :sast_with_corrupted_data do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/trace/sample_trace'), 'application/json')
end
end
trait :sast_feature_branch do
file_format { :raw }
file_type { :sast }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/feature-branch/gl-sast-report.json'), 'application/json')
end
end
trait :secret_detection_feature_branch do
file_format { :raw }
file_type { :secret_detection }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/feature-branch/gl-secret-detection-report.json'), 'application/json')
end
end
trait :sast_with_missing_scanner do
file_type { :sast }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-sast-missing-scanner.json'), 'application/json')
end
end
2021-03-11 19:13:27 +05:30
trait :secret_detection do
file_type { :secret_detection }
file_format { :raw }
after(:build) do |artifact, _|
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/security_reports/master/gl-secret-detection-report.json'), 'application/json')
end
end
2020-03-13 15:44:24 +05:30
trait :lsif do
file_type { :lsif }
2020-05-24 23:13:21 +05:30
file_format { :zip }
2020-04-08 14:13:33 +05:30
after(:build) do |artifact, evaluator|
2020-06-23 00:09:42 +05:30
artifact.file = fixture_file_upload(
Rails.root.join('spec/fixtures/lsif.json.zip'), 'application/zip')
2020-04-08 14:13:33 +05:30
end
end
trait :dotenv do
file_type { :dotenv }
file_format { :gzip }
2020-03-13 15:44:24 +05:30
after(:build) do |artifact, evaluator|
artifact.file = fixture_file_upload(
2020-04-08 14:13:33 +05:30
Rails.root.join('spec/fixtures/build.env.gz'), 'application/x-gzip')
2020-03-13 15:44:24 +05:30
end
end
2018-05-09 12:01:36 +05:30
trait :correct_checksum do
after(:build) do |artifact, evaluator|
artifact.file_sha256 = Digest::SHA256.file(artifact.file.path).hexdigest
end
end
2018-03-17 18:26:18 +05:30
end
end