2019-09-30 21:07:59 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe DeploymentMetrics do
|
|
|
|
describe '#has_metrics?' do
|
|
|
|
subject { described_class.new(deployment.project, deployment).has_metrics? }
|
|
|
|
|
|
|
|
context 'when deployment is failed' do
|
|
|
|
let(:deployment) { create(:deployment, :failed) }
|
|
|
|
|
|
|
|
it { is_expected.to be_falsy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when deployment is success' do
|
|
|
|
let(:deployment) { create(:deployment, :success) }
|
|
|
|
|
|
|
|
context 'without a monitoring service' do
|
|
|
|
it { is_expected.to be_falsy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a Prometheus Service' do
|
2020-03-09 13:42:32 +05:30
|
|
|
let(:prometheus_service) { instance_double(PrometheusService, can_query?: true, configured?: true) }
|
2019-09-30 21:07:59 +05:30
|
|
|
|
|
|
|
before do
|
|
|
|
allow(deployment.project).to receive(:find_or_initialize_service).with('prometheus').and_return prometheus_service
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a Prometheus Service that cannot query' do
|
2020-03-09 13:42:32 +05:30
|
|
|
let(:prometheus_service) { instance_double(PrometheusService, configured?: true, can_query?: false) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(deployment.project).to receive(:find_or_initialize_service).with('prometheus').and_return prometheus_service
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_falsy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a Prometheus Service that is not configured' do
|
|
|
|
let(:prometheus_service) { instance_double(PrometheusService, configured?: false, can_query?: false) }
|
2019-09-30 21:07:59 +05:30
|
|
|
|
|
|
|
before do
|
|
|
|
allow(deployment.project).to receive(:find_or_initialize_service).with('prometheus').and_return prometheus_service
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_falsy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a cluster Prometheus' do
|
|
|
|
let(:deployment) { create(:deployment, :success, :on_cluster) }
|
|
|
|
let!(:prometheus) { create(:clusters_applications_prometheus, :installed, cluster: deployment.cluster) }
|
|
|
|
|
|
|
|
before do
|
2020-03-09 13:42:32 +05:30
|
|
|
expect(deployment.cluster.application_prometheus).to receive(:configured?).and_return(true)
|
2019-09-30 21:07:59 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#metrics' do
|
|
|
|
let(:deployment) { create(:deployment, :success) }
|
2020-03-09 13:42:32 +05:30
|
|
|
let(:prometheus_adapter) { instance_double(PrometheusService, can_query?: true, configured?: true) }
|
2019-09-30 21:07:59 +05:30
|
|
|
let(:deployment_metrics) { described_class.new(deployment.project, deployment) }
|
|
|
|
|
|
|
|
subject { deployment_metrics.metrics }
|
|
|
|
|
|
|
|
context 'metrics are disabled' do
|
|
|
|
it { is_expected.to eq({}) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'metrics are enabled' do
|
|
|
|
let(:simple_metrics) do
|
|
|
|
{
|
|
|
|
success: true,
|
|
|
|
metrics: {},
|
|
|
|
last_update: 42
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(deployment_metrics).to receive(:prometheus_adapter).and_return(prometheus_adapter)
|
|
|
|
expect(prometheus_adapter).to receive(:query).with(:deployment, deployment).and_return(simple_metrics)
|
|
|
|
end
|
|
|
|
|
2020-03-09 13:42:32 +05:30
|
|
|
it { is_expected.to eq(simple_metrics.merge({ deployment_time: deployment.finished_at.to_i })) }
|
2019-09-30 21:07:59 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#additional_metrics' do
|
|
|
|
let(:project) { create(:project, :repository) }
|
|
|
|
let(:deployment) { create(:deployment, :succeed, project: project) }
|
|
|
|
let(:deployment_metrics) { described_class.new(deployment.project, deployment) }
|
|
|
|
|
|
|
|
subject { deployment_metrics.additional_metrics }
|
|
|
|
|
|
|
|
context 'metrics are disabled' do
|
|
|
|
it { is_expected.to eq({}) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'metrics are enabled' do
|
|
|
|
let(:simple_metrics) do
|
|
|
|
{
|
|
|
|
success: true,
|
|
|
|
metrics: {},
|
|
|
|
last_update: 42
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2020-03-09 13:42:32 +05:30
|
|
|
let(:prometheus_adapter) { instance_double('prometheus_adapter', can_query?: true, configured?: true) }
|
2019-09-30 21:07:59 +05:30
|
|
|
|
|
|
|
before do
|
|
|
|
allow(deployment_metrics).to receive(:prometheus_adapter).and_return(prometheus_adapter)
|
|
|
|
expect(prometheus_adapter).to receive(:query).with(:additional_metrics_deployment, deployment).and_return(simple_metrics)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq(simple_metrics.merge({ deployment_time: deployment.created_at.to_i })) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|