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

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-04-03 06:07:58 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-04-03 06:07:58 +0300
commit1eeef229aae5affdce415c2364858e8efc64f4b5 (patch)
tree7bbd126a3b41c4c8855a8e84ece3972030177acb /lib/gitlab/import
parent5d32a7a175fd1a7a6c97019a022c11434ea637dc (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'lib/gitlab/import')
-rw-r--r--lib/gitlab/import/metrics.rb60
1 files changed, 60 insertions, 0 deletions
diff --git a/lib/gitlab/import/metrics.rb b/lib/gitlab/import/metrics.rb
new file mode 100644
index 00000000000..76638a8cf86
--- /dev/null
+++ b/lib/gitlab/import/metrics.rb
@@ -0,0 +1,60 @@
+# frozen_string_literal: true
+
+# Prepend `Gitlab::Import::Metrics` to a class in order
+# to measure and emit `Gitlab::Metrics` metrics of specified methods.
+#
+# @example
+# class Importer
+# prepend Gitlab::Import::Metrics
+#
+# Gitlab::ImportExport::Metrics.measure :execute, metrics: {
+# importer_counter: {
+# type: :counter,
+# description: 'counter'
+# },
+# importer_histogram: {
+# type: :histogram,
+# labels: { importer: 'importer' },
+# description: 'histogram'
+# }
+# }
+#
+# def execute
+# ...
+# end
+# end
+#
+# Each call to `#execute` increments `importer_counter` as well as
+# measures `#execute` duration and reports histogram `importer_histogram`
+module Gitlab
+ module Import
+ module Metrics
+ def self.measure(method_name, metrics:)
+ define_method "#{method_name}" do |*args|
+ start_time = Time.zone.now
+
+ result = super(*args)
+
+ end_time = Time.zone.now
+
+ report_measurement_metrics(metrics, end_time - start_time)
+
+ result
+ end
+ end
+
+ def report_measurement_metrics(metrics, duration)
+ metrics.each do |metric_name, metric_value|
+ case metric_value[:type]
+ when :counter
+ Gitlab::Metrics.counter(metric_name, metric_value[:description]).increment
+ when :histogram
+ Gitlab::Metrics.histogram(metric_name, metric_value[:description]).observe(metric_value[:labels], duration)
+ else
+ nil
+ end
+ end
+ end
+ end
+ end
+end