2019-10-12 21:52:04 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
describe 'Metrics rendering', :js, :use_clean_rails_memory_store_caching, :sidekiq_inline do
|
2019-10-12 21:52:04 +05:30
|
|
|
include PrometheusHelpers
|
2019-12-26 22:10:19 +05:30
|
|
|
include GrafanaApiHelpers
|
2020-04-08 14:13:33 +05:30
|
|
|
include MetricsDashboardUrlHelpers
|
|
|
|
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
let_it_be(:project) { create(:prometheus_project) }
|
|
|
|
let_it_be(:environment) { create(:environment, project: project) }
|
2019-10-12 21:52:04 +05:30
|
|
|
|
|
|
|
let(:issue) { create(:issue, project: project, description: description) }
|
|
|
|
let(:description) { "See [metrics dashboard](#{metrics_url}) for info." }
|
2020-04-08 14:13:33 +05:30
|
|
|
let(:metrics_url) { urls.metrics_project_environment_url(project, environment) }
|
2019-10-12 21:52:04 +05:30
|
|
|
|
|
|
|
before do
|
2020-04-08 14:13:33 +05:30
|
|
|
clear_host_from_memoized_variables
|
|
|
|
|
|
|
|
allow(::Gitlab.config.gitlab)
|
|
|
|
.to receive(:url)
|
|
|
|
.and_return(urls.root_url.chomp('/'))
|
|
|
|
|
2019-10-12 21:52:04 +05:30
|
|
|
project.add_developer(user)
|
|
|
|
sign_in(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
2020-04-08 14:13:33 +05:30
|
|
|
clear_host_from_memoized_variables
|
2019-10-12 21:52:04 +05:30
|
|
|
end
|
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
context 'internal metrics embeds' do
|
|
|
|
before do
|
|
|
|
import_common_metrics
|
|
|
|
stub_any_prometheus_request_with_response
|
2020-04-22 19:07:51 +05:30
|
|
|
|
|
|
|
allow(Prometheus::ProxyService).to receive(:new).and_call_original
|
2019-12-26 22:10:19 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows embedded metrics' do
|
|
|
|
visit project_issue_path(project, issue)
|
|
|
|
|
|
|
|
expect(page).to have_css('div.prometheus-graph')
|
|
|
|
expect(page).to have_text('Memory Usage (Total)')
|
|
|
|
expect(page).to have_text('Core Usage (Total)')
|
2020-04-22 19:07:51 +05:30
|
|
|
|
|
|
|
# Ensure that the FE is calling the BE with expected params
|
|
|
|
expect(Prometheus::ProxyService)
|
|
|
|
.to have_received(:new)
|
|
|
|
.with(environment, 'GET', 'query_range', hash_including('start', 'end', 'step'))
|
|
|
|
.at_least(:once)
|
2019-12-26 22:10:19 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context 'when dashboard params are in included the url' do
|
2020-04-08 14:13:33 +05:30
|
|
|
let(:metrics_url) { urls.metrics_project_environment_url(project, environment, **chart_params) }
|
2019-10-12 21:52:04 +05:30
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
let(:chart_params) do
|
|
|
|
{
|
|
|
|
group: 'System metrics (Kubernetes)',
|
|
|
|
title: 'Memory Usage (Pod average)',
|
|
|
|
y_label: 'Memory Used per Pod (MB)'
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows embedded metrics for the specific chart' do
|
|
|
|
visit project_issue_path(project, issue)
|
|
|
|
|
|
|
|
expect(page).to have_css('div.prometheus-graph')
|
|
|
|
expect(page).to have_text(chart_params[:title])
|
|
|
|
expect(page).to have_text(chart_params[:y_label])
|
2020-04-22 19:07:51 +05:30
|
|
|
|
|
|
|
# Ensure that the FE is calling the BE with expected params
|
|
|
|
expect(Prometheus::ProxyService)
|
|
|
|
.to have_received(:new)
|
|
|
|
.with(environment, 'GET', 'query_range', hash_including('start', 'end', 'step'))
|
|
|
|
.at_least(:once)
|
2019-12-26 22:10:19 +05:30
|
|
|
end
|
2020-04-08 14:13:33 +05:30
|
|
|
|
|
|
|
context 'when two dashboard urls are included' do
|
|
|
|
let(:chart_params_2) do
|
|
|
|
{
|
|
|
|
group: 'System metrics (Kubernetes)',
|
|
|
|
title: 'Core Usage (Total)',
|
|
|
|
y_label: 'Total Cores'
|
|
|
|
}
|
|
|
|
end
|
|
|
|
let(:metrics_url_2) { urls.metrics_project_environment_url(project, environment, **chart_params_2) }
|
|
|
|
let(:description) { "See [metrics dashboard](#{metrics_url}) for info. \n See [metrics dashboard](#{metrics_url_2}) for info." }
|
|
|
|
let(:issue) { create(:issue, project: project, description: description) }
|
|
|
|
|
|
|
|
it 'shows embedded metrics for both urls' do
|
|
|
|
visit project_issue_path(project, issue)
|
|
|
|
|
|
|
|
expect(page).to have_css('div.prometheus-graph')
|
|
|
|
expect(page).to have_text(chart_params[:title])
|
|
|
|
expect(page).to have_text(chart_params[:y_label])
|
|
|
|
expect(page).to have_text(chart_params_2[:title])
|
|
|
|
expect(page).to have_text(chart_params_2[:y_label])
|
2020-04-22 19:07:51 +05:30
|
|
|
|
|
|
|
# Ensure that the FE is calling the BE with expected params
|
|
|
|
expect(Prometheus::ProxyService)
|
|
|
|
.to have_received(:new)
|
|
|
|
.with(environment, 'GET', 'query_range', hash_including('start', 'end', 'step'))
|
|
|
|
.at_least(:once)
|
2020-04-08 14:13:33 +05:30
|
|
|
end
|
|
|
|
end
|
2019-12-26 22:10:19 +05:30
|
|
|
end
|
2019-10-12 21:52:04 +05:30
|
|
|
end
|
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
context 'grafana metrics embeds' do
|
|
|
|
let(:grafana_integration) { create(:grafana_integration, project: project) }
|
|
|
|
let(:grafana_base_url) { grafana_integration.grafana_url }
|
|
|
|
let(:metrics_url) { valid_grafana_dashboard_link(grafana_base_url) }
|
2019-10-12 21:52:04 +05:30
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
before do
|
|
|
|
stub_dashboard_request(grafana_base_url)
|
|
|
|
stub_datasource_request(grafana_base_url)
|
|
|
|
stub_all_grafana_proxy_requests(grafana_base_url)
|
2020-04-22 19:07:51 +05:30
|
|
|
|
|
|
|
allow(Grafana::ProxyService).to receive(:new).and_call_original
|
2019-10-12 21:52:04 +05:30
|
|
|
end
|
|
|
|
|
2019-12-26 22:10:19 +05:30
|
|
|
it 'shows embedded metrics' do
|
2019-10-12 21:52:04 +05:30
|
|
|
visit project_issue_path(project, issue)
|
|
|
|
|
|
|
|
expect(page).to have_css('div.prometheus-graph')
|
2019-12-26 22:10:19 +05:30
|
|
|
expect(page).to have_text('Expired / Evicted')
|
|
|
|
expect(page).to have_text('expired - test-attribute-value')
|
2020-04-22 19:07:51 +05:30
|
|
|
|
|
|
|
# Ensure that the FE is calling the BE with expected params
|
|
|
|
expect(Grafana::ProxyService)
|
|
|
|
.to have_received(:new)
|
|
|
|
.with(project, anything, anything, hash_including('query', 'start', 'end', 'step'))
|
|
|
|
.at_least(:once)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'transient metrics embeds' do
|
2020-05-24 23:13:21 +05:30
|
|
|
let(:metrics_url) { urls.metrics_dashboard_project_environment_url(project, environment, embed_json: embed_json) }
|
2020-04-22 19:07:51 +05:30
|
|
|
let(:title) { 'Important Metrics' }
|
|
|
|
let(:embed_json) do
|
|
|
|
{
|
|
|
|
panel_groups: [{
|
|
|
|
panels: [{
|
|
|
|
type: "line-graph",
|
|
|
|
title: title,
|
|
|
|
y_label: "metric",
|
|
|
|
metrics: [{
|
|
|
|
query_range: "metric * 0.5 < 1"
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}]
|
|
|
|
}.to_json
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
stub_any_prometheus_request_with_response
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows embedded metrics' do
|
|
|
|
visit project_issue_path(project, issue)
|
|
|
|
|
|
|
|
expect(page).to have_css('div.prometheus-graph')
|
|
|
|
expect(page).to have_text(title)
|
2019-10-12 21:52:04 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def import_common_metrics
|
|
|
|
::Gitlab::DatabaseImporters::CommonMetrics::Importer.new.execute
|
|
|
|
end
|
|
|
|
end
|