Merge pull request #4980 from tchak/human-readable-cron

Use human readable expressions instead of cron gibberish
This commit is contained in:
Paul Chavard 2020-04-07 13:33:37 +02:00 committed by GitHub
commit d9015c4e3c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
19 changed files with 39 additions and 16 deletions

View file

@ -28,6 +28,7 @@ gem 'dotenv-rails', require: 'dotenv/rails-now' # dotenv should always be loaded
gem 'flipper'
gem 'flipper-active_record'
gem 'flipper-ui'
gem 'fugit'
gem 'geocoder'
gem 'gon'
gem 'graphiql-rails'

View file

@ -203,6 +203,8 @@ GEM
http_parser.rb (~> 0.6.0)
erubi (1.9.0)
erubis (2.7.0)
et-orbi (1.2.4)
tzinfo
ethon (0.11.0)
ffi (>= 1.3.0)
eventmachine (1.2.7)
@ -235,6 +237,9 @@ GEM
fog-json (>= 1.0)
ipaddress (>= 0.8)
formatador (0.2.5)
fugit (1.3.3)
et-orbi (~> 1.1, >= 1.1.8)
raabro (~> 1.1)
geocoder (1.6.0)
globalid (0.4.2)
activesupport (>= 4.2.0)
@ -452,6 +457,7 @@ GEM
puma (3.12.4)
pundit (2.0.1)
activesupport (>= 3.0.0)
raabro (1.1.6)
rack (2.2.2)
rack-attack (6.0.0)
rack (>= 1.0, < 3)
@ -746,6 +752,7 @@ DEPENDENCIES
flipper
flipper-active_record
flipper-ui
fugit
geocoder
gon
graphiql-rails

View file

@ -1,5 +1,5 @@
class AdministrateurActivateBeforeExpirationJob < CronJob
self.cron_expression = "0 8 * * *"
self.schedule_expression = "every day at 8 am"
def perform(*args)
Administrateur

View file

@ -1,5 +1,5 @@
class AutoArchiveProcedureJob < CronJob
self.cron_expression = "* * * * *"
self.schedule_expression = "every 1 minute"
def perform(*args)
Procedure.publiees.where("auto_archive_on <= ?", Time.zone.today).each do |procedure|

View file

@ -1,6 +1,6 @@
class CronJob < ApplicationJob
queue_as :cron
class_attribute :cron_expression
class_attribute :schedule_expression
class << self
def schedule
@ -12,6 +12,10 @@ class CronJob < ApplicationJob
delayed_job.destroy if scheduled?
end
def display_schedule
pp "#{name}: #{schedule_expression} cron(#{cron_expression})"
end
def scheduled?
delayed_job.present?
end
@ -25,5 +29,9 @@ class CronJob < ApplicationJob
.where('handler LIKE ?', "%job_class: #{name}%")
.first
end
def cron_expression
Fugit.do_parse(schedule_expression, multi: :fail).to_cron_s
end
end
end

View file

@ -1,5 +1,5 @@
class DeclarativeProceduresJob < CronJob
self.cron_expression = "* * * * *"
self.schedule_expression = "every 1 minute"
def perform(*args)
Procedure.declarative.find_each(&:process_dossiers!)

View file

@ -1,5 +1,5 @@
class DiscardedDossiersDeletionJob < CronJob
self.cron_expression = "0 7 * * *"
self.schedule_expression = "every day at 2 am"
def perform(*args)
Dossier.discarded_brouillon_expired.destroy_all

View file

@ -1,5 +1,5 @@
class DiscardedProceduresDeletionJob < CronJob
self.cron_expression = "0 7 * * *"
self.schedule_expression = "every day at 1 am"
def perform(*args)
Procedure.discarded_expired.find_each do |procedure|

View file

@ -1,5 +1,5 @@
class ExpiredDossiersDeletionJob < CronJob
self.cron_expression = "0 7 * * *"
self.schedule_expression = "every day at 7 am"
def perform(*args)
ExpiredDossiersDeletionService.process_expired_dossiers_brouillon

View file

@ -1,5 +1,5 @@
class FindDubiousProceduresJob < CronJob
self.cron_expression = "0 0 * * *"
self.schedule_expression = "every day at midnight"
FORBIDDEN_KEYWORDS = [
'NIR', 'NIRPP', 'race', 'religion',

View file

@ -1,5 +1,5 @@
class InstructeurEmailNotificationJob < CronJob
self.cron_expression = "0 10 * * MON-FRI"
self.schedule_expression = "from monday through friday at 10 am"
def perform(*args)
NotificationService.send_instructeur_email_notification

View file

@ -1,5 +1,5 @@
class NotifyDraftNotSubmittedJob < CronJob
self.cron_expression = "0 7 * * *"
self.schedule_expression = "from monday through friday at 7 am"
def perform(*args)
Dossier.notify_draft_not_submitted

View file

@ -1,5 +1,5 @@
class OperationsSignatureJob < CronJob
self.cron_expression = "0 6 * * *"
self.schedule_expression = "every day at 6 am"
def perform(*args)
last_midnight = Time.zone.today.beginning_of_day

View file

@ -1,5 +1,5 @@
class PurgeStaleExportsJob < CronJob
self.cron_expression = "*/5 * * * *"
self.schedule_expression = "every 5 minutes"
def perform
Export.stale.destroy_all

View file

@ -1,5 +1,5 @@
class PurgeUnattachedBlobsJob < CronJob
self.cron_expression = "0 0 * * *"
self.schedule_expression = "every day at midnight"
def perform(*args)
ActiveStorage::Blob.unattached

View file

@ -1,5 +1,5 @@
class UpdateAdministrateurUsageStatisticsJob < CronJob
self.cron_expression = "0 10 * * *"
self.schedule_expression = "every day at 10 am"
def perform
AdministrateurUsageStatisticsService.new.update_administrateurs

View file

@ -1,5 +1,5 @@
class WarnExpiringDossiersJob < CronJob
self.cron_expression = "0 0 1 * *"
self.schedule_expression = "every 1 month at midnight"
def perform(*args)
expiring, expired = Dossier

View file

@ -1,5 +1,5 @@
class WeeklyOverviewJob < CronJob
self.cron_expression = "0 7 * * MON"
self.schedule_expression = "every monday at 7 am"
def perform(*args)
# Feature flipped to avoid mails in staging due to unprocessed dossier

View file

@ -5,4 +5,11 @@ namespace :jobs do
Dir.glob(glob).each { |f| require f }
CronJob.subclasses.each(&:schedule)
end
desc 'Display schedule for all cron jobs'
task display_schedule: :environment do
glob = Rails.root.join('app', 'jobs', '**', '*_job.rb')
Dir.glob(glob).each { |f| require f }
CronJob.subclasses.each(&:display_schedule)
end
end