Sha256: e691721c75e6c590dc3a1bd29177354f3d6e98dc00db1e3f6d32fdac56eff4ad
Contents?: true
Size: 1.8 KB
Versions: 1
Compression:
Stored size: 1.8 KB
Contents
# frozen_string_literal: true module GoodJob # :nodoc: class DiscreteExecution < BaseRecord include ErrorEvents self.table_name = 'good_job_executions' self.implicit_order_column = 'created_at' belongs_to :execution, class_name: 'GoodJob::Execution', foreign_key: 'active_job_id', primary_key: 'active_job_id', inverse_of: :discrete_executions, optional: true belongs_to :job, class_name: 'GoodJob::Job', foreign_key: 'active_job_id', primary_key: 'active_job_id', inverse_of: :discrete_executions, optional: true scope :finished, -> { where.not(finished_at: nil) } alias_attribute :performed_at, :created_at # TODO: Remove when support for Rails 6.1 is dropped attribute :duration, :interval if ActiveJob.version.canonical_segments.take(2) == [6, 1] def number serialized_params.fetch('executions', 0) + 1 end # Time between when this job was expected to run and when it started running def queue_latency created_at - scheduled_at end # Monotonic time between when this job started and finished def runtime_latency duration end def last_status_at finished_at || created_at end def status if finished_at.present? if error.present? && job.finished_at.present? :discarded elsif error.present? :retried else :succeeded end else :running end end def display_serialized_params serialized_params.merge({ _good_job_execution: attributes.except('serialized_params'), }) end def filtered_error_backtrace Rails.backtrace_cleaner.clean(error_backtrace || []) end end end ActiveSupport.run_load_hooks(:good_job_execution, GoodJob::DiscreteExecution)
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
good_job-4.0.3 | app/models/good_job/discrete_execution.rb |