Sha256: 1deef52416e90a599a6ebb98b4450a15ccbcb6309fa7fccc6be7119f2f50c13d
Contents?: true
Size: 1.42 KB
Versions: 5
Compression:
Stored size: 1.42 KB
Contents
# Ripped off from https://github.com/mperham/sidekiq/blob/master/lib/sidekiq/exception_handler.rb module Sneakers module ErrorReporter class DefaultLogger def call(exception, worker, context_hash) Sneakers.logger.warn(context_hash) unless context_hash.empty? log_string = '' log_string += "[Exception error=#{exception.message.inspect} error_class=#{exception.class} worker_class=#{worker.class}" unless exception.nil? log_string += " backtrace=#{exception.backtrace.take(50).join(',')}" unless exception.nil? || exception.backtrace.nil? log_string += ']' Sneakers.logger.error log_string end end def worker_error(exception, context_hash = {}) Sneakers.error_reporters.each do |handler| begin handler.call(exception, self, context_hash) rescue SignalException, SystemExit # ServerEngine handles these exceptions, so they are not expected # to be raised within the error reporter. # Nevertheless, they are listed here to ensure that they are not # caught by the rescue block below. raise rescue Exception => inner_exception Sneakers.logger.error '!!! ERROR REPORTER THREW AN ERROR !!!' Sneakers.logger.error inner_exception Sneakers.logger.error inner_exception.backtrace.join("\n") unless inner_exception.backtrace.nil? end end end end end
Version data entries
5 entries across 5 versions & 1 rubygems