Sha256: d192ab6d74e0feb70f155f2001ffae1292cfa8c2136137e6e0f932aedc2831bb

Contents?: true

Size: 1.17 KB

Versions: 7

Compression:

Stored size: 1.17 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

  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

7 entries across 7 versions & 1 rubygems

Version Path
rufus-scheduler-3.0.6 spec/job_every_spec.rb
rufus-scheduler-3.0.5 spec/job_every_spec.rb
rufus-scheduler-3.0.4 spec/job_every_spec.rb
rufus-scheduler-3.0.3 spec/job_every_spec.rb
rufus-scheduler-3.0.2 spec/job_every_spec.rb
rufus-scheduler-3.0.1 spec/job_every_spec.rb
rufus-scheduler-3.0.0 spec/job_every_spec.rb