Commit 17414525 authored by Peter Leitzen's avatar Peter Leitzen

Merge branch 'sy-fix-transient-embed' into 'master'

Ensure transient embeds cache correctly

See merge request gitlab-org/gitlab!29734
parents b8250204 53d571fa
...@@ -30,6 +30,11 @@ module Metrics ...@@ -30,6 +30,11 @@ module Metrics
def sequence def sequence
[STAGES::EndpointInserter] [STAGES::EndpointInserter]
end end
override :identifiers
def identifiers
Digest::SHA256.hexdigest(params[:embed_json])
end
end end
end end
end end
...@@ -38,21 +38,7 @@ describe Metrics::Dashboard::TransientEmbedService, :use_clean_rails_memory_stor ...@@ -38,21 +38,7 @@ describe Metrics::Dashboard::TransientEmbedService, :use_clean_rails_memory_stor
end end
describe '#get_dashboard' do describe '#get_dashboard' do
let(:embed_json) do let(:embed_json) { get_embed_json }
{
panel_groups: [{
panels: [{
type: 'line-graph',
title: 'title',
y_label: 'y_label',
metrics: [{
query_range: 'up',
label: 'y_label'
}]
}]
}]
}.to_json
end
let(:service_params) { [project, user, { environment: environment, embedded: 'true', embed_json: embed_json }] } let(:service_params) { [project, user, { environment: environment, embedded: 'true', embed_json: embed_json }] }
let(:service_call) { described_class.new(*service_params).get_dashboard } let(:service_call) { described_class.new(*service_params).get_dashboard }
...@@ -68,5 +54,39 @@ describe Metrics::Dashboard::TransientEmbedService, :use_clean_rails_memory_stor ...@@ -68,5 +54,39 @@ describe Metrics::Dashboard::TransientEmbedService, :use_clean_rails_memory_stor
described_class.new(*service_params).get_dashboard described_class.new(*service_params).get_dashboard
described_class.new(*service_params).get_dashboard described_class.new(*service_params).get_dashboard
end end
it 'caches unique requests separately' do
alt_embed_json = get_embed_json('area-chart')
alt_service_params = [project, user, { environment: environment, embedded: 'true', embed_json: alt_embed_json }]
embed = described_class.new(*service_params).get_dashboard
alt_embed = described_class.new(*alt_service_params).get_dashboard
expect(embed).not_to eq(alt_embed)
expect(get_type_for_embed(embed)).to eq('line-graph')
expect(get_type_for_embed(alt_embed)).to eq('area-chart')
end
private
def get_embed_json(type = 'line-graph')
{
panel_groups: [{
panels: [{
type: type,
title: 'title',
y_label: 'y_label',
metrics: [{
query_range: 'up',
label: 'y_label'
}]
}]
}]
}.to_json
end
def get_type_for_embed(embed)
embed[:dashboard][:panel_groups][0][:panels][0][:type]
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