Welcome to mirror list, hosted at ThFree Co, Russian Federation.

modification_tracker.rb « loose_foreign_keys « models « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 6eb04608cd94eb3ab877ee208962f4b8ebf44792 (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
43
44
45
46
47
48
49
50
51
# frozen_string_literal: true

module LooseForeignKeys
  class ModificationTracker
    MAX_DELETES = 100_000
    MAX_UPDATES = 50_000
    MAX_RUNTIME = 3.minutes

    delegate :monotonic_time, to: :'Gitlab::Metrics::System'

    def initialize
      @delete_count_by_table = Hash.new { |h, k| h[k] = 0 }
      @update_count_by_table = Hash.new { |h, k| h[k] = 0 }
      @start_time = monotonic_time
      @deletes_counter = Gitlab::Metrics.counter(
        :loose_foreign_key_deletions,
        'The number of loose foreign key deletions'
      )
      @updates_counter = Gitlab::Metrics.counter(
        :loose_foreign_key_updates,
        'The number of loose foreign key updates'
      )
    end

    def add_deletions(table, count)
      @delete_count_by_table[table] += count
      @deletes_counter.increment({ table: table }, count)
    end

    def add_updates(table, count)
      @update_count_by_table[table] += count
      @updates_counter.increment({ table: table }, count)
    end

    def over_limit?
      @delete_count_by_table.values.sum >= MAX_DELETES ||
        @update_count_by_table.values.sum >= MAX_UPDATES ||
        monotonic_time - @start_time >= MAX_RUNTIME
    end

    def stats
      {
        over_limit: over_limit?,
        delete_count_by_table: @delete_count_by_table,
        update_count_by_table: @update_count_by_table,
        delete_count: @delete_count_by_table.values.sum,
        update_count: @update_count_by_table.values.sum
      }
    end
  end
end