# frozen_string_literal: true FactoryBot.define do factory :ci_build, class: 'Ci::Build', parent: :ci_processable do name { 'test' } add_attribute(:protected) { false } created_at { 'Di 29. Okt 09:50:00 CET 2013' } scheduling_type { 'stage' } pending options do { image: 'ruby:2.7', services: ['postgres'], script: ['ls -a'] } end yaml_variables do [ { key: 'DB_NAME', value: 'postgres', public: true } ] end project { pipeline.project } trait :degenerated do options { nil } yaml_variables { nil } end trait :unique_name do name { generate(:job_name) } end trait :dependent do scheduling_type { 'dag' } transient do sequence(:needed_name) { |n| "dependency #{n}" } needed { association(:ci_build, name: needed_name, pipeline: pipeline) } end after(:create) do |build, evaluator| build.needs << create(:ci_build_need, build: build, name: evaluator.needed.name) end end trait :started do started_at { 'Di 29. Okt 09:51:28 CET 2013' } end trait :finished do started finished_at { 'Di 29. Okt 09:53:28 CET 2013' } end trait :success do finished status { 'success' } end trait :failed do finished status { 'failed' } end trait :canceled do finished status { 'canceled' } end trait :skipped do started status { 'skipped' } end trait :running do started status { 'running' } end trait :pending do queued_at { 'Di 29. Okt 09:50:59 CET 2013' } status { 'pending' } end trait :created do status { 'created' } end trait :preparing do status { 'preparing' } end trait :scheduled do schedulable status { 'scheduled' } scheduled_at { 1.minute.since } end trait :expired_scheduled do schedulable status { 'scheduled' } scheduled_at { 1.minute.ago } end trait :manual do status { 'manual' } self.when { 'manual' } end trait :teardown_environment do environment { 'staging' } options do { script: %w(ls), environment: { name: 'staging', action: 'stop', url: 'http://staging.example.com/$CI_JOB_NAME' } } end end trait :environment_with_deployment_tier do environment { 'test_portal' } options do { script: %w(ls), environment: { name: 'test_portal', action: 'start', url: 'http://staging.example.com/$CI_JOB_NAME', deployment_tier: 'testing' } } end end trait :deploy_to_production do environment { 'production' } options do { script: %w(ls), environment: { name: 'production', url: 'http://prd.example.com/$CI_JOB_NAME' } } end end trait :start_review_app do environment { 'review/$CI_COMMIT_REF_NAME' } options do { script: %w(ls), environment: { name: 'review/$CI_COMMIT_REF_NAME', url: 'http://staging.example.com/$CI_JOB_NAME', on_stop: 'stop_review_app' } } end end trait :stop_review_app do name { 'stop_review_app' } environment { 'review/$CI_COMMIT_REF_NAME' } options do { script: %w(ls), environment: { name: 'review/$CI_COMMIT_REF_NAME', url: 'http://staging.example.com/$CI_JOB_NAME', action: 'stop' } } end end trait :allowed_to_fail do allow_failure { true } end trait :ignored do allowed_to_fail end trait :playable do manual end trait :retryable do success end trait :schedulable do self.when { 'delayed' } options do { script: ['ls -a'], start_in: '1 minute' } end end trait :actionable do self.when { 'manual' } end trait :retried do retried { true } end trait :cancelable do pending end trait :erasable do success artifacts end trait :tags do tag_list do [:docker, :ruby] end end trait :on_tag do tag { true } end trait :triggered do trigger_request factory: :ci_trigger_request end trait :with_deployment do after(:build) do |build, evaluator| ## # Build deployment/environment relations if environment name is set # to the job. If `build.deployment` has already been set, it doesn't # build a new instance. environment = Gitlab::Ci::Pipeline::Seed::Environment.new(build).to_resource build.assign_attributes( deployment: Gitlab::Ci::Pipeline::Seed::Deployment.new(build, environment).to_resource, metadata_attributes: { expanded_environment_name: environment.name } ) end end trait :tag do tag { true } end trait :coverage do coverage { 99.9 } coverage_regex { '/(d+)/' } end trait :trace_with_coverage do coverage { nil } coverage_regex { '(\d+\.\d+)%' } transient do trace_coverage { 60.0 } end after(:create) do |build, evaluator| build.trace.set("Coverage #{evaluator.trace_coverage}%") build.trace.archive! if build.complete? end end trait :trace_live do after(:create) do |build, evaluator| build.trace.set('BUILD TRACE') end end trait :trace_artifact do after(:create) do |build, evaluator| create(:ci_job_artifact, :trace, job: build) end end trait :unarchived_trace_artifact do after(:create) do |build, evaluator| create(:ci_job_artifact, :unarchived_trace_artifact, job: build) end end trait :trace_with_duplicate_sections do after(:create) do |build, evaluator| trace = File.binread( File.expand_path( Rails.root.join('spec/fixtures/trace/trace_with_duplicate_sections'))) build.trace.set(trace) end end trait :trace_with_sections do after(:create) do |build, evaluator| trace = File.binread( File.expand_path( Rails.root.join('spec/fixtures/trace/trace_with_sections'))) build.trace.set(trace) end end trait :unicode_trace_live do after(:create) do |build, evaluator| trace = File.binread( File.expand_path( Rails.root.join('spec/fixtures/trace/ansi-sequence-and-unicode'))) build.trace.set(trace) end end trait :erased do erased_at { Time.now } erased_by factory: :user end trait :queued do queued_at { Time.now } after(:create) do |build| build.create_queuing_entry! end end trait :picked do running runner factory: :ci_runner end trait :artifacts do after(:create) do |build| create(:ci_job_artifact, :archive, job: build, expire_at: build.artifacts_expire_at) create(:ci_job_artifact, :metadata, job: build, expire_at: build.artifacts_expire_at) build.reload end end trait :report_results do after(:build) do |build| build.report_results << build(:ci_build_report_result) end end trait :codequality_report do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :codequality, job: build) end end trait :sast_report do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :sast, job: build) end end trait :secret_detection_report do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :secret_detection, job: build) end end trait :test_reports do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :junit, job: build) end end trait :test_reports_with_attachment do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :junit_with_attachment, job: build) end end trait :broken_test_reports do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :junit_with_corrupted_data, job: build) end end trait :test_reports_with_duplicate_failed_test_names do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :junit_with_duplicate_failed_test_names, job: build) end end trait :test_reports_with_three_failures do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :junit_with_three_failures, job: build) end end trait :accessibility_reports do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :accessibility, job: build) end end trait :coverage_reports do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :cobertura, job: build) end end trait :codequality_reports do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :codequality, job: build) end end trait :codequality_reports_without_degradation do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :codequality_without_errors, job: build) end end trait :terraform_reports do after(:build) do |build| build.job_artifacts << create(:ci_job_artifact, :terraform, job: build) end end trait :expired do artifacts_expire_at { 1.minute.ago } end trait :with_commit do after(:build) do |build| allow(build).to receive(:commit).and_return build(:commit, :without_author) end end trait :with_commit_and_author do after(:build) do |build| allow(build).to receive(:commit).and_return build(:commit) end end trait :extended_options do options do { image: { name: 'ruby:2.7', entrypoint: '/bin/sh' }, services: ['postgres', { name: 'docker:stable-dind', entrypoint: '/bin/sh', command: 'sleep 30', alias: 'docker' }, { name: 'mysql:latest', variables: { MYSQL_ROOT_PASSWORD: 'root123.' } }], script: %w(echo), after_script: %w(ls date), artifacts: { name: 'artifacts_file', untracked: false, paths: ['out/'], when: 'always', expire_in: '7d' }, cache: { key: 'cache_key', untracked: false, paths: ['vendor/*'], policy: 'pull-push', when: 'on_success' } } end end trait :release_options do options do { only: 'tags', script: ['make changelog | tee release_changelog.txt'], release: { name: 'Release $CI_COMMIT_SHA', description: 'Created using the release-cli $EXTRA_DESCRIPTION', tag_name: 'release-$CI_COMMIT_SHA', ref: '$CI_COMMIT_SHA', assets: { links: [{ name: 'asset1', url: 'https://example.com/assets/1' }] } } } end end trait :no_options do options { {} } end # TODO: move Security traits to ee_ci_build # https://gitlab.com/gitlab-org/gitlab/-/issues/210486 trait :dast do options do { artifacts: { reports: { dast: 'gl-dast-report.json' } } } end end trait :sast do options do { artifacts: { reports: { sast: 'gl-sast-report.json' } } } end end trait :secret_detection do options do { artifacts: { reports: { secret_detection: 'gl-secret-detection-report.json' } } } end end trait :dependency_scanning do options do { artifacts: { reports: { dependency_scanning: 'gl-dependency-scanning-report.json' } } } end end trait :container_scanning do options do { artifacts: { reports: { container_scanning: 'gl-container-scanning-report.json' } } } end end trait :cluster_image_scanning do options do { artifacts: { reports: { cluster_image_scanning: 'gl-cluster-image-scanning-report.json' } } } end end trait :coverage_fuzzing do options do { artifacts: { reports: { coverage_fuzzing: 'gl-coverage-fuzzing-report.json' } } } end end trait :license_scanning do options do { artifacts: { reports: { license_scanning: 'gl-license-scanning-report.json' } } } end end trait :non_public_artifacts do options do { artifacts: { public: false } } end end trait :non_playable do status { 'created' } self.when { 'manual' } end trait :protected do add_attribute(:protected) { true } end trait :script_failure do failed failure_reason { 1 } end trait :api_failure do failed failure_reason { 2 } end trait :prerequisite_failure do failed failure_reason { 10 } end trait :forward_deployment_failure do failed failure_reason { 13 } end trait :with_runner_session do after(:build) do |build| build.build_runner_session(url: 'https://localhost') end end trait :interruptible do after(:build) do |build| build.metadata.interruptible = true end end end end