Commit 9d971b24 authored by Thong Kuah's avatar Thong Kuah

Merge branch '336426-inherit-ci-models-from-ci-application-record' into 'master'

Inherit CI models from Ci::ApplicationRecord [RUN AS-IF-FOSS]

See merge request gitlab-org/gitlab!66396
parents 825247ab 8adb61e1
# frozen_string_literal: true
module Ci
class ApplicationRecord < ::ApplicationRecord
self.abstract_class = true
def self.table_name_prefix
'ci_'
end
def self.model_name
@model_name ||= ActiveModel::Name.new(self, nil, self.name.demodulize)
end
end
end
...@@ -3,10 +3,9 @@ ...@@ -3,10 +3,9 @@
module Ci module Ci
# The purpose of this class is to store Build related data that can be disposed. # The purpose of this class is to store Build related data that can be disposed.
# Data that should be persisted forever, should be stored with Ci::Build model. # Data that should be persisted forever, should be stored with Ci::Build model.
class BuildMetadata < ApplicationRecord class BuildMetadata < Ci::ApplicationRecord
BuildTimeout = Struct.new(:value, :source) BuildTimeout = Struct.new(:value, :source)
extend Gitlab::Ci::Model
include Presentable include Presentable
include ChronicDurationAttribute include ChronicDurationAttribute
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class BuildNeed < ApplicationRecord class BuildNeed < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include BulkInsertSafe include BulkInsertSafe
include IgnorableColumns include IgnorableColumns
......
# frozen_string_literal: true # frozen_string_literal: true
class Ci::BuildPendingState < ApplicationRecord class Ci::BuildPendingState < Ci::ApplicationRecord
extend Gitlab::Ci::Model
belongs_to :build, class_name: 'Ci::Build', foreign_key: :build_id belongs_to :build, class_name: 'Ci::Build', foreign_key: :build_id
enum state: Ci::Stage.statuses enum state: Ci::Stage.statuses
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class BuildReportResult < ApplicationRecord class BuildReportResult < Ci::ApplicationRecord
extend Gitlab::Ci::Model
self.primary_key = :build_id self.primary_key = :build_id
belongs_to :build, class_name: "Ci::Build", inverse_of: :report_results belongs_to :build, class_name: "Ci::Build", inverse_of: :report_results
......
...@@ -3,8 +3,7 @@ ...@@ -3,8 +3,7 @@
module Ci module Ci
# The purpose of this class is to store Build related runner session. # The purpose of this class is to store Build related runner session.
# Data will be removed after transitioning from running to any state. # Data will be removed after transitioning from running to any state.
class BuildRunnerSession < ApplicationRecord class BuildRunnerSession < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include IgnorableColumns include IgnorableColumns
ignore_columns :build_id_convert_to_bigint, remove_with: '14.1', remove_after: '2021-07-22' ignore_columns :build_id_convert_to_bigint, remove_with: '14.1', remove_after: '2021-07-22'
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class BuildTraceChunk < ApplicationRecord class BuildTraceChunk < Ci::ApplicationRecord
extend ::Gitlab::Ci::Model
include ::Comparable include ::Comparable
include ::FastDestroyAll include ::FastDestroyAll
include ::Checksummable include ::Checksummable
......
...@@ -7,7 +7,7 @@ module Ci ...@@ -7,7 +7,7 @@ module Ci
# This class is part of a migration to move all CI classes to a new separate database. # This class is part of a migration to move all CI classes to a new separate database.
# Initially we are only going to be moving the `Ci::InstanceVariable` model and it will be duplicated in the main and CI tables # Initially we are only going to be moving the `Ci::InstanceVariable` model and it will be duplicated in the main and CI tables
# Do not extend this class in any other models. # Do not extend this class in any other models.
class BaseModel < ::ApplicationRecord class CiDatabaseRecord < Ci::ApplicationRecord
self.abstract_class = true self.abstract_class = true
if Gitlab::Database.has_config?(:ci) if Gitlab::Database.has_config?(:ci)
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class DailyBuildGroupReportResult < ApplicationRecord class DailyBuildGroupReportResult < Ci::ApplicationRecord
extend Gitlab::Ci::Model
PARAM_TYPES = %w[coverage].freeze PARAM_TYPES = %w[coverage].freeze
belongs_to :last_pipeline, class_name: 'Ci::Pipeline', foreign_key: :last_pipeline_id belongs_to :last_pipeline, class_name: 'Ci::Pipeline', foreign_key: :last_pipeline_id
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class DeletedObject < ApplicationRecord class DeletedObject < Ci::ApplicationRecord
extend Gitlab::Ci::Model
mount_uploader :file, DeletedObjectUploader mount_uploader :file, DeletedObjectUploader
scope :ready_for_destruction, ->(limit) do scope :ready_for_destruction, ->(limit) do
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class FreezePeriod < ApplicationRecord class FreezePeriod < Ci::ApplicationRecord
include StripAttribute include StripAttribute
self.table_name = 'ci_freeze_periods' include Ci::NamespacedModelName
default_scope { order(created_at: :asc) } # rubocop:disable Cop/DefaultScope default_scope { order(created_at: :asc) } # rubocop:disable Cop/DefaultScope
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class GroupVariable < ApplicationRecord class GroupVariable < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Ci::HasVariable include Ci::HasVariable
include Presentable include Presentable
include Ci::Maskable include Ci::Maskable
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class InstanceVariable < ::Ci::BaseModel class InstanceVariable < Ci::CiDatabaseRecord
extend Gitlab::Ci::Model
extend Gitlab::ProcessMemoryCache::Helper extend Gitlab::ProcessMemoryCache::Helper
include Ci::NewHasVariable include Ci::NewHasVariable
include Ci::Maskable include Ci::Maskable
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class JobArtifact < ApplicationRecord class JobArtifact < Ci::ApplicationRecord
include AfterCommitQueue include AfterCommitQueue
include ObjectStorage::BackgroundMove include ObjectStorage::BackgroundMove
include UpdateProjectStatistics include UpdateProjectStatistics
...@@ -10,7 +10,6 @@ module Ci ...@@ -10,7 +10,6 @@ module Ci
include Artifactable include Artifactable
include FileStoreMounter include FileStoreMounter
include EachBatch include EachBatch
extend Gitlab::Ci::Model
TEST_REPORT_FILE_TYPES = %w[junit].freeze TEST_REPORT_FILE_TYPES = %w[junit].freeze
COVERAGE_REPORT_FILE_TYPES = %w[cobertura].freeze COVERAGE_REPORT_FILE_TYPES = %w[cobertura].freeze
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class JobVariable < ApplicationRecord class JobVariable < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Ci::NewHasVariable include Ci::NewHasVariable
include BulkInsertSafe include BulkInsertSafe
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class PendingBuild < ApplicationRecord class PendingBuild < Ci::ApplicationRecord
extend Gitlab::Ci::Model
belongs_to :project belongs_to :project
belongs_to :build, class_name: 'Ci::Build' belongs_to :build, class_name: 'Ci::Build'
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class Pipeline < ApplicationRecord class Pipeline < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Ci::HasStatus include Ci::HasStatus
include Importable include Importable
include AfterCommitQueue include AfterCommitQueue
......
...@@ -3,8 +3,7 @@ ...@@ -3,8 +3,7 @@
# This class is being used to persist additional artifacts after a pipeline completes, which is a great place to cache a computed result in object storage # This class is being used to persist additional artifacts after a pipeline completes, which is a great place to cache a computed result in object storage
module Ci module Ci
class PipelineArtifact < ApplicationRecord class PipelineArtifact < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include UpdateProjectStatistics include UpdateProjectStatistics
include Artifactable include Artifactable
include FileStoreMounter include FileStoreMounter
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class PipelineChatData < ApplicationRecord class PipelineChatData < Ci::ApplicationRecord
include Ci::NamespacedModelName
self.table_name = 'ci_pipeline_chat_data' self.table_name = 'ci_pipeline_chat_data'
belongs_to :chat_name belongs_to :chat_name
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class PipelineConfig < ApplicationRecord class PipelineConfig < Ci::ApplicationRecord
extend Gitlab::Ci::Model
self.table_name = 'ci_pipelines_config' self.table_name = 'ci_pipelines_config'
self.primary_key = :pipeline_id self.primary_key = :pipeline_id
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class PipelineMessage < ApplicationRecord class PipelineMessage < Ci::ApplicationRecord
extend Gitlab::Ci::Model
MAX_CONTENT_LENGTH = 10_000 MAX_CONTENT_LENGTH = 10_000
belongs_to :pipeline belongs_to :pipeline
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class PipelineSchedule < ApplicationRecord class PipelineSchedule < Ci::ApplicationRecord
extend Gitlab::Ci::Model
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
include Importable include Importable
include StripAttribute include StripAttribute
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class PipelineScheduleVariable < ApplicationRecord class PipelineScheduleVariable < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Ci::HasVariable include Ci::HasVariable
belongs_to :pipeline_schedule belongs_to :pipeline_schedule
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class PipelineVariable < ApplicationRecord class PipelineVariable < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Ci::HasVariable include Ci::HasVariable
belongs_to :pipeline belongs_to :pipeline
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class Ref < ApplicationRecord class Ref < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include AfterCommitQueue include AfterCommitQueue
include Gitlab::OptimisticLocking include Gitlab::OptimisticLocking
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class Resource < ApplicationRecord class Resource < Ci::ApplicationRecord
extend Gitlab::Ci::Model
belongs_to :resource_group, class_name: 'Ci::ResourceGroup', inverse_of: :resources belongs_to :resource_group, class_name: 'Ci::ResourceGroup', inverse_of: :resources
belongs_to :processable, class_name: 'Ci::Processable', foreign_key: 'build_id', inverse_of: :resource belongs_to :processable, class_name: 'Ci::Processable', foreign_key: 'build_id', inverse_of: :resource
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class ResourceGroup < ApplicationRecord class ResourceGroup < Ci::ApplicationRecord
extend Gitlab::Ci::Model
belongs_to :project, inverse_of: :resource_groups belongs_to :project, inverse_of: :resource_groups
has_many :resources, class_name: 'Ci::Resource', inverse_of: :resource_group has_many :resources, class_name: 'Ci::Resource', inverse_of: :resource_group
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class Runner < ApplicationRecord class Runner < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Gitlab::SQL::Pattern include Gitlab::SQL::Pattern
include RedisCacheable include RedisCacheable
include ChronicDurationAttribute include ChronicDurationAttribute
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class RunnerNamespace < ApplicationRecord class RunnerNamespace < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Limitable include Limitable
self.limit_name = 'ci_registered_group_runners' self.limit_name = 'ci_registered_group_runners'
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class RunnerProject < ApplicationRecord class RunnerProject < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Limitable include Limitable
self.limit_name = 'ci_registered_project_runners' self.limit_name = 'ci_registered_project_runners'
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class RunningBuild < ApplicationRecord class RunningBuild < Ci::ApplicationRecord
extend Gitlab::Ci::Model
belongs_to :project belongs_to :project
belongs_to :build, class_name: 'Ci::Build' belongs_to :build, class_name: 'Ci::Build'
belongs_to :runner, class_name: 'Ci::Runner' belongs_to :runner, class_name: 'Ci::Runner'
......
...@@ -2,7 +2,9 @@ ...@@ -2,7 +2,9 @@
module Ci module Ci
module Sources module Sources
class Pipeline < ApplicationRecord class Pipeline < Ci::ApplicationRecord
include Ci::NamespacedModelName
self.table_name = "ci_sources_pipelines" self.table_name = "ci_sources_pipelines"
belongs_to :project, class_name: "Project" belongs_to :project, class_name: "Project"
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class Stage < ApplicationRecord class Stage < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Importable include Importable
include Ci::HasStatus include Ci::HasStatus
include Gitlab::OptimisticLocking include Gitlab::OptimisticLocking
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class Trigger < ApplicationRecord class Trigger < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Presentable include Presentable
belongs_to :project belongs_to :project
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class TriggerRequest < ApplicationRecord class TriggerRequest < Ci::ApplicationRecord
extend Gitlab::Ci::Model
belongs_to :trigger belongs_to :trigger
belongs_to :pipeline, foreign_key: :commit_id belongs_to :pipeline, foreign_key: :commit_id
has_many :builds has_many :builds
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class UnitTest < ApplicationRecord class UnitTest < Ci::ApplicationRecord
extend Gitlab::Ci::Model
MAX_NAME_SIZE = 255 MAX_NAME_SIZE = 255
MAX_SUITE_NAME_SIZE = 255 MAX_SUITE_NAME_SIZE = 255
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class UnitTestFailure < ApplicationRecord class UnitTestFailure < Ci::ApplicationRecord
extend Gitlab::Ci::Model
REPORT_WINDOW = 14.days REPORT_WINDOW = 14.days
validates :unit_test, :build, :failed_at, presence: true validates :unit_test, :build, :failed_at, presence: true
......
# frozen_string_literal: true # frozen_string_literal: true
module Ci module Ci
class Variable < ApplicationRecord class Variable < Ci::ApplicationRecord
extend Gitlab::Ci::Model
include Ci::HasVariable include Ci::HasVariable
include Presentable include Presentable
include Ci::Maskable include Ci::Maskable
......
# frozen_string_literal: true # frozen_string_literal: true
class CiPlatformMetric < ApplicationRecord class CiPlatformMetric < Ci::ApplicationRecord
include BulkInsertSafe include BulkInsertSafe
self.table_name = 'ci_platform_metrics'
PLATFORM_TARGET_MAX_LENGTH = 255 PLATFORM_TARGET_MAX_LENGTH = 255
validates :recorded_at, presence: true validates :recorded_at, presence: true
......
# frozen_string_literal: true # frozen_string_literal: true
class CommitStatus < ApplicationRecord class CommitStatus < Ci::ApplicationRecord
include Ci::HasStatus include Ci::HasStatus
include Importable include Importable
include AfterCommitQueue include AfterCommitQueue
......
# frozen_string_literal: true # frozen_string_literal: true
module Gitlab module Ci
module Ci module NamespacedModelName
module Model extend ActiveSupport::Concern
def table_name_prefix
"ci_"
end
class_methods do
def model_name def model_name
@model_name ||= ActiveModel::Name.new(self, nil, self.name.demodulize) @model_name ||= ActiveModel::Name.new(self, Ci)
end end
end end
end end
......
...@@ -92,7 +92,7 @@ test: &test ...@@ -92,7 +92,7 @@ test: &test
### Migrations ### Migrations
Any migrations that affect `Ci::BaseModel` models Any migrations that affect `Ci::CiDatabaseRecord` models
and their tables must be placed in two directories for now: and their tables must be placed in two directories for now:
- `db/migrate` - `db/migrate`
......
...@@ -7,7 +7,9 @@ ...@@ -7,7 +7,9 @@
# purchase via CustomersDot/Zuora # purchase via CustomersDot/Zuora
module Ci module Ci
module Minutes module Minutes
class AdditionalPack < ApplicationRecord class AdditionalPack < Ci::ApplicationRecord
include Ci::NamespacedModelName
self.table_name = 'ci_minutes_additional_packs' self.table_name = 'ci_minutes_additional_packs'
belongs_to :namespace belongs_to :namespace
......
...@@ -4,8 +4,8 @@ module Ci ...@@ -4,8 +4,8 @@ module Ci
module Minutes module Minutes
# Track usage of Shared Runners minutes at root namespace level. # Track usage of Shared Runners minutes at root namespace level.
# This class ensures that we keep 1 record per namespace per month. # This class ensures that we keep 1 record per namespace per month.
class NamespaceMonthlyUsage < ApplicationRecord class NamespaceMonthlyUsage < Ci::ApplicationRecord
self.table_name = "ci_namespace_monthly_usages" include Ci::NamespacedModelName
belongs_to :namespace belongs_to :namespace
......
...@@ -4,8 +4,8 @@ module Ci ...@@ -4,8 +4,8 @@ module Ci
module Minutes module Minutes
# Track usage of Shared Runners minutes at root project level. # Track usage of Shared Runners minutes at root project level.
# This class ensures that we keep 1 record per project per month. # This class ensures that we keep 1 record per project per month.
class ProjectMonthlyUsage < ApplicationRecord class ProjectMonthlyUsage < Ci::ApplicationRecord
self.table_name = "ci_project_monthly_usages" include Ci::NamespacedModelName
belongs_to :project belongs_to :project
......
...@@ -2,7 +2,9 @@ ...@@ -2,7 +2,9 @@
module Ci module Ci
module Sources module Sources
class Project < ApplicationRecord class Project < Ci::ApplicationRecord
include Ci::NamespacedModelName
self.table_name = "ci_sources_projects" self.table_name = "ci_sources_projects"
belongs_to :pipeline, class_name: "Ci::Pipeline", optional: false belongs_to :pipeline, class_name: "Ci::Pipeline", optional: false
......
...@@ -2,7 +2,8 @@ ...@@ -2,7 +2,8 @@
module Ci module Ci
module Subscriptions module Subscriptions
class Project < ApplicationRecord class Project < Ci::ApplicationRecord
include Ci::NamespacedModelName
include ::Limitable include ::Limitable
self.table_name = 'ci_subscriptions_projects' self.table_name = 'ci_subscriptions_projects'
......
...@@ -13,7 +13,7 @@ RSpec.describe Gitlab::Database::SchemaMigrations::Context do ...@@ -13,7 +13,7 @@ RSpec.describe Gitlab::Database::SchemaMigrations::Context do
end end
context 'multiple databases' do context 'multiple databases' do
let(:connection) { Ci::BaseModel.connection } let(:connection) { Ci::CiDatabaseRecord.connection }
it 'returns a directory path that is database specific' do it 'returns a directory path that is database specific' do
skip_if_multiple_databases_not_setup skip_if_multiple_databases_not_setup
......
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