Commit d6097ca4 authored by Grzegorz Bizon's avatar Grzegorz Bizon

Extend specs for build badge

parent 4cd1b9f4
......@@ -3,16 +3,18 @@ require 'spec_helper'
describe Gitlab::Badge::Build do
let(:project) { create(:project) }
let(:sha) { project.commit.sha }
let(:ci_commit) { create(:ci_commit, project: project, sha: sha) }
let(:badge) { described_class.new(project, 'master') }
let!(:build) { create(:ci_build, commit: ci_commit) }
describe '#type' do
subject { badge.type }
it { is_expected.to eq 'image/svg+xml' }
end
context 'build exists' do
let(:ci_commit) { create(:ci_commit, project: project, sha: sha) }
let!(:build) { create(:ci_build, commit: ci_commit) }
context 'build success' do
before { build.success! }
......@@ -23,11 +25,48 @@ describe Gitlab::Badge::Build do
describe '#data' do
let(:data) { badge.data }
let(:xml) { Nokogiri::XML.parse(data) }
it 'contains infromation about success' do
expect(xml.at(%Q{text:contains("success")})).to be_truthy
expect(status_node(data, 'success')).to be_truthy
end
end
end
context 'build failed' do
before { build.drop! }
describe '#to_s' do
subject { badge.to_s }
it { is_expected.to eq 'build-failed' }
end
describe '#data' do
let(:data) { badge.data }
it 'contains infromation about failure' do
expect(status_node(data, 'failed')).to be_truthy
end
end
end
end
context 'build does not exist' do
describe '#to_s' do
subject { badge.to_s }
it { is_expected.to eq 'build-unknown' }
end
describe '#data' do
let(:data) { badge.data }
it 'contains infromation about unknown build' do
expect(status_node(data, 'unknown')).to be_truthy
end
end
end
def status_node(data, status)
xml = Nokogiri::XML.parse(data)
xml.at(%Q{text:contains("#{status}")})
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