Sha256: 3f64af4543f59cc9fc969d7649fd945d4468591eb6e3bd5669dcdb90461b8f46

Contents?: true

Size: 1.19 KB

Versions: 20

Compression:

Stored size: 1.19 KB

Contents

require 'logger'

module Backburner
  module Logger
    # Loads in instance and class levels
    def self.included(base)
      base.extend self
    end

    # Print out when a job is about to begin
    def log_job_begin(name, args)
      log_info "Work job #{name} with #{args.inspect}"
      @job_started_at = Time.now
    end

    # Print out when a job completed
    # If message is nil, job is considered complete
    def log_job_end(name, message = nil)
      ellapsed = Time.now - job_started_at
      ms = (ellapsed.to_f * 1000).to_i
      action_word = message ? 'Finished' : 'Completed'
      log_info("#{action_word} #{name} in #{ms}ms #{message}")
    end

    # Returns true if the job logging started
    def job_started_at
      @job_started_at
    end

    # Print a message to stdout
    #
    # @example
    #   log_info("Working on task")
    #
    def log_info(msg)
      logger ? logger.info(msg) : puts(msg)
    end

    # Print an error to stderr
    #
    # @example
    #   log_error("Task failed!")
    #
    def log_error(msg)
      logger ? logger.error(msg) : $stderr.puts(msg)
    end

    # Return logger if specified
    def logger
      Backburner.configuration.logger
    end
  end
end

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
backburner-1.4.1 lib/backburner/logger.rb
backburner-1.4.0 lib/backburner/logger.rb
backburner-1.3.1 lib/backburner/logger.rb
backburner-1.3.0 lib/backburner/logger.rb
backburner-1.2.0 lib/backburner/logger.rb
backburner-1.2.0.pre lib/backburner/logger.rb
backburner-1.1.0 lib/backburner/logger.rb
backburner-1.0.0 lib/backburner/logger.rb
backburner-0.4.6 lib/backburner/logger.rb
backburner-0.4.5 lib/backburner/logger.rb
backburner-0.4.4 lib/backburner/logger.rb
backburner-0.4.3 lib/backburner/logger.rb
backburner-0.4.2 lib/backburner/logger.rb
backburner-0.4.1 lib/backburner/logger.rb
backburner-0.4.0 lib/backburner/logger.rb
backburner-0.3.4 lib/backburner/logger.rb
backburner-0.3.3 lib/backburner/logger.rb
backburner-0.3.2 lib/backburner/logger.rb
backburner-0.3.1 lib/backburner/logger.rb
backburner-0.3.0 lib/backburner/logger.rb