Commit 1a8b411813954ff4b2d046d3aa98ca3e50e9f0a3
1 parent
16929d88
Exists in
master
and in
7 other branches
Fix job reschedule
Showing
2 changed files
with
5 additions
and
2 deletions
Show diff stats
lib/proposals_discussion_plugin/ranking_job.rb
| @@ -4,6 +4,9 @@ class ProposalsDiscussionPlugin::RankingJob | @@ -4,6 +4,9 @@ class ProposalsDiscussionPlugin::RankingJob | ||
| 4 | ProposalsDiscussionPlugin::Topic.find_each do |topic| | 4 | ProposalsDiscussionPlugin::Topic.find_each do |topic| |
| 5 | ProposalsDiscussionPlugin::RankingJob::TopicRankingJob.new(topic.id).schedule | 5 | ProposalsDiscussionPlugin::RankingJob::TopicRankingJob.new(topic.id).schedule |
| 6 | end | 6 | end |
| 7 | + end | ||
| 8 | + | ||
| 9 | + def after(job) | ||
| 7 | schedule(30.minutes.from_now) | 10 | schedule(30.minutes.from_now) |
| 8 | end | 11 | end |
| 9 | 12 | ||
| @@ -12,7 +15,7 @@ class ProposalsDiscussionPlugin::RankingJob | @@ -12,7 +15,7 @@ class ProposalsDiscussionPlugin::RankingJob | ||
| 12 | end | 15 | end |
| 13 | 16 | ||
| 14 | def self.find_job | 17 | def self.find_job |
| 15 | - Delayed::Job.by_handler("--- !ruby/object:ProposalsDiscussionPlugin::RankingJob {}\n") | 18 | + Delayed::Job.by_handler("--- !ruby/object:ProposalsDiscussionPlugin::RankingJob {}\n").where('locked_at IS NULL') |
| 16 | end | 19 | end |
| 17 | 20 | ||
| 18 | 21 |
test/unit/ranking_job_test.rb
| @@ -15,6 +15,7 @@ class RankingJobTest < ActiveSupport::TestCase | @@ -15,6 +15,7 @@ class RankingJobTest < ActiveSupport::TestCase | ||
| 15 | end | 15 | end |
| 16 | 16 | ||
| 17 | should 'do not create duplicated ranking job' do | 17 | should 'do not create duplicated ranking job' do |
| 18 | + Delayed::Job.destroy_all | ||
| 18 | job.schedule | 19 | job.schedule |
| 19 | job.schedule | 20 | job.schedule |
| 20 | assert_equal 1, job.class.find_job.count | 21 | assert_equal 1, job.class.find_job.count |
| @@ -27,7 +28,6 @@ class RankingJobTest < ActiveSupport::TestCase | @@ -27,7 +28,6 @@ class RankingJobTest < ActiveSupport::TestCase | ||
| 27 | 28 | ||
| 28 | should 'reschedule job when performed' do | 29 | should 'reschedule job when performed' do |
| 29 | process_delayed_job_queue | 30 | process_delayed_job_queue |
| 30 | - job.perform | ||
| 31 | new_job = job.class.find_job.first | 31 | new_job = job.class.find_job.first |
| 32 | assert new_job.present? | 32 | assert new_job.present? |
| 33 | assert new_job.run_at > 20.minutes.from_now | 33 | assert new_job.run_at > 20.minutes.from_now |