summaryrefslogtreecommitdiff
path: root/spec/workers
diff options
context:
space:
mode:
authorShinya Maeda <gitlab.shinyamaeda@gmail.com>2017-04-06 19:13:29 +0900
committerShinya Maeda <gitlab.shinyamaeda@gmail.com>2017-04-06 23:46:59 +0900
commitfff6afbad1180cb39fd0a8d9032de91397ba6471 (patch)
treea94e3f20e2a8aad5dea6b5307ef96cd2efb1e9b4 /spec/workers
parent059ec792cbd670d2b716c111b6faa50e5782ae9f (diff)
downloadgitlab-ce-fff6afbad1180cb39fd0a8d9032de91397ba6471.tar.gz
Use change direction in spec
Diffstat (limited to 'spec/workers')
-rw-r--r--spec/workers/trigger_schedule_worker_spec.rb33
1 files changed, 13 insertions, 20 deletions
diff --git a/spec/workers/trigger_schedule_worker_spec.rb b/spec/workers/trigger_schedule_worker_spec.rb
index 0bb0bcc5c42..151e1c2f7b9 100644
--- a/spec/workers/trigger_schedule_worker_spec.rb
+++ b/spec/workers/trigger_schedule_worker_spec.rb
@@ -8,58 +8,51 @@ describe TriggerScheduleWorker do
end
context 'when there is a scheduled trigger within next_run_at' do
- let!(:trigger_schedule) { create(:ci_trigger_schedule, :nightly) }
- let(:next_time) { Gitlab::Ci::CronParser.new(trigger_schedule.cron, trigger_schedule.cron_timezone).next_time_from(@time_future) }
-
before do
- @time_future = Time.now + 10.days
- allow(Time).to receive(:now).and_return(@time_future)
- worker.perform
+ trigger_schedule = create(:ci_trigger_schedule, :nightly)
+ time_future = Time.now + 10.days
+ allow(Time).to receive(:now).and_return(time_future)
+ @next_time = Gitlab::Ci::CronParser.new(trigger_schedule.cron, trigger_schedule.cron_timezone).next_time_from(time_future)
end
it 'creates a new trigger request' do
- expect(trigger_schedule.trigger.id).to eq(Ci::TriggerRequest.first.trigger_id)
+ expect { worker.perform }.to change { Ci::TriggerRequest.count }.by(1)
end
it 'creates a new pipeline' do
+ expect { worker.perform }.to change { Ci::Pipeline.count }.by(1)
expect(Ci::Pipeline.last).to be_pending
end
it 'updates next_run_at' do
- expect(Ci::TriggerSchedule.last.next_run_at).to eq(next_time)
+ expect { worker.perform }.to change { Ci::TriggerSchedule.last.next_run_at }.to(@next_time)
end
end
context 'when there are no scheduled triggers within next_run_at' do
- let!(:trigger_schedule) { create(:ci_trigger_schedule, :nightly) }
-
- before do
- worker.perform
- end
+ before { create(:ci_trigger_schedule, :nightly) }
it 'does not create a new pipeline' do
- expect(Ci::Pipeline.count).to eq(0)
+ expect { worker.perform }.not_to change { Ci::Pipeline.count }
end
it 'does not update next_run_at' do
- expect(trigger_schedule.next_run_at).to eq(Ci::TriggerSchedule.last.next_run_at)
+ expect { worker.perform }.not_to change { Ci::TriggerSchedule.last.next_run_at }
end
end
context 'when next_run_at is nil' do
- let!(:trigger_schedule) { create(:ci_trigger_schedule, :nightly) }
-
before do
+ trigger_schedule = create(:ci_trigger_schedule, :nightly)
trigger_schedule.update_attribute(:next_run_at, nil)
- worker.perform
end
it 'does not create a new pipeline' do
- expect(Ci::Pipeline.count).to eq(0)
+ expect { worker.perform }.not_to change { Ci::Pipeline.count }
end
it 'does not update next_run_at' do
- expect(trigger_schedule.next_run_at).to eq(Ci::TriggerSchedule.last.next_run_at)
+ expect { worker.perform }.not_to change { Ci::TriggerSchedule.last.next_run_at }
end
end
end