diff options
author | Z.J. van de Weg <git@zjvandeweg.nl> | 2017-07-21 14:36:22 +0200 |
---|---|---|
committer | Z.J. van de Weg <git@zjvandeweg.nl> | 2017-07-21 14:43:27 +0200 |
commit | 0d3b8fad9742e6568458f2a8e4d66f0b36d731ec (patch) | |
tree | 20c847a609b0dc8ac41357e7a7683321718e41ef /spec/features | |
parent | 8877f2e8c16ebb0c1251124659117c7d2c209399 (diff) | |
download | gitlab-ce-0d3b8fad9742e6568458f2a8e4d66f0b36d731ec.tar.gz |
Port spinach tests to rspec feature specszj-pipeline-badge-improvements
Logic is the same, just now ported, while this feature was being
improved anyway in this branch.
Resolves #20961
Diffstat (limited to 'spec/features')
-rw-r--r-- | spec/features/projects/badges/pipeline_badge_spec.rb | 66 |
1 files changed, 61 insertions, 5 deletions
diff --git a/spec/features/projects/badges/pipeline_badge_spec.rb b/spec/features/projects/badges/pipeline_badge_spec.rb index 786973d6c2e..b83ea8f4eaa 100644 --- a/spec/features/projects/badges/pipeline_badge_spec.rb +++ b/spec/features/projects/badges/pipeline_badge_spec.rb @@ -1,14 +1,70 @@ require 'spec_helper' -feature 'pipeline badge' do - let(:project) { create(:project, :repository, :public) } +feature 'Pipeline Badge' do + set(:project) { create(:project, :repository, :public) } + let(:ref) { project.default_branch } # this can't be tested in the controller, as it bypasses the rails router # and constructs a route based on the controller being tested # Keep around until 10.0, see gitlab-org/gitlab-ce#35307 - scenario 'user request the deprecated build status badge' do - visit build_project_badges_path(project, ref: project.default_branch, format: :svg) + context 'when the deprecated badge is requested' do + it 'displays the badge' do + visit build_project_badges_path(project, ref: ref, format: :svg) - expect(page.status_code).to eq(200) + expect(page.status_code).to eq(200) + end + end + + context 'when the project has a pipeline' do + let!(:pipeline) { create(:ci_empty_pipeline, project: project, ref: ref, sha: project.commit(ref).sha) } + let!(:job) { create(:ci_build, pipeline: pipeline) } + + context 'when the pipeline was successfull' do + it 'displays so on the badge' do + job.success + + visit pipeline_project_badges_path(project, ref: ref, format: :svg) + + expect(page.status_code).to eq(200) + expect_badge('passed') + end + end + + context 'when the pipeline failed' do + it 'shows displays so on the badge' do + job.drop + + visit pipeline_project_badges_path(project, ref: ref, format: :svg) + + expect(page.status_code).to eq(200) + expect_badge('failed') + end + end + + context 'when the pipeline is running' do + it 'shows displays so on the badge' do + create(:ci_build, pipeline: pipeline, name: 'second build', status_event: 'run') + + visit pipeline_project_badges_path(project, ref: ref, format: :svg) + + expect(page.status_code).to eq(200) + expect_badge('running') + end + end + + context 'when a new pipeline is created' do + it 'shows a fresh badge' do + visit pipeline_project_badges_path(project, ref: ref, format: :svg) + + expect(page.status_code).to eq(200) + expect(page.response_headers['Cache-Control']).to include 'no-cache' + end + end + + def expect_badge(status) + svg = Nokogiri::XML.parse(page.body) + expect(page.response_headers['Content-Type']).to include('image/svg+xml') + expect(svg.at(%Q{text:contains("#{status}")})).to be_truthy + end end end |