Commit 925f3613 authored by Douglas Barbosa Alexandre's avatar Douglas Barbosa Alexandre

Merge branch 'mwaw/inject_environments_helper_data_into_metrics_dashboard_response' into 'master'

Resolve "Embed: Add link to embedded panels to go to logs page"

Closes #201846

See merge request gitlab-org/gitlab!25111
parents 8e2790e8 83905f6a
...@@ -5,6 +5,7 @@ ...@@ -5,6 +5,7 @@
module MetricsDashboard module MetricsDashboard
include RenderServiceResults include RenderServiceResults
include ChecksCollaboration include ChecksCollaboration
include EnvironmentsHelper
extend ActiveSupport::Concern extend ActiveSupport::Concern
...@@ -15,8 +16,9 @@ module MetricsDashboard ...@@ -15,8 +16,9 @@ module MetricsDashboard
metrics_dashboard_params.to_h.symbolize_keys metrics_dashboard_params.to_h.symbolize_keys
) )
if include_all_dashboards? && result if result
result[:all_dashboards] = all_dashboards result[:all_dashboards] = all_dashboards if include_all_dashboards?
result[:metrics_data] = metrics_data(project_for_dashboard, environment_for_dashboard) if project_for_dashboard && environment_for_dashboard
end end
respond_to do |format| respond_to do |format|
...@@ -76,10 +78,14 @@ module MetricsDashboard ...@@ -76,10 +78,14 @@ module MetricsDashboard
defined?(project) ? project : nil defined?(project) ? project : nil
end end
def environment_for_dashboard
defined?(environment) ? environment : nil
end
def dashboard_success_response(result) def dashboard_success_response(result)
{ {
status: :ok, status: :ok,
json: result.slice(:all_dashboards, :dashboard, :status) json: result.slice(:all_dashboards, :dashboard, :status, :metrics_data)
} }
end end
......
# frozen_string_literal: true # frozen_string_literal: true
module EnvironmentsHelper module EnvironmentsHelper
include ActionView::Helpers::AssetUrlHelper
prepend_if_ee('::EE::EnvironmentsHelper') # rubocop: disable Cop/InjectEnterpriseEditionModule prepend_if_ee('::EE::EnvironmentsHelper') # rubocop: disable Cop/InjectEnterpriseEditionModule
def environments_list_data def environments_list_data
...@@ -21,7 +22,7 @@ module EnvironmentsHelper ...@@ -21,7 +22,7 @@ module EnvironmentsHelper
{ {
"settings-path" => edit_project_service_path(project, 'prometheus'), "settings-path" => edit_project_service_path(project, 'prometheus'),
"clusters-path" => project_clusters_path(project), "clusters-path" => project_clusters_path(project),
"current-environment-name": environment.name, "current-environment-name" => environment.name,
"documentation-path" => help_page_path('administration/monitoring/prometheus/index.md'), "documentation-path" => help_page_path('administration/monitoring/prometheus/index.md'),
"empty-getting-started-svg-path" => image_path('illustrations/monitoring/getting_started.svg'), "empty-getting-started-svg-path" => image_path('illustrations/monitoring/getting_started.svg'),
"empty-loading-svg-path" => image_path('illustrations/monitoring/loading.svg'), "empty-loading-svg-path" => image_path('illustrations/monitoring/loading.svg'),
......
...@@ -45,6 +45,7 @@ describe MetricsDashboard do ...@@ -45,6 +45,7 @@ describe MetricsDashboard do
it 'returns the specified dashboard' do it 'returns the specified dashboard' do
expect(json_response['dashboard']['dashboard']).to eq('Environment metrics') expect(json_response['dashboard']['dashboard']).to eq('Environment metrics')
expect(json_response).not_to have_key('all_dashboards') expect(json_response).not_to have_key('all_dashboards')
expect(json_response).not_to have_key('metrics_data')
end end
context 'when the params are in an alternate format' do context 'when the params are in an alternate format' do
...@@ -53,6 +54,25 @@ describe MetricsDashboard do ...@@ -53,6 +54,25 @@ describe MetricsDashboard do
it 'returns the specified dashboard' do it 'returns the specified dashboard' do
expect(json_response['dashboard']['dashboard']).to eq('Environment metrics') expect(json_response['dashboard']['dashboard']).to eq('Environment metrics')
expect(json_response).not_to have_key('all_dashboards') expect(json_response).not_to have_key('all_dashboards')
expect(json_response).not_to have_key('metrics_data')
end
end
context 'when environment for dashboard is available' do
let(:params) { { environment: environment } }
before do
allow(controller).to receive(:project).and_return(project)
allow(controller).to receive(:environment).and_return(environment)
allow(controller)
.to receive(:metrics_dashboard_params)
.and_return(params)
end
it 'returns the specified dashboard' do
expect(json_response['dashboard']['dashboard']).to eq('Environment metrics')
expect(json_response).not_to have_key('all_dashboards')
expect(json_response).to have_key('metrics_data')
end end
end end
......
...@@ -489,7 +489,7 @@ describe Projects::EnvironmentsController do ...@@ -489,7 +489,7 @@ describe Projects::EnvironmentsController do
end end
shared_examples_for '200 response' do shared_examples_for '200 response' do
let(:expected_keys) { %w(dashboard status) } let(:expected_keys) { %w(dashboard status metrics_data) }
it_behaves_like 'correctly formatted response', :ok it_behaves_like 'correctly formatted response', :ok
end end
......
...@@ -20,7 +20,7 @@ describe EnvironmentsHelper do ...@@ -20,7 +20,7 @@ describe EnvironmentsHelper do
expect(metrics_data).to include( expect(metrics_data).to include(
'settings-path' => edit_project_service_path(project, 'prometheus'), 'settings-path' => edit_project_service_path(project, 'prometheus'),
'clusters-path' => project_clusters_path(project), 'clusters-path' => project_clusters_path(project),
'current-environment-name': environment.name, 'current-environment-name' => environment.name,
'documentation-path' => help_page_path('administration/monitoring/prometheus/index.md'), 'documentation-path' => help_page_path('administration/monitoring/prometheus/index.md'),
'empty-getting-started-svg-path' => match_asset_path('/assets/illustrations/monitoring/getting_started.svg'), 'empty-getting-started-svg-path' => match_asset_path('/assets/illustrations/monitoring/getting_started.svg'),
'empty-loading-svg-path' => match_asset_path('/assets/illustrations/monitoring/loading.svg'), 'empty-loading-svg-path' => match_asset_path('/assets/illustrations/monitoring/loading.svg'),
......
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