mtn_log4r 1.1.11
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +15 -0
- data/doc/content/contact.html +22 -0
- data/doc/content/contribute.html +21 -0
- data/doc/content/index.html +90 -0
- data/doc/content/license.html +56 -0
- data/doc/content/manual.html +449 -0
- data/doc/dev/README.developers +55 -0
- data/doc/dev/checklist +23 -0
- data/doc/dev/things-to-do +5 -0
- data/doc/images/log4r-logo.png +0 -0
- data/doc/images/logo2.png +0 -0
- data/doc/log4r.css +111 -0
- data/doc/rdoc-log4r.css +696 -0
- data/doc/templates/main.html +147 -0
- data/examples/README +19 -0
- data/examples/ancestors.rb +53 -0
- data/examples/chainsaw_settings.xml +7 -0
- data/examples/customlevels.rb +34 -0
- data/examples/filelog.rb +25 -0
- data/examples/fileroll.rb +40 -0
- data/examples/gmail.rb +30 -0
- data/examples/gmail.yaml +95 -0
- data/examples/log4r_yaml.yaml +0 -0
- data/examples/logclient.rb +25 -0
- data/examples/logserver.rb +18 -0
- data/examples/moderate.xml +29 -0
- data/examples/moderateconfig.rb +66 -0
- data/examples/myformatter.rb +23 -0
- data/examples/outofthebox.rb +21 -0
- data/examples/rdoc-gen +2 -0
- data/examples/rrconfig.xml +63 -0
- data/examples/rrsetup.rb +42 -0
- data/examples/simpleconfig.rb +39 -0
- data/examples/syslogcustom.rb +52 -0
- data/examples/xmlconfig.rb +25 -0
- data/examples/yaml.rb +30 -0
- data/lib/log4r/GDC.rb +41 -0
- data/lib/log4r/MDC.rb +59 -0
- data/lib/log4r/NDC.rb +86 -0
- data/lib/log4r/base.rb +74 -0
- data/lib/log4r/config.rb +9 -0
- data/lib/log4r/configurator.rb +224 -0
- data/lib/log4r/formatter/formatter.rb +109 -0
- data/lib/log4r/formatter/log4jxmlformatter.rb +65 -0
- data/lib/log4r/formatter/patternformatter.rb +145 -0
- data/lib/log4r/lib/drbloader.rb +52 -0
- data/lib/log4r/lib/xmlloader.rb +24 -0
- data/lib/log4r/logevent.rb +28 -0
- data/lib/log4r/logger.rb +199 -0
- data/lib/log4r/loggerfactory.rb +89 -0
- data/lib/log4r/logserver.rb +28 -0
- data/lib/log4r/outputter/consoleoutputters.rb +18 -0
- data/lib/log4r/outputter/datefileoutputter.rb +117 -0
- data/lib/log4r/outputter/emailoutputter.rb +143 -0
- data/lib/log4r/outputter/fileoutputter.rb +56 -0
- data/lib/log4r/outputter/iooutputter.rb +55 -0
- data/lib/log4r/outputter/outputter.rb +134 -0
- data/lib/log4r/outputter/outputterfactory.rb +61 -0
- data/lib/log4r/outputter/rabbitoutputter.rb +70 -0
- data/lib/log4r/outputter/remoteoutputter.rb +40 -0
- data/lib/log4r/outputter/rollingfileoutputter.rb +234 -0
- data/lib/log4r/outputter/scribeoutputter.rb +37 -0
- data/lib/log4r/outputter/staticoutputter.rb +30 -0
- data/lib/log4r/outputter/syslogoutputter.rb +130 -0
- data/lib/log4r/outputter/udpoutputter.rb +53 -0
- data/lib/log4r/rdoc/GDC +14 -0
- data/lib/log4r/rdoc/MDC +16 -0
- data/lib/log4r/rdoc/NDC +41 -0
- data/lib/log4r/rdoc/configurator +243 -0
- data/lib/log4r/rdoc/emailoutputter +103 -0
- data/lib/log4r/rdoc/formatter +39 -0
- data/lib/log4r/rdoc/log4jxmlformatter +21 -0
- data/lib/log4r/rdoc/log4r +89 -0
- data/lib/log4r/rdoc/logger +175 -0
- data/lib/log4r/rdoc/logserver +85 -0
- data/lib/log4r/rdoc/outputter +108 -0
- data/lib/log4r/rdoc/patternformatter +128 -0
- data/lib/log4r/rdoc/scribeoutputter +16 -0
- data/lib/log4r/rdoc/syslogoutputter +29 -0
- data/lib/log4r/rdoc/win32eventoutputter +7 -0
- data/lib/log4r/rdoc/yamlconfigurator +20 -0
- data/lib/log4r/repository.rb +88 -0
- data/lib/log4r/staticlogger.rb +49 -0
- data/lib/log4r/version.rb +4 -0
- data/lib/log4r/yamlconfigurator.rb +198 -0
- data/lib/log4r.rb +18 -0
- data/tests/README +10 -0
- data/tests/testGDC.rb +24 -0
- data/tests/testMDC.rb +40 -0
- data/tests/testNDC.rb +25 -0
- data/tests/test_helper.rb +12 -0
- data/tests/testall.rb +6 -0
- data/tests/testbase.rb +48 -0
- data/tests/testchainsaw.rb +42 -0
- data/tests/testconf.xml +37 -0
- data/tests/testcustom.rb +30 -0
- data/tests/testformatter.rb +31 -0
- data/tests/testlogger.rb +200 -0
- data/tests/testoutputter.rb +143 -0
- data/tests/testpatternformatter.rb +76 -0
- data/tests/testthreads.rb +31 -0
- data/tests/testxmlconf.rb +48 -0
- data/tests/testyaml.rb +39 -0
- data/tests/testyaml_arrays.yaml +25 -0
- data/tests/testyaml_injection.yaml +22 -0
- metadata +193 -0
data/tests/testlogger.rb
ADDED
@@ -0,0 +1,200 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
class MyFormatter1 < Log4r::Formatter
|
4
|
+
def format(event)
|
5
|
+
return "MyFormatter1\n"
|
6
|
+
end
|
7
|
+
end
|
8
|
+
|
9
|
+
class MyFormatter2 < Log4r::Formatter
|
10
|
+
def format(event)
|
11
|
+
return "MyFormatter2\n"
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
class TestLogger < TestCase
|
16
|
+
include Log4r
|
17
|
+
|
18
|
+
def test_root
|
19
|
+
l1 = Logger.root
|
20
|
+
l2 = Logger['root']
|
21
|
+
l3 = Logger.global
|
22
|
+
assert(l1 == l2, "RootLogger wasn't singleton!")
|
23
|
+
assert(l1 == l3)
|
24
|
+
assert(l1.is_root? == true, "is_root? not working")
|
25
|
+
assert(l1.parent == nil, "Root's parent wasn't nil!")
|
26
|
+
end
|
27
|
+
def test_validation
|
28
|
+
assert_raise(ArgumentError) { Logger.new }
|
29
|
+
assert_nothing_raised { Logger.new('validate', nil) }
|
30
|
+
end
|
31
|
+
def test_all_off
|
32
|
+
l = Logger.new("create_method")
|
33
|
+
l.level = WARN
|
34
|
+
assert(l.debug? == false)
|
35
|
+
assert(l.info? == false)
|
36
|
+
assert(l.warn? == true)
|
37
|
+
assert(l.error? == true)
|
38
|
+
assert(l.fatal? == true)
|
39
|
+
assert(l.off? == false)
|
40
|
+
assert(l.all? == false)
|
41
|
+
l.level = OFF
|
42
|
+
assert(l.off? == true)
|
43
|
+
assert(l.all? == false)
|
44
|
+
l.level = ALL
|
45
|
+
assert(l.off? == false)
|
46
|
+
assert(l.all? == true)
|
47
|
+
end
|
48
|
+
def test_add_outputters
|
49
|
+
StdoutOutputter.new('fake1')
|
50
|
+
StdoutOutputter.new('fake2')
|
51
|
+
a = Logger.new("add")
|
52
|
+
assert_raise(TypeError) { a.add 'bogus' }
|
53
|
+
assert_raise(TypeError) { a.add Class }
|
54
|
+
assert_raise(TypeError) { a.add 'fake1', Class }
|
55
|
+
assert_nothing_raised { a.add 'fake1', 'fake2' }
|
56
|
+
end
|
57
|
+
def test_repository
|
58
|
+
assert_raise(NameError) { Logger.get('bogusbogus') }
|
59
|
+
assert_nothing_raised { Logger['bogusbogus'] }
|
60
|
+
end
|
61
|
+
def test_heiarchy
|
62
|
+
a = Logger.new("a")
|
63
|
+
a.additive = true
|
64
|
+
assert(a.name == "a", "name wasn't set properly")
|
65
|
+
assert(a.path == "", "path wasn't set properly")
|
66
|
+
assert(a.level == Logger.root.level, "didn't inherit root's level")
|
67
|
+
assert(a.parent == Logger.root)
|
68
|
+
a.level = WARN
|
69
|
+
b = Logger.new("a::b")
|
70
|
+
assert(b.name == "b", "name wasn't set properly")
|
71
|
+
assert(b.path == "a", "path wasn't set properly")
|
72
|
+
assert(b.level == a.level, "didn't inherit parent's level")
|
73
|
+
assert(b.parent == a, "parent wasn't what is expected")
|
74
|
+
c = Logger.new("a::b::c")
|
75
|
+
assert(Logger["a::b::c"] == c)
|
76
|
+
assert(c.name == "c", "name wasn't set properly")
|
77
|
+
assert(c.path == "a::b", "path wasn't set properly")
|
78
|
+
assert(c.level == b.level, "didn't inherit parent's level")
|
79
|
+
assert(c.parent == b, "parent wasn't what is expected")
|
80
|
+
d = Logger.new("a::d")
|
81
|
+
assert(Logger["a::d"] == d)
|
82
|
+
assert(d.name == "d", "name wasn't set properly")
|
83
|
+
assert(d.path == "a", "path wasn't set properly")
|
84
|
+
assert(d.level == a.level, "didn't inherit parent's level")
|
85
|
+
assert(d.parent == a, "parent wasn't what is expected")
|
86
|
+
assert_raise(ArgumentError) { Logger.new("::a") }
|
87
|
+
end
|
88
|
+
def test_undefined_parents
|
89
|
+
a = Logger.new 'has::no::real::parents::me'
|
90
|
+
assert(a.parent == Logger.root)
|
91
|
+
b = Logger.new 'has::no::real::parents::me::child'
|
92
|
+
assert(b.parent == a)
|
93
|
+
c = Logger.new 'has::no::real::parents::metoo'
|
94
|
+
assert(c.parent == Logger.root)
|
95
|
+
p = Logger.new 'has::no::real::parents'
|
96
|
+
assert(p.parent == Logger.root)
|
97
|
+
assert(a.parent == p)
|
98
|
+
assert(b.parent == a)
|
99
|
+
assert(c.parent == p)
|
100
|
+
Logger.each{|fullname, logger|
|
101
|
+
if logger != a and logger != c
|
102
|
+
assert(logger.parent != p)
|
103
|
+
end
|
104
|
+
}
|
105
|
+
end
|
106
|
+
def test_levels
|
107
|
+
l = Logger.new("levels", WARN)
|
108
|
+
assert(l.level == WARN, "level wasn't changed")
|
109
|
+
assert(l.fatal? == true)
|
110
|
+
assert(l.error? == true)
|
111
|
+
assert(l.warn? == true)
|
112
|
+
assert(l.info? == false)
|
113
|
+
assert(l.debug? == false)
|
114
|
+
l.debug "debug message should NOT show up"
|
115
|
+
l.info "info message should NOT show up"
|
116
|
+
l.warn "warn messge should show up. 3 total"
|
117
|
+
l.error "error messge should show up. 3 total"
|
118
|
+
l.fatal "fatal messge should show up. 3 total"
|
119
|
+
l.level = ERROR
|
120
|
+
assert(l.level == ERROR, "level wasn't changed")
|
121
|
+
assert(l.fatal? == true)
|
122
|
+
assert(l.error? == true)
|
123
|
+
assert(l.warn? == false)
|
124
|
+
assert(l.info? == false)
|
125
|
+
assert(l.debug? == false)
|
126
|
+
l.debug "debug message should NOT show up"
|
127
|
+
l.info "info message should NOT show up"
|
128
|
+
l.warn "warn messge should NOT show up."
|
129
|
+
l.error "error messge should show up. 2 total"
|
130
|
+
l.fatal "fatal messge should show up. 2 total"
|
131
|
+
l.level = WARN
|
132
|
+
end
|
133
|
+
def test_log_blocks
|
134
|
+
l = Logger.new 'logblocks'
|
135
|
+
l.level = WARN
|
136
|
+
l.add(Outputter.stdout)
|
137
|
+
assert_nothing_raised {
|
138
|
+
l.debug { puts "should not show up"; "LOGBLOCKS" }
|
139
|
+
l.fatal { puts "should show up"; "LOGBLOCKS" }
|
140
|
+
l.fatal { nil }
|
141
|
+
l.fatal {}
|
142
|
+
}
|
143
|
+
end
|
144
|
+
def test_heiarchial_logging
|
145
|
+
a = Logger.new("one")
|
146
|
+
a.add(StdoutOutputter.new 'so1')
|
147
|
+
b = Logger.new("one::two")
|
148
|
+
b.add(StdoutOutputter.new 'so2')
|
149
|
+
c = Logger.new("one::two::three")
|
150
|
+
c.add(StdoutOutputter.new 'so3')
|
151
|
+
d = Logger.new("one::two::three::four")
|
152
|
+
d.add(StdoutOutputter.new 'so4')
|
153
|
+
d.additive = false
|
154
|
+
e = Logger.new("one::two::three::four::five")
|
155
|
+
e.add(StdoutOutputter.new 'so5')
|
156
|
+
|
157
|
+
a.fatal "statement from a should show up once"
|
158
|
+
b.fatal "statement from b should show up twice"
|
159
|
+
c.fatal "statement from c should show up thrice"
|
160
|
+
d.fatal "statement from d should show up once"
|
161
|
+
e.fatal "statement from e should show up twice"
|
162
|
+
end
|
163
|
+
def test_multi_outs
|
164
|
+
f1 = FileOutputter.new('f1', :filename => "./junk/tmp1.log", :level=>ALL)
|
165
|
+
f2 = FileOutputter.new('f2', :filename => "./junk/tmp2.log", :level=>DEBUG)
|
166
|
+
f3 = FileOutputter.new('f3', :filename => "./junk/tmp3.log", :level=>ERROR)
|
167
|
+
f4 = FileOutputter.new('f4', :filename => "./junk/tmp4.log", :level=>FATAL)
|
168
|
+
|
169
|
+
l = Logger.new("multi")
|
170
|
+
l.add(f1, f3, f4)
|
171
|
+
|
172
|
+
a = Logger.new("multi::multi2")
|
173
|
+
a.level = ERROR
|
174
|
+
a.add(f2, f4)
|
175
|
+
|
176
|
+
l.debug "debug test_multi_outputters"
|
177
|
+
l.info "info test_multi_outputters"
|
178
|
+
l.warn "warn test_multi_outputters"
|
179
|
+
l.error "error test_multi_outputters"
|
180
|
+
l.fatal "fatal test_multi_outputters"
|
181
|
+
|
182
|
+
a.debug "debug test_multi_outputters"
|
183
|
+
a.info "info test_multi_outputters"
|
184
|
+
a.warn "warn test_multi_outputters"
|
185
|
+
a.error "error test_multi_outputters"
|
186
|
+
a.fatal "fatal test_multi_outputters"
|
187
|
+
|
188
|
+
f1.close; f2.close; f3.close; f4.close
|
189
|
+
end
|
190
|
+
def test_custom_formatter
|
191
|
+
l = Logger.new('custom_formatter')
|
192
|
+
o = StdoutOutputter.new('formatter'=>MyFormatter1.new)
|
193
|
+
l.add o
|
194
|
+
l.error "try myformatter1"
|
195
|
+
l.fatal "try myformatter1"
|
196
|
+
o.formatter = MyFormatter2.new
|
197
|
+
l.error "try formatter2"
|
198
|
+
l.fatal "try formatter2"
|
199
|
+
end
|
200
|
+
end
|
@@ -0,0 +1,143 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
require 'test_helper'
|
3
|
+
|
4
|
+
class TestOutputter < TestCase
|
5
|
+
include Log4r
|
6
|
+
|
7
|
+
def test_validation
|
8
|
+
assert_raise(ArgumentError) { Outputter.new }
|
9
|
+
assert_raise(ArgumentError) { Outputter.new 'fonda', :level=>-10}
|
10
|
+
assert_raise(TypeError) { Outputter.new 'fonda', :formatter=>-10}
|
11
|
+
end
|
12
|
+
def test_io
|
13
|
+
assert_nothing_raised {
|
14
|
+
IOOutputter.new('foo3', $stdout)
|
15
|
+
IOOutputter.new('foo4', $stderr)
|
16
|
+
}
|
17
|
+
f = File.new("junk/tmpx.log", "w")
|
18
|
+
o = IOOutputter.new('asdf', f)
|
19
|
+
o.close
|
20
|
+
assert(f.closed? == true)
|
21
|
+
assert(o.level == OFF)
|
22
|
+
end
|
23
|
+
def test_repository
|
24
|
+
assert( Outputter['foo3'].class == IOOutputter )
|
25
|
+
assert( Outputter['foo4'].class == IOOutputter )
|
26
|
+
assert( Outputter['asdf'].class == IOOutputter )
|
27
|
+
end
|
28
|
+
def test_validation_and_creation
|
29
|
+
assert_nothing_raised {
|
30
|
+
StdoutOutputter.new('out', 'level'=>DEBUG)
|
31
|
+
FileOutputter.new('file', 'filename'=>'junk/test', :trunc=>true)
|
32
|
+
}
|
33
|
+
a = StdoutOutputter.new 'out2'
|
34
|
+
assert(a.level == Logger.root.level)
|
35
|
+
assert(a.formatter.class == DefaultFormatter)
|
36
|
+
b = StdoutOutputter.new('ook', :level => DEBUG, :formatter => Formatter)
|
37
|
+
assert(b.level == DEBUG)
|
38
|
+
assert(b.formatter.class == Formatter)
|
39
|
+
c = StdoutOutputter.new('akk', :formatter => Formatter)
|
40
|
+
assert(c.level == Logger.root.level)
|
41
|
+
assert(c.formatter.class == Formatter)
|
42
|
+
c = StderrOutputter.new('iikk', :level => OFF)
|
43
|
+
assert(c.level == OFF)
|
44
|
+
assert(c.formatter.class == DefaultFormatter)
|
45
|
+
o = StderrOutputter.new 'ik'
|
46
|
+
assert_nothing_raised(TypeError) { o.formatter = DefaultFormatter }
|
47
|
+
assert(o.formatter.class == DefaultFormatter)
|
48
|
+
end
|
49
|
+
# test the resource= bounds
|
50
|
+
def test_boundaries
|
51
|
+
o = StderrOutputter.new('ak', :formatter => Formatter)
|
52
|
+
assert_raise(TypeError) { o.formatter = nil }
|
53
|
+
assert_raise(TypeError) { o.formatter = String }
|
54
|
+
assert_raise(TypeError) { o.formatter = "bogus" }
|
55
|
+
assert_raise(TypeError) { o.formatter = -3 }
|
56
|
+
# the formatter should be preserved
|
57
|
+
assert(o.formatter.class == Formatter)
|
58
|
+
end
|
59
|
+
def test_file
|
60
|
+
assert_raise(TypeError) { FileOutputter.new 'f' }
|
61
|
+
assert_raise(TypeError) { FileOutputter.new('fa', :filename => DEBUG) }
|
62
|
+
assert_raise(TypeError) { FileOutputter.new('fo', :filename => nil) }
|
63
|
+
assert_nothing_raised {
|
64
|
+
FileOutputter.new('fi', :filename => './junk/tmp')
|
65
|
+
FileOutputter.new('fum', :filename=>'./junk/tmp', :trunc => "true")
|
66
|
+
}
|
67
|
+
fo = FileOutputter.new('food', :filename => './junk/tmp', :trunc => false)
|
68
|
+
assert(fo.trunc == false)
|
69
|
+
assert(fo.filename == './junk/tmp')
|
70
|
+
assert(fo.closed? == false)
|
71
|
+
fo.close
|
72
|
+
assert(fo.closed? == true)
|
73
|
+
assert(fo.level == OFF)
|
74
|
+
end
|
75
|
+
# test the dynamic definition of outputter log messages
|
76
|
+
def test_log_methods
|
77
|
+
o = StderrOutputter.new('so1', :level => WARN )
|
78
|
+
# test to see if all of the methods are defined
|
79
|
+
for mname in LNAMES
|
80
|
+
next if mname == 'OFF' || mname == 'ALL'
|
81
|
+
assert_respond_to(o, mname.downcase.to_sym, "Test respond to #{mname.to_s}")
|
82
|
+
end
|
83
|
+
return # cuz the rest is borked
|
84
|
+
# we rely on BasicFormatter's inability to reference a nil Logger to test
|
85
|
+
# the log methods. Everything from WARN to FATAL should choke.
|
86
|
+
event = LogEvent.new(nil, nil, nil, nil)
|
87
|
+
assert_nothing_raised { o.debug event }
|
88
|
+
assert_nothing_raised { o.info event }
|
89
|
+
assert_raise(NameError) { o.warn event }
|
90
|
+
assert_raise(NameError) { o.error event }
|
91
|
+
assert_raise(NameError) { o.fatal event }
|
92
|
+
# now let's dynamically change the level and repeat
|
93
|
+
o.level = ERROR
|
94
|
+
assert_nothing_raised { o.debug event}
|
95
|
+
assert_nothing_raised { o.info event}
|
96
|
+
assert_nothing_raised { o.warn event}
|
97
|
+
assert_raise(NameError) { o.error event}
|
98
|
+
assert_raise(NameError) { o.fatal event}
|
99
|
+
end
|
100
|
+
def test_only_at_validation
|
101
|
+
o = StdoutOutputter.new 'so2'
|
102
|
+
assert_raise(ArgumentError) { o.only_at }
|
103
|
+
assert_raise(ArgumentError) { o.only_at ALL }
|
104
|
+
assert_raise(TypeError) { o.only_at OFF }
|
105
|
+
assert_nothing_raised { o.only_at DEBUG, ERROR }
|
106
|
+
return # cuz the rest is borked
|
107
|
+
# test the methods as before
|
108
|
+
event = LogEvent.new(nil,nil,nil,nil)
|
109
|
+
assert_raise(NameError) { o.debug event}
|
110
|
+
assert_raise(NameError) { o.error event}
|
111
|
+
assert_nothing_raised { o.warn event}
|
112
|
+
assert_nothing_raised { o.info event}
|
113
|
+
assert_nothing_raised { o.fatal event}
|
114
|
+
end
|
115
|
+
if defined?( Encoding )
|
116
|
+
# tests that files are opened in binary mode
|
117
|
+
def test_file_encoding
|
118
|
+
Encoding.default_internal = Encoding::UTF_8
|
119
|
+
File.open( './junk/tmp2', 'w' ) { |f| f.write( 'scheiß encoding' ) }
|
120
|
+
fenc = FileOutputter.new('fenc', :filename => './junk/tmp2')
|
121
|
+
event = LogEvent.new(1, Logger.root, nil, 'scheiß encoding'.force_encoding('ASCII-8BIT'))
|
122
|
+
assert_nothing_raised(Encoding::UndefinedConversionError) do
|
123
|
+
fenc.debug event
|
124
|
+
end
|
125
|
+
end
|
126
|
+
end
|
127
|
+
def broken_test_threading
|
128
|
+
class << self
|
129
|
+
def log_work
|
130
|
+
o = StdoutOutputter.new 'so2'
|
131
|
+
assert_nothing_raised { o.only_at DEBUG, ERROR }
|
132
|
+
Thread.current().exit()
|
133
|
+
end
|
134
|
+
def log_thread_start
|
135
|
+
t = Thread.new(log_work)
|
136
|
+
t.join
|
137
|
+
end
|
138
|
+
end
|
139
|
+
|
140
|
+
ts = Thread.new(log_thread_start)
|
141
|
+
ts.join
|
142
|
+
end
|
143
|
+
end
|
@@ -0,0 +1,76 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
class TestPatternFormatter < TestCase
|
4
|
+
include Log4r
|
5
|
+
|
6
|
+
def test_pattern
|
7
|
+
l = Logger.new 'test::this::that'
|
8
|
+
l.trace = true
|
9
|
+
o = StdoutOutputter.new 'test'
|
10
|
+
l.add o
|
11
|
+
assert_nothing_raised {
|
12
|
+
f = PatternFormatter.new :pattern=> "'%t' T-'%T' %d %6l [%C]%c %% %-40.30M"
|
13
|
+
#:date_pattern=> "%Y"
|
14
|
+
#:date_method => :usec
|
15
|
+
Outputter['test'].formatter = f
|
16
|
+
l.debug "And this?"
|
17
|
+
l.info "How's this?"
|
18
|
+
l.error "and a really freaking huge line which we hope will be trimmed?"
|
19
|
+
e = ArgumentError.new("something barfed")
|
20
|
+
e.set_backtrace Array.new(5, "trace junk at thisfile.rb 154")
|
21
|
+
l.fatal e
|
22
|
+
l.info [1, 3, 5]
|
23
|
+
}
|
24
|
+
end
|
25
|
+
|
26
|
+
def test_ndc
|
27
|
+
l = Logger.new 'test::this::that::other'
|
28
|
+
l.trace = true
|
29
|
+
o = StdoutOutputter.new 'testy'
|
30
|
+
l.add o
|
31
|
+
f = PatternFormatter.new :pattern=> "%d %6l [%C]%c {%x} %% %-40.30M"
|
32
|
+
#:date_pattern=> "%Y"
|
33
|
+
#:date_method => :usec
|
34
|
+
Outputter['testy'].formatter = f
|
35
|
+
|
36
|
+
l.info "no NDC"
|
37
|
+
NDC.push("start")
|
38
|
+
l.info "start NDC"
|
39
|
+
NDC.push("finish")
|
40
|
+
l.info "start finish NDC"
|
41
|
+
NDC.pop()
|
42
|
+
l.info "start NDC"
|
43
|
+
NDC.remove()
|
44
|
+
l.info "no NDC"
|
45
|
+
end
|
46
|
+
|
47
|
+
def test_gdc
|
48
|
+
l = Logger.new 'test::this::that::other'
|
49
|
+
l.trace = true
|
50
|
+
o = StdoutOutputter.new 'testy'
|
51
|
+
l.add o
|
52
|
+
f = PatternFormatter.new :pattern=> "%d %6l [%C]%c {%g} %% %-40.30M"
|
53
|
+
#:date_pattern=> "%Y"
|
54
|
+
#:date_method => :usec
|
55
|
+
Outputter['testy'].formatter = f
|
56
|
+
|
57
|
+
l.info "GDC default"
|
58
|
+
GDC.set("non-default")
|
59
|
+
l.info "GDC non-default"
|
60
|
+
end
|
61
|
+
|
62
|
+
def test_mdc
|
63
|
+
l = Logger.new 'test::this::that::other'
|
64
|
+
l.trace = true
|
65
|
+
o = StdoutOutputter.new 'testy'
|
66
|
+
l.add o
|
67
|
+
f = PatternFormatter.new :pattern=> "%d %6l [%C]%c {%X{user}} %% %-40.30M"
|
68
|
+
#:date_pattern=> "%Y"
|
69
|
+
#:date_method => :usec
|
70
|
+
Outputter['testy'].formatter = f
|
71
|
+
|
72
|
+
l.info "no user"
|
73
|
+
MDC.put("user","colbygk")
|
74
|
+
l.info "user colbygk"
|
75
|
+
end
|
76
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
# $Id$
|
2
|
+
# Test guts sent in by chetreddy bug #27184
|
3
|
+
#
|
4
|
+
# Note: this test won't always catch a threading problem, as it
|
5
|
+
# relies on a brute force approach. NUM_THREADS can be increased
|
6
|
+
# to stress the system longer and therefore increasing the chance
|
7
|
+
# of exposing a threading issue, however, it is not a definitive
|
8
|
+
# test.
|
9
|
+
#
|
10
|
+
|
11
|
+
require 'test_helper'
|
12
|
+
|
13
|
+
class TestThreads < TestCase
|
14
|
+
include Log4r
|
15
|
+
|
16
|
+
NUMTHREADS = 1000
|
17
|
+
|
18
|
+
def test_threads
|
19
|
+
|
20
|
+
assert_nothing_raised do
|
21
|
+
(0..NUMTHREADS).map do |i|
|
22
|
+
Thread.new do
|
23
|
+
Thread.current[:logger] = Log4r::Logger.new "Hello #{i}"
|
24
|
+
Thread.current[:logger].outputters = [StdoutOutputter.new("log4r#{i}")]
|
25
|
+
Thread.current[:logger].outputters.each { |j| j.flush }
|
26
|
+
Thread.current.exit()
|
27
|
+
end
|
28
|
+
end.each do |thr| thr.join end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,48 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
One=<<-EOX
|
4
|
+
<log4r_config><pre_config><custom_levels> Foo </custom_levels>
|
5
|
+
</pre_config></log4r_config>
|
6
|
+
EOX
|
7
|
+
Two=<<-EOX
|
8
|
+
<log4r_config><pre_config><global level="DEBUG"/></pre_config></log4r_config>
|
9
|
+
EOX
|
10
|
+
Three=<<-EOX
|
11
|
+
<log4r_config><pre_config><custom_levels>Foo</custom_levels>
|
12
|
+
<global level="Foo"/></pre_config>
|
13
|
+
</log4r_config>
|
14
|
+
EOX
|
15
|
+
|
16
|
+
# must be run independently
|
17
|
+
class TestXmlConf < TestCase
|
18
|
+
include Log4r
|
19
|
+
|
20
|
+
def test_load1
|
21
|
+
Configurator.load_xml_string(One)
|
22
|
+
assert_nothing_raised{
|
23
|
+
assert(Foo == 1)
|
24
|
+
assert(Logger.global.level == ALL)
|
25
|
+
}
|
26
|
+
end
|
27
|
+
def test_load2
|
28
|
+
Configurator.load_xml_string(Two)
|
29
|
+
assert_nothing_raised{
|
30
|
+
assert(Logger.global.level == DEBUG)
|
31
|
+
}
|
32
|
+
end
|
33
|
+
def test_load3
|
34
|
+
Configurator.load_xml_string(Three)
|
35
|
+
assert_nothing_raised{
|
36
|
+
assert(Foo == 1)
|
37
|
+
assert(Logger.global.level == Foo)
|
38
|
+
}
|
39
|
+
end
|
40
|
+
def test_load4
|
41
|
+
assert_nothing_raised {
|
42
|
+
Configurator['logpath'] = '.'
|
43
|
+
Configurator.load_xml_file "testconf.xml"
|
44
|
+
a = Logger['first::second']
|
45
|
+
a.bing "what the heck"
|
46
|
+
}
|
47
|
+
end
|
48
|
+
end
|
data/tests/testyaml.rb
ADDED
@@ -0,0 +1,39 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
# Define a custom outputter that allows arrays in configuration hash
|
4
|
+
module Log4r
|
5
|
+
class TestYamlOutputter < Outputter
|
6
|
+
# expose array parameter
|
7
|
+
attr_reader :array_param
|
8
|
+
|
9
|
+
def initialize(name, hash = {})
|
10
|
+
@array_param = hash['array_param']
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
|
16
|
+
class TestYaml < TestCase
|
17
|
+
include Log4r
|
18
|
+
|
19
|
+
def setup
|
20
|
+
@cfg = YamlConfigurator # shorthand
|
21
|
+
@cfg['CUSTOM_DOMAIN'] = 'bar.com'
|
22
|
+
end
|
23
|
+
|
24
|
+
def test_injection
|
25
|
+
assert_nothing_raised("Exception injected") do
|
26
|
+
@cfg.load_yaml_file(File.join(File.dirname(__FILE__),'testyaml_injection.yaml'))
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
def test_arrays
|
31
|
+
assert_nothing_raised("Parser couldn't handle arrays in YAML") do
|
32
|
+
@cfg.load_yaml_file(File.join(File.dirname(__FILE__),'testyaml_arrays.yaml'))
|
33
|
+
end
|
34
|
+
log = Logger['mylogger']
|
35
|
+
assert_instance_of(Array, log.outputters.first.array_param, 'Array not loaded properly from YAML')
|
36
|
+
assert_equal('wilma@bar.com', log.outputters.first.array_param[2], '#{}-style parameter interpolation doesn\'t work properly in arrays')
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
@@ -0,0 +1,25 @@
|
|
1
|
+
log4r_config:
|
2
|
+
|
3
|
+
# define all loggers ...
|
4
|
+
loggers:
|
5
|
+
- name : mylogger
|
6
|
+
level : INFO
|
7
|
+
additive : 'false'
|
8
|
+
trace : 'false'
|
9
|
+
outputters:
|
10
|
+
- testyaml
|
11
|
+
|
12
|
+
# define all outputters (incl. formatters)
|
13
|
+
outputters:
|
14
|
+
- type : TestYamlOutputter
|
15
|
+
name : testyaml
|
16
|
+
level : INFO
|
17
|
+
array_param:
|
18
|
+
- fred@foo.com
|
19
|
+
- barney@foo.com
|
20
|
+
- 'wilma@#{CUSTOM_DOMAIN}'
|
21
|
+
formatter:
|
22
|
+
date_pattern: '%y%m%d %H:%M:%S'
|
23
|
+
pattern : '%d %l: %m '
|
24
|
+
type : PatternFormatter
|
25
|
+
|
@@ -0,0 +1,22 @@
|
|
1
|
+
log4r_config:
|
2
|
+
|
3
|
+
# define all loggers ...
|
4
|
+
loggers:
|
5
|
+
- name : mylogger
|
6
|
+
level : INFO
|
7
|
+
additive : 'false'
|
8
|
+
trace : 'false'
|
9
|
+
outputters:
|
10
|
+
- stderr
|
11
|
+
|
12
|
+
# define all outputters (incl. formatters)
|
13
|
+
outputters:
|
14
|
+
- type : StderrOutputter
|
15
|
+
name : stderr
|
16
|
+
level : INFO
|
17
|
+
crash : "'; raise Exception #"
|
18
|
+
formatter:
|
19
|
+
date_pattern: '%y%m%d %H:%M:%S'
|
20
|
+
pattern : '%d %l: %m '
|
21
|
+
type : PatternFormatter
|
22
|
+
|