2020-03-13 15:44:24 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe Gitlab::SidekiqMiddleware::ClientMetrics do
|
2021-04-29 21:17:54 +05:30
|
|
|
shared_examples "a metrics middleware" do
|
|
|
|
context "with mocked prometheus" do
|
|
|
|
let(:enqueued_jobs_metric) { double('enqueued jobs metric', increment: true) }
|
2020-03-13 15:44:24 +05:30
|
|
|
|
2020-06-23 00:09:42 +05:30
|
|
|
before do
|
2021-04-29 21:17:54 +05:30
|
|
|
allow(Gitlab::Metrics).to receive(:counter).with(described_class::ENQUEUED, anything).and_return(enqueued_jobs_metric)
|
2020-04-08 14:13:33 +05:30
|
|
|
end
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
describe '#call' do
|
|
|
|
it 'yields block' do
|
|
|
|
expect { |b| subject.call(worker_class, job, :test, double, &b) }.to yield_control.once
|
2020-03-13 15:44:24 +05:30
|
|
|
end
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
it 'increments enqueued jobs metric with correct labels when worker is a string of the class' do
|
|
|
|
expect(enqueued_jobs_metric).to receive(:increment).with(labels, 1)
|
2020-03-13 15:44:24 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
subject.call(worker_class.to_s, job, :test, double) { nil }
|
2020-03-13 15:44:24 +05:30
|
|
|
end
|
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
it 'increments enqueued jobs metric with correct labels' do
|
|
|
|
expect(enqueued_jobs_metric).to receive(:increment).with(labels, 1)
|
2020-03-13 15:44:24 +05:30
|
|
|
|
2021-04-29 21:17:54 +05:30
|
|
|
subject.call(worker_class, job, :test, double) { nil }
|
2020-03-13 15:44:24 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2021-04-29 21:17:54 +05:30
|
|
|
|
|
|
|
it_behaves_like 'metrics middleware with worker attribution'
|
2020-03-13 15:44:24 +05:30
|
|
|
end
|