|
12 | 12 | Resque.redis.flushall |
13 | 13 | Resque::Scheduler.clear_schedule! |
14 | 14 | Resque::Scheduler.send(:instance_variable_set, :@scheduled_jobs, {}) |
| 15 | + Resque::Scheduler.send(:instance_variable_set, :@shutdown, false) |
15 | 16 | end |
16 | 17 |
|
17 | 18 | test 'enqueue constantizes' do |
|
456 | 457 | /#{Resque::Scheduler.send(:internal_name)}: cage/ |
457 | 458 | end |
458 | 459 |
|
| 460 | + test 'gracefully shuts down rufus-scheduler threads' do |
| 461 | + if RUBY_ENGINE == 'jruby' || RUBY_PLATFORM =~ /mingw|windows/i |
| 462 | + omit("forking is not supported on #{RUBY_ENGINE}/#{RUBY_PLATFORM} but " \ |
| 463 | + 'this behaviour is best tested using forks') |
| 464 | + end |
| 465 | + |
| 466 | + class BeforeEnqueueJob |
| 467 | + @queue = :quick |
| 468 | + |
| 469 | + class << self |
| 470 | + def before_enqueue_example(*) |
| 471 | + return false if enqueue_started? |
| 472 | + enqueue_started! |
| 473 | + |
| 474 | + sleep 5 |
| 475 | + true |
| 476 | + end |
| 477 | + |
| 478 | + def enqueue_started? |
| 479 | + Resque.redis.get('before_enqueue_job:enqueued') == 'true' |
| 480 | + end |
| 481 | + |
| 482 | + def perform(*) |
| 483 | + end |
| 484 | + |
| 485 | + private |
| 486 | + |
| 487 | + def enqueue_started! |
| 488 | + Resque.redis.set('before_enqueue_job:enqueued', 'true') |
| 489 | + end |
| 490 | + end |
| 491 | + end |
| 492 | + |
| 493 | + schedule = { |
| 494 | + 'BeforeEnqueueJob' => { cron: '* * * * * *', class: 'BeforeEnqueueJob' } |
| 495 | + } |
| 496 | + |
| 497 | + pid = fork do |
| 498 | + Resque::Scheduler.clear_schedule! |
| 499 | + Resque.schedule = schedule |
| 500 | + Resque::Scheduler.run |
| 501 | + end |
| 502 | + |
| 503 | + begin |
| 504 | + 30.times do |
| 505 | + break if BeforeEnqueueJob.enqueue_started? |
| 506 | + sleep 0.1 |
| 507 | + end |
| 508 | + ensure |
| 509 | + Process.kill('TERM', pid) |
| 510 | + Process.wait(pid) |
| 511 | + end |
| 512 | + |
| 513 | + assert BeforeEnqueueJob.enqueue_started?, "Job enqueue didn't start in time" |
| 514 | + assert_equal 1, Resque.size('quick') |
| 515 | + end |
| 516 | + |
459 | 517 | context 'printing schedule' do |
460 | 518 | setup do |
461 | 519 | Resque::Scheduler.expects(:log!).at_least_once |
|
0 commit comments