diff options
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.rb | 34 |
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 |