debian-mirror-gitlab/spec/workers/stuck_ci_jobs_worker_spec.rb

39 lines
1 KiB
Ruby
Raw Normal View History

2019-07-07 11:18:12 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe StuckCiJobsWorker do
2018-11-08 19:23:39 +05:30
include ExclusiveLeaseHelpers
2021-11-18 22:05:49 +05:30
let(:worker) { described_class.new }
let(:lease_uuid) { SecureRandom.uuid }
2017-08-17 22:00:37 +05:30
2021-11-11 11:23:49 +05:30
describe '#perform' do
2021-11-18 22:05:49 +05:30
subject { worker.perform }
2018-03-17 18:26:18 +05:30
2021-11-18 22:05:49 +05:30
it 'enqueues a Ci::StuckBuilds::DropRunningWorker job' do
expect(Ci::StuckBuilds::DropRunningWorker).to receive(:perform_in).with(20.minutes).exactly(:once)
2021-09-04 01:27:46 +05:30
2021-11-18 22:05:49 +05:30
subject
end
2021-09-04 01:27:46 +05:30
2021-11-18 22:05:49 +05:30
it 'enqueues a Ci::StuckBuilds::DropScheduledWorker job' do
expect(Ci::StuckBuilds::DropScheduledWorker).to receive(:perform_in).with(40.minutes).exactly(:once)
2021-09-04 01:27:46 +05:30
2021-11-18 22:05:49 +05:30
subject
end
2018-12-05 23:21:45 +05:30
2021-11-18 22:05:49 +05:30
it 'executes an instance of Ci::StuckBuilds::DropPendingService' do
expect_to_obtain_exclusive_lease(worker.lease_key, lease_uuid)
2018-12-05 23:21:45 +05:30
2021-11-18 22:05:49 +05:30
expect_next_instance_of(Ci::StuckBuilds::DropPendingService) do |service|
expect(service).to receive(:execute).exactly(:once)
2018-12-05 23:21:45 +05:30
end
2021-11-18 22:05:49 +05:30
expect_to_cancel_exclusive_lease(worker.lease_key, lease_uuid)
2018-12-05 23:21:45 +05:30
2021-11-18 22:05:49 +05:30
subject
2018-12-05 23:21:45 +05:30
end
end
2017-08-17 22:00:37 +05:30
end