RSpec 3 和 sidekiq 3.2.1。我已经正确设置了 sidekiq 和 rspec-sidekiq。
假设我有一个名为 的工人WeatherJob
,它将天气状态从更改sunny
为rainy
:
class WeatherJob
include Sidekiq::Worker
def perform record_id
weather = Weather.find record_id
weather.update status: 'rainy'
end
end
我像这样使用这个工人:
WeatherJob.perform_in 15.minutes, weather.id
.
在规范中,我使用 Timecop 来模拟时间:
require 'rails_helper'
describe WeatherJob do
let(:weather) { create :weather, status: 'sunny' }
let(:now) { Time.current }
it 'enqueue a job' do
expect {
WeatherJob.perform_async weather.id
}.to change(WeatherJob.jobs, :size).by 1
end
context '15 mins later' do
before do
Timecop.freeze(now) do
Weather.perform_in 15.minutes, weather.id
end
end
it 'update to rainy' do
Timecop.freeze(now + 16.minutes) do
expect(weather.status).to eq 'rainy'
end
end
end
end
我可以看到Weather.jobs
数组中有工作。时间是正确的 16 分钟后。但它没有执行任务?有什么建议吗?谢谢!