Sha256: 5d58fb5b4305271069cf969549f2e4abbb717e4b90432a4fbd006ef8192eee9c
Contents?: true
Size: 1.6 KB
Versions: 1
Compression:
Stored size: 1.6 KB
Contents
# # Specifying rufus-scheduler # # Wed Apr 17 06:00:59 JST 2013 # require 'spec_helper' describe Rufus::Scheduler::EveryJob do before :each do @scheduler = Rufus::Scheduler.new end after :each do @scheduler.shutdown end it 'triggers as expected' do counter = 0 @scheduler.every '1s' do counter = counter + 1 end sleep 3.5 [ 2, 3 ].should include(counter) end it 'lets its @next_time change in-flight' do times = [] @scheduler.every '1s' do |job| times << Time.now job.next_time = Time.now + 3 if times.count == 2 end sleep 0.3 while times.count < 3 #p [ times[1] - times[0], times[2] - times[1] ] (times[1] - times[0]).should > 1.0 (times[1] - times[0]).should < 1.4 (times[2] - times[1]).should > 3.0 (times[2] - times[1]).should < 3.4 end context 'first_at/in' do it 'triggers for the first time at first_at' do t = Time.now job = @scheduler.schedule_every '3s', :first_in => '1s' do; end sleep 2 #p [ t, t.to_f ] #p [ job.last_time, job.last_time.to_f ] #p [ job.first_at, job.first_at.to_f ] job.first_at.should be_within_1s_of(t + 2) job.last_time.should be_within_1s_of(job.first_at) end describe '#first_at=' do it 'alters @next_time' do job = @scheduler.schedule_every '3s', :first_in => '10s' do; end fa0 = job.first_at nt0 = job.next_time job.first_at = Time.now + 3 fa1 = job.first_at nt1 = job.next_time nt0.should == fa0 nt1.should == fa1 end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
rufus-scheduler-3.0.7 | spec/job_every_spec.rb |