summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMałgorzata Ksionek <meksionek@gmail.com>2019-05-23 13:23:38 +0200
committerMałgorzata Ksionek <meksionek@gmail.com>2019-05-23 13:23:38 +0200
commitee92acccb47c073992f46f9b8f9132a8ef9a92a6 (patch)
tree691dd4c08919dc16c984fb4155c17a9c49d6c1d0
parentddb2949b1c1b0797bb982749b8af22faf9a0a421 (diff)
downloadgitlab-ce-ee92acccb47c073992f46f9b8f9132a8ef9a92a6.tar.gz
Add specs for median serializing
-rw-r--r--app/serializers/analytics_stage_entity.rb1
-rw-r--r--spec/serializers/analytics_stage_serializer_spec.rb30
2 files changed, 31 insertions, 0 deletions
diff --git a/app/serializers/analytics_stage_entity.rb b/app/serializers/analytics_stage_entity.rb
index ab3cf912695..64eba185a4e 100644
--- a/app/serializers/analytics_stage_entity.rb
+++ b/app/serializers/analytics_stage_entity.rb
@@ -10,6 +10,7 @@ class AnalyticsStageEntity < Grape::Entity
expose :median, as: :value do |stage|
# median returns a BatchLoader instance which we first have to unwrap by using to_f
+ # we use to_f to make sure results below 1 are presented to the end-user
!stage.median.to_f.zero? ? distance_of_time_in_words(stage.median) : nil
end
end
diff --git a/spec/serializers/analytics_stage_serializer_spec.rb b/spec/serializers/analytics_stage_serializer_spec.rb
index dbfb3eace83..907d1b35e74 100644
--- a/spec/serializers/analytics_stage_serializer_spec.rb
+++ b/spec/serializers/analytics_stage_serializer_spec.rb
@@ -21,4 +21,34 @@ describe AnalyticsStageSerializer do
it 'contains important elements of AnalyticsStage' do
expect(subject).to include(:title, :description, :value)
end
+
+ context 'when median is equal 0' do
+ before do
+ allow_any_instance_of(Gitlab::CycleAnalytics::BaseStage).to receive(:median).and_return(0)
+ end
+
+ it 'value is nil' do
+ expect(subject.fetch(:value)).to be_nil
+ end
+ end
+
+ context 'when median is below 1' do
+ before do
+ allow_any_instance_of(Gitlab::CycleAnalytics::BaseStage).to receive(:median).and_return(0.12)
+ end
+
+ it 'value is equal to median' do
+ expect(subject.fetch(:value)).to eq('less than a minute')
+ end
+ end
+
+ context 'when median is above 1' do
+ before do
+ allow_any_instance_of(Gitlab::CycleAnalytics::BaseStage).to receive(:median).and_return(1.12)
+ end
+
+ it 'value is equal to median' do
+ expect(subject.fetch(:value)).to eq('less than a minute')
+ end
+ end
end