1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
# frozen_string_literal: true
class ReplaceOldFkCiJobArtifactsToBuilds < Gitlab::Database::Migration[2.1]
include Gitlab::Database::MigrationHelpers::WraparoundAutovacuum
disable_ddl_transaction!
def up
return unless should_run?
return if new_foreign_key_exists?
with_lock_retries do
remove_foreign_key_if_exists :ci_job_artifacts, :ci_builds,
name: :fk_rails_c5137cb2c1_p, reverse_lock_order: true
rename_constraint :ci_job_artifacts, :temp_fk_rails_c5137cb2c1_p, :fk_rails_c5137cb2c1_p
end
end
def down
return unless should_run?
return unless new_foreign_key_exists?
add_concurrent_foreign_key :ci_job_artifacts, :ci_builds,
name: :temp_fk_rails_c5137cb2c1_p,
column: [:partition_id, :job_id],
target_column: [:partition_id, :id],
on_update: :cascade,
on_delete: :cascade,
validate: true,
reverse_lock_order: true
switch_constraint_names :ci_job_artifacts, :fk_rails_c5137cb2c1_p, :temp_fk_rails_c5137cb2c1_p
end
private
def should_run?
can_execute_on?(:ci_job_artifacts, :ci_builds)
end
def new_foreign_key_exists?
foreign_key_exists?(:ci_job_artifacts, :p_ci_builds, name: :fk_rails_c5137cb2c1_p)
end
end
|