2016-06-02 11:05:42 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2016-09-29 09:46:39 +05:30
|
|
|
describe HasStatus do
|
2016-06-02 11:05:42 +05:30
|
|
|
before do
|
|
|
|
@object = Object.new
|
2016-09-29 09:46:39 +05:30
|
|
|
@object.extend(HasStatus::ClassMethods)
|
2016-06-02 11:05:42 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
describe '.status' do
|
|
|
|
before do
|
|
|
|
allow(@object).to receive(:all).and_return(CommitStatus.where(id: statuses))
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { @object.status }
|
2016-09-29 09:46:39 +05:30
|
|
|
|
2016-06-02 11:05:42 +05:30
|
|
|
shared_examples 'build status summary' do
|
|
|
|
context 'all successful' do
|
|
|
|
let(:statuses) { Array.new(2) { create(type, status: :success) } }
|
|
|
|
it { is_expected.to eq 'success' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'at least one failed' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :success), create(type, status: :failed)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'failed' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'at least one running' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :success), create(type, status: :running)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'running' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'at least one pending' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :success), create(type, status: :pending)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'running' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'success and failed but allowed to fail' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :success),
|
|
|
|
create(type, status: :failed, allow_failure: true)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'success' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'one failed but allowed to fail' do
|
|
|
|
let(:statuses) { [create(type, status: :failed, allow_failure: true)] }
|
|
|
|
it { is_expected.to eq 'success' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'success and canceled' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :success), create(type, status: :canceled)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'canceled' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'one failed and one canceled' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :failed), create(type, status: :canceled)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'failed' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'one failed but allowed to fail and one canceled' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :failed, allow_failure: true),
|
|
|
|
create(type, status: :canceled)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'canceled' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'one running one canceled' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :running), create(type, status: :canceled)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'running' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'all canceled' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :canceled), create(type, status: :canceled)]
|
|
|
|
end
|
|
|
|
it { is_expected.to eq 'canceled' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'success and canceled but allowed to fail' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :success),
|
|
|
|
create(type, status: :canceled, allow_failure: true)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'success' }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'one finished and second running but allowed to fail' do
|
|
|
|
let(:statuses) do
|
|
|
|
[create(type, status: :success),
|
|
|
|
create(type, status: :running, allow_failure: true)]
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq 'running' }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'ci build statuses' do
|
|
|
|
let(:type) { :ci_build }
|
|
|
|
it_behaves_like 'build status summary'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'generic commit statuses' do
|
|
|
|
let(:type) { :generic_commit_status }
|
|
|
|
it_behaves_like 'build status summary'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|