summaryrefslogtreecommitdiff
path: root/db/migrate/20190910212256_add_any_approver_rule_unique_indexes.rb
blob: e8f5b853d1dc794e0e2e1339791bf0e78c0a40de (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

# See http://doc.gitlab.com/ce/development/migration_style_guide.html
# for more information on how to write migrations for GitLab.

class AddAnyApproverRuleUniqueIndexes < ActiveRecord::Migration[5.2]
  include Gitlab::Database::MigrationHelpers

  DOWNTIME = false

  PROJECT_RULE_UNIQUE_INDEX = 'any_approver_project_rule_type_unique_index'
  MERGE_REQUEST_RULE_UNIQUE_INDEX = 'any_approver_merge_request_rule_type_unique_index'

  disable_ddl_transaction!

  def up
    add_concurrent_index(:approval_project_rules, [:project_id],
      where: "rule_type = 3",
      name: PROJECT_RULE_UNIQUE_INDEX, unique: true)

    add_concurrent_index(:approval_merge_request_rules, [:merge_request_id, :rule_type],
      where: "rule_type = 4",
      name: MERGE_REQUEST_RULE_UNIQUE_INDEX, unique: true)
  end

  def down
    remove_concurrent_index_by_name(:approval_project_rules, PROJECT_RULE_UNIQUE_INDEX)
    remove_concurrent_index_by_name(:approval_merge_request_rules, MERGE_REQUEST_RULE_UNIQUE_INDEX)
  end
end