2014-03-17 08:59:34 +08:00
|
|
|
# encoding: utf-8
|
2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-10-11 17:41:23 +08:00
|
|
|
require 'rails_helper'
|
2014-03-17 08:59:34 +08:00
|
|
|
|
|
|
|
describe Scheduler::Defer do
|
|
|
|
class DeferInstance
|
|
|
|
include Scheduler::Deferrable
|
|
|
|
end
|
|
|
|
|
|
|
|
def wait_for(timeout, &blk)
|
|
|
|
till = Time.now + (timeout.to_f / 1000)
|
|
|
|
while Time.now < till && !blk.call
|
|
|
|
sleep 0.001
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-10-12 14:03:47 +08:00
|
|
|
class TrackingLogger < ::Logger
|
|
|
|
attr_reader :messages
|
|
|
|
def initialize
|
|
|
|
super(nil)
|
|
|
|
@messages = []
|
|
|
|
end
|
|
|
|
def add(*args, &block)
|
|
|
|
@messages << args
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def track_log_messages
|
|
|
|
old_logger = Rails.logger
|
|
|
|
logger = Rails.logger = TrackingLogger.new
|
|
|
|
yield logger.messages
|
|
|
|
logger.messages
|
|
|
|
ensure
|
|
|
|
Rails.logger = old_logger
|
|
|
|
end
|
|
|
|
|
2014-03-17 08:59:34 +08:00
|
|
|
before do
|
|
|
|
@defer = DeferInstance.new
|
|
|
|
@defer.async = true
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
@defer.stop!
|
|
|
|
end
|
|
|
|
|
2018-10-12 14:03:47 +08:00
|
|
|
it "supports timeout reporting" do
|
|
|
|
@defer.timeout = 0.05
|
|
|
|
|
|
|
|
m = track_log_messages do |messages|
|
|
|
|
10.times do
|
|
|
|
@defer.later("fast job") {}
|
|
|
|
end
|
|
|
|
@defer.later "weird slow job" do
|
|
|
|
sleep
|
|
|
|
end
|
|
|
|
|
2018-11-19 13:21:18 +08:00
|
|
|
wait_for(200) do
|
2018-10-12 14:03:47 +08:00
|
|
|
messages.length == 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
expect(m.length).to eq(1)
|
|
|
|
expect(m[0][2]).to include("weird slow job")
|
|
|
|
end
|
|
|
|
|
2015-02-17 06:56:21 +08:00
|
|
|
it "can pause and resume" do
|
|
|
|
x = 1
|
|
|
|
@defer.pause
|
|
|
|
|
|
|
|
@defer.later do
|
|
|
|
x = 2
|
|
|
|
end
|
|
|
|
|
2017-11-23 12:48:47 +08:00
|
|
|
expect(@defer.length).to eq(1)
|
|
|
|
|
2015-02-17 06:56:21 +08:00
|
|
|
@defer.do_all_work
|
|
|
|
|
|
|
|
expect(x).to eq(2)
|
|
|
|
|
|
|
|
@defer.resume
|
|
|
|
|
|
|
|
@defer.later do
|
|
|
|
x = 3
|
|
|
|
end
|
|
|
|
|
2019-05-27 15:08:35 +08:00
|
|
|
wait_for(1000) do
|
2015-02-17 06:56:21 +08:00
|
|
|
x == 3
|
|
|
|
end
|
|
|
|
|
|
|
|
expect(x).to eq(3)
|
|
|
|
end
|
|
|
|
|
2014-03-17 12:22:11 +08:00
|
|
|
it "recovers from a crash / fork" do
|
|
|
|
s = nil
|
|
|
|
@defer.stop!
|
|
|
|
wait_for(10) do
|
|
|
|
@defer.stopped?
|
|
|
|
end
|
|
|
|
# hack allow thread to die
|
|
|
|
sleep 0.005
|
|
|
|
|
|
|
|
@defer.later do
|
|
|
|
s = "good"
|
|
|
|
end
|
|
|
|
|
|
|
|
wait_for(10) do
|
|
|
|
s == "good"
|
|
|
|
end
|
|
|
|
|
2015-01-10 00:34:37 +08:00
|
|
|
expect(s).to eq("good")
|
2014-03-17 12:22:11 +08:00
|
|
|
end
|
|
|
|
|
2014-03-17 08:59:34 +08:00
|
|
|
it "can queue jobs properly" do
|
|
|
|
s = nil
|
|
|
|
|
|
|
|
@defer.later do
|
|
|
|
s = "good"
|
|
|
|
end
|
|
|
|
|
|
|
|
wait_for(10) do
|
|
|
|
s == "good"
|
|
|
|
end
|
|
|
|
|
2015-01-10 00:34:37 +08:00
|
|
|
expect(s).to eq("good")
|
2014-03-17 08:59:34 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|