2021-03-19 08:09:03 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Ci
|
2021-08-03 02:08:50 -04:00
|
|
|
class UnitTest < Ci::ApplicationRecord
|
2021-03-19 08:09:03 -04:00
|
|
|
MAX_NAME_SIZE = 255
|
|
|
|
MAX_SUITE_NAME_SIZE = 255
|
|
|
|
|
|
|
|
validates :project, :key_hash, :name, :suite_name, presence: true
|
|
|
|
|
|
|
|
has_many :unit_test_failures, class_name: 'Ci::UnitTestFailure'
|
|
|
|
|
|
|
|
belongs_to :project
|
|
|
|
|
|
|
|
scope :by_project_and_keys, -> (project, keys) { where(project_id: project.id, key_hash: keys) }
|
2021-05-18 17:10:16 -04:00
|
|
|
scope :deletable, -> { where('NOT EXISTS (?)', Ci::UnitTestFailure.select(1).where("#{Ci::UnitTestFailure.table_name}.unit_test_id = #{table_name}.id")) }
|
2021-03-19 08:09:03 -04:00
|
|
|
|
|
|
|
class << self
|
|
|
|
def find_or_create_by_batch(project, unit_test_attrs)
|
|
|
|
# Insert records first. Existing ones will be skipped.
|
|
|
|
insert_all(build_insert_attrs(project, unit_test_attrs))
|
|
|
|
|
|
|
|
# Find all matching records now that we are sure they all are persisted.
|
|
|
|
by_project_and_keys(project, gather_keys(unit_test_attrs))
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def build_insert_attrs(project, unit_test_attrs)
|
|
|
|
# NOTE: Rails 6.1 will add support for insert_all on relation so that
|
|
|
|
# we will be able to do project.test_cases.insert_all.
|
|
|
|
unit_test_attrs.map do |attrs|
|
|
|
|
attrs.merge(
|
|
|
|
project_id: project.id,
|
|
|
|
name: attrs[:name].truncate(MAX_NAME_SIZE),
|
|
|
|
suite_name: attrs[:suite_name].truncate(MAX_SUITE_NAME_SIZE)
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def gather_keys(unit_test_attrs)
|
|
|
|
unit_test_attrs.map { |attrs| attrs[:key_hash] }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|