Commit 9210e9da authored by alinamihaila's avatar alinamihaila

Add custom fallback to GenericMetric

parent c6282573
...@@ -12,19 +12,25 @@ module Gitlab ...@@ -12,19 +12,25 @@ module Gitlab
# Gitlab::CurrentSettings.uuid # Gitlab::CurrentSettings.uuid
# end # end
# end # end
FALLBACK = -1
class << self class << self
attr_reader :metric_operation attr_reader :metric_operation
@metric_operation = :alt @metric_operation = :alt
def fallback(custom_fallback)
@metric_fallback = custom_fallback
end
def value(&block) def value(&block)
@metric_value = block @metric_value = block
end end
attr_reader :metric_value attr_reader :metric_value, :metric_fallback
end end
def value def value
alt_usage_data do alt_usage_data(fallback: fallback) do
self.class.metric_value.call self.class.metric_value.call
end end
end end
...@@ -34,6 +40,10 @@ module Gitlab ...@@ -34,6 +40,10 @@ module Gitlab
self.class.metric_operation self.class.metric_operation
) )
end end
def fallback
self.class.metric_fallback || FALLBACK
end
end end
end end
end end
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::Usage::Metrics::Instrumentations::GenericMetric do
context 'with custom fallback' do
subject do
Class.new(described_class) do
fallback(-2)
value { Gitlab::Database.version }
end.new(time_frame: 'none')
end
describe '#value' do
it 'gives the correct value' do
expect(subject.value).to eq(Gitlab::Database.version )
end
context 'when raising an exception' do
it 'return the custom fallback' do
expect(Gitlab::Database).to receive(:version).and_raise('Error')
expect(subject.value).to eq(-2)
end
end
end
end
context 'with default fallback' do
subject do
Class.new(described_class) do
value { Gitlab::Database.version }
end.new(time_frame: 'none')
end
describe '#value' do
it 'gives the correct value' do
expect(subject.value).to eq(Gitlab::Database.version )
end
context 'when raising an exception' do
it 'return the custom fallback' do
expect(Gitlab::Database).to receive(:version).and_raise('Error')
expect(subject.value).to eq(-1)
end
end
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment