Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/lib/gitlab/badge/coverage')
-rw-r--r--spec/lib/gitlab/badge/coverage/metadata_spec.rb32
-rw-r--r--spec/lib/gitlab/badge/coverage/report_spec.rb99
-rw-r--r--spec/lib/gitlab/badge/coverage/template_spec.rb182
3 files changed, 0 insertions, 313 deletions
diff --git a/spec/lib/gitlab/badge/coverage/metadata_spec.rb b/spec/lib/gitlab/badge/coverage/metadata_spec.rb
deleted file mode 100644
index 725ae03ad74..00000000000
--- a/spec/lib/gitlab/badge/coverage/metadata_spec.rb
+++ /dev/null
@@ -1,32 +0,0 @@
-# frozen_string_literal: true
-
-require 'spec_helper'
-require 'lib/gitlab/badge/shared/metadata'
-
-RSpec.describe Gitlab::Badge::Coverage::Metadata do
- let(:badge) do
- double(project: create(:project), ref: 'feature', job: 'test')
- end
-
- let(:metadata) { described_class.new(badge) }
-
- it_behaves_like 'badge metadata'
-
- describe '#title' do
- it 'returns coverage report title' do
- expect(metadata.title).to eq 'coverage report'
- end
- end
-
- describe '#image_url' do
- it 'returns valid url' do
- expect(metadata.image_url).to include 'badges/feature/coverage.svg'
- end
- end
-
- describe '#link_url' do
- it 'returns valid link' do
- expect(metadata.link_url).to include 'commits/feature'
- end
- end
-end
diff --git a/spec/lib/gitlab/badge/coverage/report_spec.rb b/spec/lib/gitlab/badge/coverage/report_spec.rb
deleted file mode 100644
index 3b5ea3291e4..00000000000
--- a/spec/lib/gitlab/badge/coverage/report_spec.rb
+++ /dev/null
@@ -1,99 +0,0 @@
-# frozen_string_literal: true
-
-require 'spec_helper'
-
-RSpec.describe Gitlab::Badge::Coverage::Report do
- let_it_be(:project) { create(:project) }
- let_it_be(:success_pipeline) { create(:ci_pipeline, :success, project: project) }
- let_it_be(:running_pipeline) { create(:ci_pipeline, :running, project: project) }
- let_it_be(:failure_pipeline) { create(:ci_pipeline, :failed, project: project) }
-
- let_it_be(:builds) do
- [
- create(:ci_build, :success, pipeline: success_pipeline, coverage: 40, created_at: 9.seconds.ago, name: 'coverage'),
- create(:ci_build, :success, pipeline: success_pipeline, coverage: 60, created_at: 8.seconds.ago)
- ]
- end
-
- let(:badge) do
- described_class.new(project, 'master', opts: { job: job_name })
- end
-
- let(:job_name) { nil }
-
- describe '#entity' do
- it 'describes a coverage' do
- expect(badge.entity).to eq 'coverage'
- end
- end
-
- describe '#metadata' do
- it 'returns correct metadata' do
- expect(badge.metadata.image_url).to include 'coverage.svg'
- end
- end
-
- describe '#template' do
- it 'returns correct template' do
- expect(badge.template.key_text).to eq 'coverage'
- end
- end
-
- describe '#status' do
- context 'with no job specified' do
- it 'returns the most recent successful pipeline coverage value' do
- expect(badge.status).to eq(50.00)
- end
-
- context 'and no successful pipelines' do
- before do
- allow(badge).to receive(:successful_pipeline).and_return(nil)
- end
-
- it 'returns nil' do
- expect(badge.status).to eq(nil)
- end
- end
- end
-
- context 'with a blank job name' do
- let(:job_name) { ' ' }
-
- it 'returns the latest successful pipeline coverage value' do
- expect(badge.status).to eq(50.00)
- end
- end
-
- context 'with an unmatching job name specified' do
- let(:job_name) { 'incorrect name' }
-
- it 'returns nil' do
- expect(badge.status).to be_nil
- end
- end
-
- context 'with a matching job name specified' do
- let(:job_name) { 'coverage' }
-
- it 'returns the pipeline coverage value' do
- expect(badge.status).to eq(40.00)
- end
-
- context 'with a more recent running pipeline' do
- let!(:another_build) { create(:ci_build, :success, pipeline: running_pipeline, coverage: 20, created_at: 7.seconds.ago, name: 'coverage') }
-
- it 'returns the running pipeline coverage value' do
- expect(badge.status).to eq(20.00)
- end
- end
-
- context 'with a more recent failed pipeline' do
- let!(:another_build) { create(:ci_build, :success, pipeline: failure_pipeline, coverage: 10, created_at: 6.seconds.ago, name: 'coverage') }
-
- it 'returns the failed pipeline coverage value' do
- expect(badge.status).to eq(10.00)
- end
- end
- end
- end
-end
diff --git a/spec/lib/gitlab/badge/coverage/template_spec.rb b/spec/lib/gitlab/badge/coverage/template_spec.rb
deleted file mode 100644
index ba5c1b2ce6e..00000000000
--- a/spec/lib/gitlab/badge/coverage/template_spec.rb
+++ /dev/null
@@ -1,182 +0,0 @@
-# frozen_string_literal: true
-
-require 'spec_helper'
-
-RSpec.describe Gitlab::Badge::Coverage::Template do
- let(:badge) { double(entity: 'coverage', status: 90.00, customization: {}) }
- let(:template) { described_class.new(badge) }
-
- describe '#key_text' do
- it 'says coverage by default' do
- expect(template.key_text).to eq 'coverage'
- end
-
- context 'when custom key_text is defined' do
- before do
- allow(badge).to receive(:customization).and_return({ key_text: "custom text" })
- end
-
- it 'returns custom value' do
- expect(template.key_text).to eq "custom text"
- end
-
- context 'when its size is larger than the max allowed value' do
- before do
- allow(badge).to receive(:customization).and_return({ key_text: 't' * 65 })
- end
-
- it 'returns default value' do
- expect(template.key_text).to eq 'coverage'
- end
- end
- end
- end
-
- describe '#value_text' do
- context 'when coverage is known' do
- it 'returns coverage percentage' do
- expect(template.value_text).to eq '90.00%'
- end
- end
-
- context 'when coverage is known to many digits' do
- before do
- allow(badge).to receive(:status).and_return(92.349)
- end
-
- it 'returns rounded coverage percentage' do
- expect(template.value_text).to eq '92.35%'
- end
- end
-
- context 'when coverage is unknown' do
- before do
- allow(badge).to receive(:status).and_return(nil)
- end
-
- it 'returns string that says coverage is unknown' do
- expect(template.value_text).to eq 'unknown'
- end
- end
- end
-
- describe '#key_width' do
- it 'is fixed by default' do
- expect(template.key_width).to eq 62
- end
-
- context 'when custom key_width is defined' do
- before do
- allow(badge).to receive(:customization).and_return({ key_width: 101 })
- end
-
- it 'returns custom value' do
- expect(template.key_width).to eq 101
- end
-
- context 'when it is larger than the max allowed value' do
- before do
- allow(badge).to receive(:customization).and_return({ key_width: 513 })
- end
-
- it 'returns default value' do
- expect(template.key_width).to eq 62
- end
- end
- end
- end
-
- describe '#value_width' do
- context 'when coverage is known' do
- it 'is narrower when coverage is known' do
- expect(template.value_width).to eq 54
- end
- end
-
- context 'when coverage is unknown' do
- before do
- allow(badge).to receive(:status).and_return(nil)
- end
-
- it 'is wider when coverage is unknown to fit text' do
- expect(template.value_width).to eq 58
- end
- end
- end
-
- describe '#key_color' do
- it 'always has the same color' do
- expect(template.key_color).to eq '#555'
- end
- end
-
- describe '#value_color' do
- context 'when coverage is good' do
- before do
- allow(badge).to receive(:status).and_return(98)
- end
-
- it 'is green' do
- expect(template.value_color).to eq '#4c1'
- end
- end
-
- context 'when coverage is acceptable' do
- before do
- allow(badge).to receive(:status).and_return(90)
- end
-
- it 'is green-orange' do
- expect(template.value_color).to eq '#a3c51c'
- end
- end
-
- context 'when coverage is medium' do
- before do
- allow(badge).to receive(:status).and_return(75)
- end
-
- it 'is orange-yellow' do
- expect(template.value_color).to eq '#dfb317'
- end
- end
-
- context 'when coverage is low' do
- before do
- allow(badge).to receive(:status).and_return(50)
- end
-
- it 'is red' do
- expect(template.value_color).to eq '#e05d44'
- end
- end
-
- context 'when coverage is unknown' do
- before do
- allow(badge).to receive(:status).and_return(nil)
- end
-
- it 'is grey' do
- expect(template.value_color).to eq '#9f9f9f'
- end
- end
- end
-
- describe '#width' do
- context 'when coverage is known' do
- it 'returns the key width plus value width' do
- expect(template.width).to eq 116
- end
- end
-
- context 'when coverage is unknown' do
- before do
- allow(badge).to receive(:status).and_return(nil)
- end
-
- it 'returns key width plus wider value width' do
- expect(template.width).to eq 120
- end
- end
- end
-end