-
Notifications
You must be signed in to change notification settings - Fork 0
/
log_all_exceptions.rb
47 lines (35 loc) · 1.16 KB
/
log_all_exceptions.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# Use this monkey patch to log or output all exceptions within a program.
# This works by hooking the creation of all Exceptions. Keep in mind, this
# will trap all exceptions, including rescued exceptions that are not fatal.
# This can be useful, especially within evented code like Eventmachine when used to discover
# where a callback is dying.
# A simple string-match filter is included so eliminating noise is possible:
# Exception.ignore_for_logging = ['Timeout']
# In order to use this, you must define a global log method specifying what to do with
# the output. For example, here you could simply write it to stdout. Alternately, you
# can call your own logger.
# module Kernel
# def log(msg)
# p msg
# end
# end
class Exception
alias :real_init :initialize
@@ignore_patterns = []
def self.ignore_for_logging=(text_arr)
@@ignore_patterns = text_arr
end
def ignored?
@@ignore_patterns.each do |p|
return true if self.message.include?(p)
end
false
end
def initialize(*args)
real_init *args
unless ignored?
log "****Exception: #{self} #{self.message} #{caller(1)}"
end
self
end
end