2015-11-13 13:22:46 -05:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: ci_builds
|
|
|
|
#
|
|
|
|
# id :integer not null, primary key
|
|
|
|
# project_id :integer
|
|
|
|
# status :string(255)
|
|
|
|
# finished_at :datetime
|
|
|
|
# trace :text
|
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
|
|
|
# started_at :datetime
|
|
|
|
# runner_id :integer
|
|
|
|
# coverage :float
|
|
|
|
# commit_id :integer
|
|
|
|
# commands :text
|
|
|
|
# job_id :integer
|
|
|
|
# name :string(255)
|
|
|
|
# deploy :boolean default(FALSE)
|
|
|
|
# options :text
|
|
|
|
# allow_failure :boolean default(FALSE), not null
|
|
|
|
# stage :string(255)
|
|
|
|
# trigger_request_id :integer
|
|
|
|
# stage_idx :integer
|
|
|
|
# tag :boolean
|
|
|
|
# ref :string(255)
|
|
|
|
# user_id :integer
|
|
|
|
# type :string(255)
|
|
|
|
# target_url :string(255)
|
|
|
|
# description :string(255)
|
|
|
|
# artifacts_file :text
|
2016-01-05 21:30:59 -05:00
|
|
|
# gl_project_id :integer
|
2015-11-13 13:22:46 -05:00
|
|
|
#
|
|
|
|
|
2015-10-06 06:01:16 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2015-12-09 04:50:51 -05:00
|
|
|
describe CommitStatus, models: true do
|
2015-10-06 06:01:16 -04:00
|
|
|
let(:commit) { FactoryGirl.create :ci_commit }
|
|
|
|
let(:commit_status) { FactoryGirl.create :commit_status, commit: commit }
|
|
|
|
|
|
|
|
it { is_expected.to belong_to(:commit) }
|
|
|
|
it { is_expected.to belong_to(:user) }
|
2015-12-11 08:37:16 -05:00
|
|
|
it { is_expected.to belong_to(:project) }
|
|
|
|
|
2015-10-06 06:01:16 -04:00
|
|
|
it { is_expected.to validate_presence_of(:name) }
|
|
|
|
it { is_expected.to validate_inclusion_of(:status).in_array(%w(pending running failed success canceled)) }
|
|
|
|
|
|
|
|
it { is_expected.to delegate_method(:sha).to(:commit) }
|
|
|
|
it { is_expected.to delegate_method(:short_sha).to(:commit) }
|
|
|
|
|
|
|
|
it { is_expected.to respond_to :success? }
|
|
|
|
it { is_expected.to respond_to :failed? }
|
|
|
|
it { is_expected.to respond_to :running? }
|
|
|
|
it { is_expected.to respond_to :pending? }
|
|
|
|
|
2015-10-12 06:15:48 -04:00
|
|
|
describe :author do
|
|
|
|
subject { commit_status.author }
|
|
|
|
before { commit_status.author = User.new }
|
|
|
|
|
|
|
|
it { is_expected.to eq(commit_status.user) }
|
|
|
|
end
|
|
|
|
|
2015-10-06 06:01:16 -04:00
|
|
|
describe :started? do
|
|
|
|
subject { commit_status.started? }
|
|
|
|
|
|
|
|
context 'without started_at' do
|
|
|
|
before { commit_status.started_at = nil }
|
|
|
|
|
|
|
|
it { is_expected.to be_falsey }
|
|
|
|
end
|
|
|
|
|
|
|
|
%w(running success failed).each do |status|
|
|
|
|
context "if commit status is #{status}" do
|
|
|
|
before { commit_status.status = status }
|
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
%w(pending canceled).each do |status|
|
|
|
|
context "if commit status is #{status}" do
|
|
|
|
before { commit_status.status = status }
|
|
|
|
|
|
|
|
it { is_expected.to be_falsey }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe :active? do
|
|
|
|
subject { commit_status.active? }
|
|
|
|
|
|
|
|
%w(pending running).each do |state|
|
|
|
|
context "if commit_status.status is #{state}" do
|
|
|
|
before { commit_status.status = state }
|
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
%w(success failed canceled).each do |state|
|
|
|
|
context "if commit_status.status is #{state}" do
|
|
|
|
before { commit_status.status = state }
|
|
|
|
|
|
|
|
it { is_expected.to be_falsey }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe :complete? do
|
|
|
|
subject { commit_status.complete? }
|
|
|
|
|
|
|
|
%w(success failed canceled).each do |state|
|
|
|
|
context "if commit_status.status is #{state}" do
|
|
|
|
before { commit_status.status = state }
|
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
%w(pending running).each do |state|
|
|
|
|
context "if commit_status.status is #{state}" do
|
|
|
|
before { commit_status.status = state }
|
|
|
|
|
|
|
|
it { is_expected.to be_falsey }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe :duration do
|
|
|
|
subject { commit_status.duration }
|
|
|
|
|
|
|
|
it { is_expected.to eq(120.0) }
|
|
|
|
|
|
|
|
context 'if the building process has not started yet' do
|
|
|
|
before do
|
|
|
|
commit_status.started_at = nil
|
|
|
|
commit_status.finished_at = nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_nil }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'if the building process has started' do
|
|
|
|
before do
|
|
|
|
commit_status.started_at = Time.now - 1.minute
|
|
|
|
commit_status.finished_at = nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_a(Float) }
|
|
|
|
it { is_expected.to be > 0.0 }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe :latest do
|
|
|
|
subject { CommitStatus.latest.order(:id) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
@commit1 = FactoryGirl.create :commit_status, commit: commit, name: 'aa', ref: 'bb', status: 'running'
|
|
|
|
@commit2 = FactoryGirl.create :commit_status, commit: commit, name: 'cc', ref: 'cc', status: 'pending'
|
|
|
|
@commit3 = FactoryGirl.create :commit_status, commit: commit, name: 'aa', ref: 'cc', status: 'success'
|
|
|
|
@commit4 = FactoryGirl.create :commit_status, commit: commit, name: 'cc', ref: 'bb', status: 'success'
|
|
|
|
@commit5 = FactoryGirl.create :commit_status, commit: commit, name: 'aa', ref: 'bb', status: 'success'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'return unique statuses' do
|
2016-04-11 10:55:40 -04:00
|
|
|
is_expected.to eq([@commit4, @commit5])
|
2015-10-06 06:01:16 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe :running_or_pending do
|
|
|
|
subject { CommitStatus.running_or_pending.order(:id) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
@commit1 = FactoryGirl.create :commit_status, commit: commit, name: 'aa', ref: 'bb', status: 'running'
|
|
|
|
@commit2 = FactoryGirl.create :commit_status, commit: commit, name: 'cc', ref: 'cc', status: 'pending'
|
|
|
|
@commit3 = FactoryGirl.create :commit_status, commit: commit, name: 'aa', ref: nil, status: 'success'
|
|
|
|
@commit4 = FactoryGirl.create :commit_status, commit: commit, name: 'dd', ref: nil, status: 'failed'
|
|
|
|
@commit5 = FactoryGirl.create :commit_status, commit: commit, name: 'ee', ref: nil, status: 'canceled'
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'return statuses that are running or pending' do
|
|
|
|
is_expected.to eq([@commit1, @commit2])
|
|
|
|
end
|
|
|
|
end
|
2016-04-16 16:43:40 -04:00
|
|
|
|
|
|
|
describe '#before_sha' do
|
|
|
|
subject { commit_status.before_sha }
|
|
|
|
|
|
|
|
context 'when no before_sha is set for ci::commit' do
|
|
|
|
before { commit.before_sha = nil }
|
|
|
|
|
|
|
|
it 'return blank sha' do
|
|
|
|
is_expected.to eq(Gitlab::Git::BLANK_SHA)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'for before_sha set for ci::commit' do
|
|
|
|
let(:value) { '1234' }
|
|
|
|
before { commit.before_sha = value }
|
|
|
|
|
|
|
|
it 'return the set value' do
|
|
|
|
is_expected.to eq(value)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#stages' do
|
|
|
|
before do
|
|
|
|
FactoryGirl.create :commit_status, commit: commit, stage: 'build', stage_idx: 0, status: 'success'
|
|
|
|
FactoryGirl.create :commit_status, commit: commit, stage: 'build', stage_idx: 0, status: 'failed'
|
|
|
|
FactoryGirl.create :commit_status, commit: commit, stage: 'deploy', stage_idx: 2, status: 'running'
|
|
|
|
FactoryGirl.create :commit_status, commit: commit, stage: 'test', stage_idx: 1, status: 'success'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'stages list' do
|
|
|
|
subject { CommitStatus.where(commit: commit).stages }
|
|
|
|
|
|
|
|
it 'return ordered list of stages' do
|
|
|
|
is_expected.to eq(%w(build test deploy))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'stages with statuses' do
|
|
|
|
subject { CommitStatus.where(commit: commit).stages_status }
|
|
|
|
|
|
|
|
it 'return list of stages with statuses' do
|
|
|
|
is_expected.to eq({
|
|
|
|
'build' => 'failed',
|
|
|
|
'test' => 'success',
|
|
|
|
'deploy' => 'running'
|
|
|
|
})
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2015-10-06 06:01:16 -04:00
|
|
|
end
|