2018-11-21 10:25:55 +00:00
|
|
|
# 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.
|
|
|
|
|
2018-12-12 15:38:40 +00:00
|
|
|
class AddCiBuildsPartialIndexOnProjectIdAndStatus < ActiveRecord::Migration[4.2]
|
2018-11-21 10:25:55 +00:00
|
|
|
include Gitlab::Database::MigrationHelpers
|
|
|
|
|
|
|
|
DOWNTIME = false
|
|
|
|
|
|
|
|
disable_ddl_transaction!
|
|
|
|
|
|
|
|
def up
|
|
|
|
add_concurrent_index(*index_arguments)
|
|
|
|
end
|
|
|
|
|
|
|
|
def down
|
|
|
|
remove_concurrent_index(*index_arguments)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def index_arguments
|
|
|
|
[
|
|
|
|
:ci_builds,
|
|
|
|
[:project_id, :status],
|
|
|
|
{
|
|
|
|
name: 'index_ci_builds_project_id_and_status_for_live_jobs_partial2',
|
|
|
|
where: "(((type)::text = 'Ci::Build'::text) AND ((status)::text = ANY (ARRAY[('running'::character varying)::text, ('pending'::character varying)::text, ('created'::character varying)::text])))"
|
|
|
|
}
|
|
|
|
]
|
|
|
|
end
|
|
|
|
end
|