65 lines
1.9 KiB
Ruby
65 lines
1.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe Gitlab::Metrics::SidekiqSlis, feature_category: :error_budgets do
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
describe ".initialize_slis!" do
|
|
let(:possible_labels) do
|
|
[
|
|
{
|
|
worker: "Projects::RecordTargetPlatformsWorker",
|
|
feature_category: "projects",
|
|
urgency: "low"
|
|
}
|
|
]
|
|
end
|
|
|
|
it "initializes the apdex and error rate SLIs" do
|
|
expect(Gitlab::Metrics::Sli::Apdex).to receive(:initialize_sli).with(:sidekiq_execution, possible_labels)
|
|
expect(Gitlab::Metrics::Sli::ErrorRate).to receive(:initialize_sli).with(:sidekiq_execution, possible_labels)
|
|
|
|
described_class.initialize_slis!(possible_labels)
|
|
end
|
|
end
|
|
|
|
describe ".record_execution_apdex" do
|
|
where(:urgency, :duration, :success) do
|
|
"high" | 5 | true
|
|
"high" | 11 | false
|
|
"low" | 295 | true
|
|
"low" | 400 | false
|
|
"throttled" | 295 | true
|
|
"throttled" | 400 | false
|
|
"not_found" | 295 | true
|
|
"not_found" | 400 | false
|
|
end
|
|
|
|
with_them do
|
|
it "increments the apdex SLI with success based on urgency requirement" do
|
|
labels = { urgency: urgency }
|
|
expect(Gitlab::Metrics::Sli::Apdex[:sidekiq_execution]).to receive(:increment).with(
|
|
labels: labels,
|
|
success: success
|
|
)
|
|
|
|
described_class.record_execution_apdex(labels, duration)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe ".record_execution_error" do
|
|
it "increments the error rate SLI with the given labels and error" do
|
|
labels = { urgency: :throttled }
|
|
error = StandardError.new("something went wrong")
|
|
|
|
expect(Gitlab::Metrics::Sli::ErrorRate[:sidekiq_execution]).to receive(:increment).with(
|
|
labels: labels,
|
|
error: error
|
|
)
|
|
|
|
described_class.record_execution_error(labels, error)
|
|
end
|
|
end
|
|
end
|