2019-05-17 12:10:44 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 06:09:01 +00:00
|
|
|
RSpec.describe Ci::PipelineScheduleService do
|
2022-09-16 21:09:49 +00:00
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
let_it_be(:project) { create(:project) }
|
|
|
|
|
2019-05-17 12:10:44 +00:00
|
|
|
let(:service) { described_class.new(project, user) }
|
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
subject { service.execute(schedule) }
|
|
|
|
|
2022-09-16 21:09:49 +00:00
|
|
|
let_it_be(:schedule) { create(:ci_pipeline_schedule, project: project, owner: user) }
|
2019-05-17 12:10:44 +00:00
|
|
|
|
|
|
|
it 'schedules next run' do
|
|
|
|
expect(schedule).to receive(:schedule_next_run!)
|
|
|
|
|
|
|
|
subject
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'runs RunPipelineScheduleWorker' do
|
|
|
|
expect(RunPipelineScheduleWorker)
|
|
|
|
.to receive(:perform_async).with(schedule.id, schedule.owner.id)
|
|
|
|
|
|
|
|
subject
|
|
|
|
end
|
2019-06-11 11:03:40 +00:00
|
|
|
|
|
|
|
context 'when owner is nil' do
|
|
|
|
let(:schedule) { create(:ci_pipeline_schedule, project: project, owner: nil) }
|
|
|
|
|
|
|
|
it 'does not raise an error' do
|
|
|
|
expect { subject }.not_to raise_error
|
|
|
|
end
|
|
|
|
end
|
2022-01-28 12:17:26 +00:00
|
|
|
|
|
|
|
context 'when the project is missing' do
|
2022-09-16 21:09:49 +00:00
|
|
|
let(:project) { create(:project).tap(&:delete) }
|
2022-01-28 12:17:26 +00:00
|
|
|
|
|
|
|
it 'does not raise an exception' do
|
|
|
|
expect { subject }.not_to raise_error
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not run RunPipelineScheduleWorker' do
|
|
|
|
expect(RunPipelineScheduleWorker)
|
|
|
|
.not_to receive(:perform_async).with(schedule.id, schedule.owner.id)
|
|
|
|
|
|
|
|
subject
|
|
|
|
end
|
|
|
|
end
|
2019-05-17 12:10:44 +00:00
|
|
|
end
|
|
|
|
end
|