28 lines
920 B
Ruby
28 lines
920 B
Ruby
# frozen_string_literal: true
|
|
|
|
class ScheduleResetDuplicateCiRunnersTokenEncryptedValuesOnProjects < Gitlab::Database::Migration[1.0]
|
|
MIGRATION = 'ResetDuplicateCiRunnersTokenEncryptedValuesOnProjects'
|
|
TOKEN_COLUMN_NAME = :runners_token_encrypted
|
|
TEMP_INDEX_NAME = "tmp_index_projects_on_id_and_#{TOKEN_COLUMN_NAME}"
|
|
BATCH_SIZE = 10_000
|
|
DELAY_INTERVAL = 2.minutes
|
|
|
|
disable_ddl_transaction!
|
|
|
|
def up
|
|
add_concurrent_index :projects, [:id, TOKEN_COLUMN_NAME], where: "#{TOKEN_COLUMN_NAME} IS NOT NULL", unique: false, name: TEMP_INDEX_NAME
|
|
|
|
queue_background_migration_jobs_by_range_at_intervals(
|
|
Gitlab::BackgroundMigration::ResetDuplicateCiRunnersTokenEncryptedValuesOnProjects::Project.base_query,
|
|
MIGRATION,
|
|
DELAY_INTERVAL,
|
|
batch_size: BATCH_SIZE,
|
|
track_jobs: true
|
|
)
|
|
end
|
|
|
|
def down
|
|
remove_concurrent_index_by_name(:projects, name: TEMP_INDEX_NAME)
|
|
end
|
|
end
|