Commit 40b6875d authored by Andreas Brandl's avatar Andreas Brandl

Exclude expression indexes from reindexing

This excludes expression (aka "functional") indexes from reindexing due
to https://gitlab.com/gitlab-org/gitlab/-/issues/272997.
parent 26421ba6
...@@ -10,6 +10,7 @@ module Gitlab ...@@ -10,6 +10,7 @@ module Gitlab
def self.candidate_indexes def self.candidate_indexes
Gitlab::Database::PostgresIndex Gitlab::Database::PostgresIndex
.regular .regular
.where('NOT expression')
.not_match("^#{ConcurrentReindex::TEMPORARY_INDEX_PREFIX}") .not_match("^#{ConcurrentReindex::TEMPORARY_INDEX_PREFIX}")
.not_match("^#{ConcurrentReindex::REPLACED_INDEX_PREFIX}") .not_match("^#{ConcurrentReindex::REPLACED_INDEX_PREFIX}")
end end
......
...@@ -24,7 +24,7 @@ RSpec.describe Gitlab::Database::Reindexing do ...@@ -24,7 +24,7 @@ RSpec.describe Gitlab::Database::Reindexing do
it 'retrieves regular indexes that are no left-overs from previous runs' do it 'retrieves regular indexes that are no left-overs from previous runs' do
result = double result = double
expect(Gitlab::Database::PostgresIndex).to receive_message_chain('regular.not_match.not_match').with(no_args).with('^tmp_reindex_').with('^old_reindex_').and_return(result) expect(Gitlab::Database::PostgresIndex).to receive_message_chain('regular.where.not_match.not_match').with(no_args).with('NOT expression').with('^tmp_reindex_').with('^old_reindex_').and_return(result)
expect(subject).to eq(result) expect(subject).to eq(result)
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment