debian-mirror-gitlab/spec/lib/gitlab/metrics/background_transaction_spec.rb

57 lines
1.9 KiB
Ruby
Raw Normal View History

2019-12-04 20:38:33 +05:30
# frozen_string_literal: true
2018-03-17 18:26:18 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Gitlab::Metrics::BackgroundTransaction do
2018-03-17 18:26:18 +05:30
let(:test_worker_class) { double(:class, name: 'TestWorker') }
2020-10-24 23:57:45 +05:30
let(:prometheus_metric) { instance_double(Prometheus::Client::Metric, base_labels: {}) }
before do
allow(described_class).to receive(:prometheus_metric).and_return(prometheus_metric)
end
2018-03-17 18:26:18 +05:30
subject { described_class.new(test_worker_class) }
2020-10-24 23:57:45 +05:30
RSpec.shared_examples 'metric with worker labels' do |metric_method|
it 'measures with correct labels and value' do
value = 1
expect(prometheus_metric).to receive(metric_method).with({ controller: 'TestWorker', action: 'perform', feature_category: '' }, value)
subject.send(metric_method, :bau, value)
end
end
2018-03-17 18:26:18 +05:30
describe '#label' do
it 'returns labels based on class name' do
2020-07-28 23:09:34 +05:30
expect(subject.labels).to eq(controller: 'TestWorker', action: 'perform', feature_category: '')
end
it 'contains only the labels defined for metrics' do
2020-10-24 23:57:45 +05:30
expect(subject.labels.keys).to contain_exactly(*described_class.superclass::BASE_LABEL_KEYS)
2020-07-28 23:09:34 +05:30
end
it 'includes the feature category if there is one' do
expect(test_worker_class).to receive(:get_feature_category).and_return('source_code_management')
expect(subject.labels).to include(feature_category: 'source_code_management')
2018-03-17 18:26:18 +05:30
end
end
2020-10-24 23:57:45 +05:30
describe '#increment' do
let(:prometheus_metric) { instance_double(Prometheus::Client::Counter, :increment, base_labels: {}) }
it_behaves_like 'metric with worker labels', :increment
end
describe '#set' do
let(:prometheus_metric) { instance_double(Prometheus::Client::Gauge, :set, base_labels: {}) }
it_behaves_like 'metric with worker labels', :set
end
describe '#observe' do
let(:prometheus_metric) { instance_double(Prometheus::Client::Histogram, :observe, base_labels: {}) }
it_behaves_like 'metric with worker labels', :observe
end
2018-03-17 18:26:18 +05:30
end