30 lines
1.3 KiB
Ruby
30 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class RecreateIndexSecurityCiBuildsOnNameAndIdParserFeatures < Gitlab::Database::Migration[1.0]
|
|
TABLE = "ci_builds"
|
|
OLD_INDEX_NAME = "index_security_ci_builds_on_name_and_id_parser_features"
|
|
NEW_INDEX_NAME = "index_security_ci_builds_on_name_and_id_parser_features_broken"
|
|
COLUMNS = %i[name id]
|
|
CONSTRAINTS = "(name::text = ANY (ARRAY['container_scanning'::character varying::text,
|
|
'dast'::character varying::text,
|
|
'dependency_scanning'::character varying::text,
|
|
'license_management'::character varying::text,
|
|
'sast'::character varying::text,
|
|
'secret_detection'::character varying::text,
|
|
'coverage_fuzzing'::character varying::text,
|
|
'license_scanning'::character varying::text])
|
|
) AND type::text = 'Ci::Build'::text"
|
|
|
|
enable_lock_retries!
|
|
|
|
def up
|
|
rename_index(TABLE, OLD_INDEX_NAME, NEW_INDEX_NAME)
|
|
prepare_async_index TABLE, COLUMNS, name: OLD_INDEX_NAME, where: CONSTRAINTS
|
|
end
|
|
|
|
def down
|
|
unprepare_async_index TABLE, COLUMNS, name: OLD_INDEX_NAME
|
|
rename_index(TABLE, NEW_INDEX_NAME, OLD_INDEX_NAME)
|
|
end
|
|
end
|