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:
Diffstat (limited to 'lib/gitlab/usage/metrics/instrumentations/batched_background_migration_failed_jobs_metric.rb')
-rw-r--r--lib/gitlab/usage/metrics/instrumentations/batched_background_migration_failed_jobs_metric.rb34
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/gitlab/usage/metrics/instrumentations/batched_background_migration_failed_jobs_metric.rb b/lib/gitlab/usage/metrics/instrumentations/batched_background_migration_failed_jobs_metric.rb
new file mode 100644
index 00000000000..f5d963cf522
--- /dev/null
+++ b/lib/gitlab/usage/metrics/instrumentations/batched_background_migration_failed_jobs_metric.rb
@@ -0,0 +1,34 @@
+# frozen_string_literal: true
+
+module Gitlab
+ module Usage
+ module Metrics
+ module Instrumentations
+ class BatchedBackgroundMigrationFailedJobsMetric < DatabaseMetric
+ relation do
+ Gitlab::Database::BackgroundMigration::BatchedMigration
+ .joins(:batched_jobs)
+ .where(batched_jobs: { status: '2' })
+ .group(%w[table_name job_class_name])
+ .order(%w[table_name job_class_name])
+ .select(['table_name', 'job_class_name', 'COUNT(batched_jobs) AS number_of_failed_jobs'])
+ end
+
+ timestamp_column(:created_at)
+
+ operation :count
+
+ def value
+ relation.map do |batched_migration|
+ {
+ job_class_name: batched_migration.job_class_name,
+ table_name: batched_migration.table_name,
+ number_of_failed_jobs: batched_migration.number_of_failed_jobs
+ }
+ end
+ end
+ end
+ end
+ end
+ end
+end