28 lines
1.1 KiB
Ruby
28 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class TruncateSbomOccurrences < Gitlab::Database::Migration[2.1]
|
|
def up
|
|
# Because existing data in the table violates the new
|
|
# uniqueness constraints, we need to remove the non-distinct rows.
|
|
# Rather than do an expensive and error-prone batch migration
|
|
# to find and remove the duplicates, we'll just remove all records
|
|
# from the table.
|
|
#
|
|
# The `cyclonedx_sbom_ingestion` feature flag should
|
|
# be OFF in all environments to avoid having more duplicate records
|
|
# added between this migration and the one where the new unqiue index
|
|
# is added.
|
|
|
|
# TRUNCATE is a DDL statement (it drops the table and re-creates it), so we want to run the
|
|
# migration in DDL mode, but we also don't want to execute it against all schemas because
|
|
# it's considered a write operation. So, we'll manually check and skip the migration if
|
|
# it's on not `:gitlab_main`.
|
|
return unless Gitlab::Database.gitlab_schemas_for_connection(connection).include?(:gitlab_main)
|
|
|
|
execute('TRUNCATE sbom_occurrences')
|
|
end
|
|
|
|
def down
|
|
# no-op
|
|
end
|
|
end
|