summaryrefslogtreecommitdiff
path: root/db/migrate/20201103184333_create_packages_package_file_build_infos.rb
blob: 9cb6869cae413320b4aba3ace1ebb60f23193e85 (plain)
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
# frozen_string_literal: true

class CreatePackagesPackageFileBuildInfos < ActiveRecord::Migration[6.0]
  include Gitlab::Database::MigrationHelpers

  DOWNTIME = false

  def up
    unless table_exists?(:packages_package_file_build_infos)
      with_lock_retries do
        create_table :packages_package_file_build_infos do |t|
          t.references :package_file, index: true,
                                      null: false,
                                      foreign_key: { to_table: :packages_package_files, on_delete: :cascade },
                                      type: :bigint
          t.references :pipeline, index: true,
                                  null: true,
                                  foreign_key: { to_table: :ci_pipelines, on_delete: :nullify },
                                  type: :bigint
        end
      end
    end
  end

  def down
    with_lock_retries do
      drop_table :packages_package_file_build_infos
    end
  end
end