# frozen_string_literal: true module Loggery module Util def log_job_runtime(job_type, job_instance_name = nil) job_name = ["Job type #{job_type}", job_instance_name].compact.join " - " Rails.logger.info event_type: :"#{job_type}_started", message: "#{job_name} started" begin start_time = Time.current yield if block_given? ensure end_time = Time.current duration = end_time - start_time Rails.logger.info event_type: :"#{job_type}_finished", message: "#{job_name} finished", duration: duration end end end end