summaryrefslogtreecommitdiff
path: root/db/migrate/20210503105022_create_project_value_streams.rb
blob: 775ab03ad4bf31b0af02d0b80a2d775efd7e70c3 (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
# frozen_string_literal: true

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

  INDEX_NAME = 'index_analytics_ca_project_value_streams_on_project_id_and_name'

  def up
    create_table_with_constraints :analytics_cycle_analytics_project_value_streams do |t|
      t.timestamps_with_timezone
      t.references(:project,
                   null: false,
                   index: false,
                   foreign_key: { to_table: :projects, on_delete: :cascade }
                  )
      t.text :name, null: false
      t.index [:project_id, :name], unique: true, name: INDEX_NAME
      t.text_limit :name, 100
    end
  end

  def down
    with_lock_retries do
      drop_table :analytics_cycle_analytics_project_value_streams
    end
  end
end