2015-10-21 09:29:47 +00:00
|
|
|
require "spec_helper"
|
|
|
|
|
|
|
|
describe StuckCiBuildsWorker do
|
|
|
|
let!(:build) { create :ci_build }
|
2016-06-12 13:15:58 +00:00
|
|
|
let(:worker) { described_class.new }
|
2015-10-21 09:29:47 +00:00
|
|
|
|
|
|
|
subject do
|
|
|
|
build.reload
|
|
|
|
build.status
|
|
|
|
end
|
|
|
|
|
|
|
|
%w(pending running).each do |status|
|
|
|
|
context "#{status} build" do
|
|
|
|
before do
|
|
|
|
build.update!(status: status)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'gets dropped if it was updated over 2 days ago' do
|
2015-12-15 02:53:52 +00:00
|
|
|
build.update!(updated_at: 2.days.ago)
|
2016-06-12 13:15:58 +00:00
|
|
|
worker.perform
|
2015-10-21 09:29:47 +00:00
|
|
|
is_expected.to eq('failed')
|
|
|
|
end
|
|
|
|
|
|
|
|
it "is still #{status}" do
|
|
|
|
build.update!(updated_at: 1.minute.ago)
|
2016-06-12 13:15:58 +00:00
|
|
|
worker.perform
|
2015-10-21 09:29:47 +00:00
|
|
|
is_expected.to eq(status)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
%w(success failed canceled).each do |status|
|
|
|
|
context "#{status} build" do
|
|
|
|
before do
|
|
|
|
build.update!(status: status)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "is still #{status}" do
|
2015-12-15 02:53:52 +00:00
|
|
|
build.update!(updated_at: 2.days.ago)
|
2016-06-12 13:15:58 +00:00
|
|
|
worker.perform
|
2015-10-21 09:29:47 +00:00
|
|
|
is_expected.to eq(status)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-06-12 13:15:58 +00:00
|
|
|
|
|
|
|
context "for deleted project" do
|
|
|
|
before do
|
|
|
|
build.update!(status: :running, updated_at: 2.days.ago)
|
|
|
|
build.project.update(pending_delete: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not drop build" do
|
|
|
|
expect_any_instance_of(Ci::Build).not_to receive(:drop)
|
|
|
|
worker.perform
|
|
|
|
end
|
|
|
|
end
|
2015-10-21 09:29:47 +00:00
|
|
|
end
|