mirror of
https://github.com/plashchynski/crono.git
synced 2026-04-23 17:28:45 +02:00
Handle a few jobs scheduled at the same time
This commit is contained in:
@@ -79,9 +79,10 @@ module Crono
|
|||||||
end
|
end
|
||||||
|
|
||||||
def start_working_loop
|
def start_working_loop
|
||||||
while (job = Crono.scheduler.next)
|
while true
|
||||||
sleep(job.next - Time.now)
|
next_time, jobs = Crono.scheduler.next_jobs
|
||||||
job.perform
|
sleep(next_time - Time.now)
|
||||||
|
jobs.each(&:perform)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -17,8 +17,7 @@ module Crono
|
|||||||
end
|
end
|
||||||
|
|
||||||
def next
|
def next
|
||||||
next_time = period.next(since: last_performed_at)
|
period.next(since: last_performed_at)
|
||||||
next_time.past? ? period.next : next_time
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def description
|
def description
|
||||||
|
|||||||
@@ -12,14 +12,8 @@ module Crono
|
|||||||
jobs << job
|
jobs << job
|
||||||
end
|
end
|
||||||
|
|
||||||
def next
|
def next_jobs
|
||||||
queue.first
|
jobs.group_by(&:next).sort_by {|time,_| time }.first
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def queue
|
|
||||||
jobs.sort_by(&:next)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe Crono::Job do
|
describe Crono::Job do
|
||||||
let(:period) { Crono::Period.new(2.day) }
|
let(:period) { Crono::Period.new(2.day, at: '15:00') }
|
||||||
let(:job) { Crono::Job.new(TestJob, period) }
|
let(:job) { Crono::Job.new(TestJob, period) }
|
||||||
let(:failing_job) { Crono::Job.new(TestFailingJob, period) }
|
let(:failing_job) { Crono::Job.new(TestFailingJob, period) }
|
||||||
|
|
||||||
@@ -10,6 +10,12 @@ describe Crono::Job do
|
|||||||
expect(job.period).to be period
|
expect(job.period).to be period
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#next' do
|
||||||
|
it 'should return next performing time according to period' do
|
||||||
|
expect(job.next).to be_eql period.next
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe '#perform' do
|
describe '#perform' do
|
||||||
after { job.send(:model).destroy }
|
after { job.send(:model).destroy }
|
||||||
|
|
||||||
@@ -47,7 +53,7 @@ describe Crono::Job do
|
|||||||
|
|
||||||
describe '#description' do
|
describe '#description' do
|
||||||
it 'should return job identificator' do
|
it 'should return job identificator' do
|
||||||
expect(job.description).to be_eql('Perform TestJob every 2 days')
|
expect(job.description).to be_eql('Perform TestJob every 2 days at 15:00')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -1,27 +1,38 @@
|
|||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe Crono::Scheduler do
|
describe Crono::Scheduler do
|
||||||
before(:each) do
|
let(:scheduler) { Crono::Scheduler.new }
|
||||||
@scheduler = Crono::Scheduler.new
|
|
||||||
@jobs = [
|
|
||||||
Crono::Period.new(3.day, at: 10.minutes.from_now.strftime('%H:%M')),
|
|
||||||
Crono::Period.new(1.day, at: 20.minutes.from_now.strftime('%H:%M')),
|
|
||||||
Crono::Period.new(7.day, at: 40.minutes.from_now.strftime('%H:%M'))
|
|
||||||
].map { |period| Crono::Job.new(TestJob, period) }
|
|
||||||
@scheduler.jobs = @jobs
|
|
||||||
end
|
|
||||||
|
|
||||||
describe '#add_job' do
|
describe '#add_job' do
|
||||||
it 'should call Job#load on Job' do
|
it 'should call Job#load on Job' do
|
||||||
@job = Crono::Job.new(TestJob, Crono::Period.new(10.day, at: '04:05'))
|
@job = Crono::Job.new(TestJob, Crono::Period.new(10.day, at: '04:05'))
|
||||||
expect(@job).to receive(:load)
|
expect(@job).to receive(:load)
|
||||||
@scheduler.add_job(@job)
|
scheduler.add_job(@job)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#next' do
|
describe '#next_jobs' do
|
||||||
it 'should return next job in schedule' do
|
it 'should return next job in schedule' do
|
||||||
expect(@scheduler.next).to be @jobs[0]
|
scheduler.jobs = jobs = [
|
||||||
|
Crono::Period.new(3.days, at: 10.minutes.from_now.strftime('%H:%M')),
|
||||||
|
Crono::Period.new(1.day, at: 20.minutes.from_now.strftime('%H:%M')),
|
||||||
|
Crono::Period.new(7.days, at: 40.minutes.from_now.strftime('%H:%M'))
|
||||||
|
].map { |period| Crono::Job.new(TestJob, period) }
|
||||||
|
|
||||||
|
time, jobs = scheduler.next_jobs
|
||||||
|
expect(jobs).to be_eql [jobs[0]]
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'should return an array of jobs scheduled at same time' do
|
||||||
|
time = 5.minutes.from_now
|
||||||
|
scheduler.jobs = jobs = [
|
||||||
|
Crono::Period.new(1.day, at: time.strftime('%H:%M')),
|
||||||
|
Crono::Period.new(1.day, at: time.strftime('%H:%M')),
|
||||||
|
Crono::Period.new(1.day, at: 10.minutes.from_now.strftime('%H:%M'))
|
||||||
|
].map { |period| Crono::Job.new(TestJob, period) }
|
||||||
|
|
||||||
|
time, jobs = scheduler.next_jobs
|
||||||
|
expect(jobs).to be_eql [jobs[0], jobs[1]]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user