Skip to content

Commit

Permalink
Fix args
Browse files Browse the repository at this point in the history
  • Loading branch information
misteral committed Sep 2, 2022
1 parent e43ad4d commit 43e411c
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 12 deletions.
2 changes: 1 addition & 1 deletion lib/crono/job.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ class Job
attr_accessor :performer, :period, :job_args, :last_performed_at, :job_options,
:next_performed_at, :job_log, :job_logger, :healthy, :execution_interval

def initialize(performer, period, job_args, job_options = nil)
def initialize(performer, period, job_args = nil, job_options = nil)
self.execution_interval = 0.minutes
self.performer, self.period = performer, period
self.job_args = JSON.generate(job_args) if job_args.present?
Expand Down
9 changes: 5 additions & 4 deletions lib/crono/performer_proxy.rb
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
module Crono
# Crono::PerformerProxy is a proxy used in cronotab.rb semantic
class PerformerProxy
def initialize(performer, scheduler, job_args)
def initialize(performer, scheduler, job_args = nil, job_options = nil)
@performer = performer
@scheduler = scheduler
@job_args = job_args
@job_options = job_options
end

def every(period, **options)
@job = Job.new(@performer, Period.new(period, **options), @job_args, @options)
@job = Job.new(@performer, Period.new(period, **options), @job_args, @job_options)
@scheduler.add_job(@job)
self
end
Expand All @@ -19,12 +20,12 @@ def once_per(execution_interval)
end

def with_options(options)
@options = options
@job_options = options
self
end
end

def self.perform(performer, *job_args)
PerformerProxy.new(performer, Crono.scheduler, job_args)
PerformerProxy.new(performer, Crono.scheduler, *job_args)
end
end
19 changes: 15 additions & 4 deletions spec/job_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,12 +12,19 @@ def perform(*args)
end
end

class TestNoArgsJob
def perform
puts 'Test!'
end
end

describe Crono::Job do
let(:period) { Crono::Period.new(2.day, at: '15:00') }
let(:job_args) {[{some: 'data'}]}
let(:job) { Crono::Job.new(TestJob, period, []) }
let(:job_with_args) { Crono::Job.new(TestJob, period, job_args) }
let(:failing_job) { Crono::Job.new(TestFailingJob, period, []) }
let(:not_args_job) { Crono::Job.new(TestJob, period) }

it 'should contain performer and period' do
expect(job.performer).to be TestJob
Expand Down Expand Up @@ -70,6 +77,10 @@ def perform(*args)
test_preform_job_twice
end

it 'should execute twice without args' do
test_preform_job_twice not_args_job
end

it 'should execute twice without initialize execution_interval' do
test_preform_job_twice
end
Expand All @@ -88,10 +99,10 @@ def perform(*args)
expect(thread).to be_stop
end

def test_preform_job_twice
expect(job).to receive(:perform_job).twice
job.perform.join
thread = job.perform.join
def test_preform_job_twice(jon_instance = job)
expect(jon_instance).to receive(:perform_job).twice
jon_instance.perform.join
thread = jon_instance.perform.join
expect(thread).to be_stop
end
end
Expand Down
12 changes: 9 additions & 3 deletions spec/performer_proxy_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -26,13 +26,19 @@ def perform
end

it 'should add job with args to schedule' do
expect(Crono::Job).to receive(:new).with(TestJob, kind_of(Crono::Period), [:some, {some: 'data'}], nil)
expect(Crono::Job).to receive(:new).with(TestJob, kind_of(Crono::Period), :some, { some: 'data' })
allow(Crono.scheduler).to receive(:add_job)
Crono.perform(TestJob, :some, {some: 'data'}).every(2.days, at: '15:30')
Crono.perform(TestJob, :some, { some: 'data' }).every(2.days, at: '15:30')
end

it 'should add job without args to schedule' do
expect(Crono::Job).to receive(:new).with(TestJob, kind_of(Crono::Period), nil, nil)
allow(Crono.scheduler).to receive(:add_job)
Crono.perform(TestJob).every(2.days, at: '15:30')
end

it 'should add job with options to schedule' do
expect(Crono::Job).to receive(:new).with(TestJob, kind_of(Crono::Period), [], {some_option: true})
expect(Crono::Job).to receive(:new).with(TestJob, kind_of(Crono::Period), nil, { some_option: true })
allow(Crono.scheduler).to receive(:add_job)
Crono.perform(TestJob).with_options(some_option: true).every(2.days, at: '15:30')
end
Expand Down

0 comments on commit 43e411c

Please sign in to comment.