Commit 1f99a858 authored by Tiger's avatar Tiger

Remove foreign key from terraform_state_versions to ci_builds

https://gitlab.com/gitlab-org/gitlab/-/merge_requests/70743

Changelog: other
parent 2a2a6855
...@@ -55,6 +55,8 @@ module Ci ...@@ -55,6 +55,8 @@ module Ci
has_one :runner_session, class_name: 'Ci::BuildRunnerSession', validate: true, inverse_of: :build has_one :runner_session, class_name: 'Ci::BuildRunnerSession', validate: true, inverse_of: :build
has_one :trace_metadata, class_name: 'Ci::BuildTraceMetadata', inverse_of: :build has_one :trace_metadata, class_name: 'Ci::BuildTraceMetadata', inverse_of: :build
has_many :terraform_state_versions, class_name: 'Terraform::StateVersion', dependent: :nullify, inverse_of: :build, foreign_key: :ci_build_id # rubocop:disable Cop/ActiveRecordDependent
accepts_nested_attributes_for :runner_session, update_only: true accepts_nested_attributes_for :runner_session, update_only: true
accepts_nested_attributes_for :job_variables accepts_nested_attributes_for :job_variables
......
# frozen_string_literal: true
class RemoveCiBuildsForeignKeyFromTerraformStateVersions < Gitlab::Database::Migration[1.0]
disable_ddl_transaction!
def up
with_lock_retries do
remove_foreign_key_if_exists(:terraform_state_versions, :ci_builds)
end
end
def down
add_concurrent_foreign_key(:terraform_state_versions, :ci_builds, column: :ci_build_id, on_delete: :nullify)
end
end
12dfb473067fc836cd435474405c3ca978d159a13e975f7663fe22c078731fd1
\ No newline at end of file
...@@ -27402,9 +27402,6 @@ ALTER TABLE ONLY service_desk_settings ...@@ -27402,9 +27402,6 @@ ALTER TABLE ONLY service_desk_settings
ALTER TABLE ONLY design_management_designs_versions ALTER TABLE ONLY design_management_designs_versions
ADD CONSTRAINT fk_03c671965c FOREIGN KEY (design_id) REFERENCES design_management_designs(id) ON DELETE CASCADE; ADD CONSTRAINT fk_03c671965c FOREIGN KEY (design_id) REFERENCES design_management_designs(id) ON DELETE CASCADE;
ALTER TABLE ONLY terraform_state_versions
ADD CONSTRAINT fk_04b91e4a9f FOREIGN KEY (ci_build_id) REFERENCES ci_builds(id) ON DELETE SET NULL;
ALTER TABLE ONLY issues ALTER TABLE ONLY issues
ADD CONSTRAINT fk_05f1e72feb FOREIGN KEY (author_id) REFERENCES users(id) ON DELETE SET NULL; ADD CONSTRAINT fk_05f1e72feb FOREIGN KEY (author_id) REFERENCES users(id) ON DELETE SET NULL;
...@@ -82,6 +82,7 @@ RSpec.describe 'Database schema' do ...@@ -82,6 +82,7 @@ RSpec.describe 'Database schema' do
subscriptions: %w[user_id subscribable_id], subscriptions: %w[user_id subscribable_id],
suggestions: %w[commit_id], suggestions: %w[commit_id],
taggings: %w[tag_id taggable_id tagger_id], taggings: %w[tag_id taggable_id tagger_id],
terraform_state_versions: %w[ci_build_id],
timelogs: %w[user_id], timelogs: %w[user_id],
todos: %w[target_id commit_id], todos: %w[target_id commit_id],
uploads: %w[model_id], uploads: %w[model_id],
......
...@@ -29,6 +29,7 @@ RSpec.describe Ci::Build do ...@@ -29,6 +29,7 @@ RSpec.describe Ci::Build do
it { is_expected.to have_one(:deployment) } it { is_expected.to have_one(:deployment) }
it { is_expected.to have_one(:runner_session) } it { is_expected.to have_one(:runner_session) }
it { is_expected.to have_one(:trace_metadata) } it { is_expected.to have_one(:trace_metadata) }
it { is_expected.to have_many(:terraform_state_versions).dependent(:nullify).inverse_of(:build) }
it { is_expected.to validate_presence_of(:ref) } it { is_expected.to validate_presence_of(:ref) }
......
...@@ -48,7 +48,7 @@ RSpec.describe Ci::RetryBuildService do ...@@ -48,7 +48,7 @@ RSpec.describe Ci::RetryBuildService do
job_artifacts_network_referee job_artifacts_dotenv job_artifacts_network_referee job_artifacts_dotenv
job_artifacts_cobertura needs job_artifacts_accessibility job_artifacts_cobertura needs job_artifacts_accessibility
job_artifacts_requirements job_artifacts_coverage_fuzzing job_artifacts_requirements job_artifacts_coverage_fuzzing
job_artifacts_api_fuzzing].freeze job_artifacts_api_fuzzing terraform_state_versions].freeze
ignore_accessors = ignore_accessors =
%i[type lock_version target_url base_tags trace_sections %i[type lock_version target_url base_tags trace_sections
...@@ -88,6 +88,7 @@ RSpec.describe Ci::RetryBuildService do ...@@ -88,6 +88,7 @@ RSpec.describe Ci::RetryBuildService do
create(:ci_job_variable, job: build) create(:ci_job_variable, job: build)
create(:ci_build_need, build: build) create(:ci_build_need, build: build)
create(:terraform_state_version, build: build)
end end
describe 'clone accessors' do describe 'clone accessors' do
......
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