summaryrefslogtreecommitdiff
path: root/db/post_migrate/20220315171129_cleanup_draft_data_from_faulty_regex.rb
blob: be81bf85f6210a694aff76e2dbe3eed1d8454ab4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# frozen_string_literal: true

class CleanupDraftDataFromFaultyRegex < Gitlab::Database::Migration[1.0]
  MIGRATION       = 'CleanupDraftDataFromFaultyRegex'
  DELAY_INTERVAL  = 5.minutes
  BATCH_SIZE      = 20

  disable_ddl_transaction!

  class MergeRequest < ActiveRecord::Base
    LEAKY_REGEXP_STR     = "^\\[draft\\]|\\(draft\\)|draft:|draft|\\[WIP\\]|WIP:|WIP"
    CORRECTED_REGEXP_STR = "^(\\[draft\\]|\\(draft\\)|draft:|draft|\\[WIP\\]|WIP:|WIP)"

    self.table_name = 'merge_requests'

    include ::EachBatch

    def self.eligible
      where(state_id: 1)
        .where(draft: true)
        .where("title ~* ?", LEAKY_REGEXP_STR)
        .where("title !~* ?", CORRECTED_REGEXP_STR)
    end
  end

  def up
    return unless Gitlab.com?

    queue_background_migration_jobs_by_range_at_intervals(
      MergeRequest.eligible,
      MIGRATION,
      DELAY_INTERVAL,
      batch_size: BATCH_SIZE,
      track_jobs: true
    )
  end

  def down
    # noop
    #
  end
end