26 lines
1 KiB
Ruby
26 lines
1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Ci
|
|
class BuildNeed < Ci::ApplicationRecord
|
|
include BulkInsertSafe
|
|
include IgnorableColumns
|
|
|
|
ignore_columns :build_id_convert_to_bigint, remove_with: '14.1', remove_after: '2021-07-22'
|
|
|
|
belongs_to :build, class_name: "Ci::Processable", foreign_key: :build_id, inverse_of: :needs
|
|
|
|
validates :build, presence: true
|
|
validates :name, presence: true, length: { maximum: 128 }
|
|
validates :optional, inclusion: { in: [true, false] }
|
|
|
|
scope :scoped_build, -> { where('ci_builds.id=ci_build_needs.build_id') }
|
|
scope :artifacts, -> { where(artifacts: true) }
|
|
|
|
# TODO: Remove once build_id_convert_to_bigint is not an "ignored" column anymore (see .ignore_columns above)
|
|
# There is a database-side trigger to populate this column. This is unexpected in the context
|
|
# of cloning an instance, e.g. when retrying the job. Hence we exclude the ignored column explicitly here.
|
|
def attributes
|
|
super.except('build_id_convert_to_bigint')
|
|
end
|
|
end
|
|
end
|