|
19 | 19 | org.jruby.rack.servlet.DefaultServletRackContext.new(rack_config) |
20 | 20 | end |
21 | 21 |
|
| 22 | + let(:level) { org.jruby.rack.RackLogger::Level } |
| 23 | + |
| 24 | + let(:logger) { JRuby::Rack::Logger.new real_logger } |
| 25 | + |
22 | 26 | before { JRuby::Rack.context = rack_context } |
23 | 27 | after { JRuby::Rack.context = nil } |
24 | 28 |
|
25 | 29 | it 'works with a servlet context' do |
26 | | - logger = JRuby::Rack::Logger.new real_logger |
27 | 30 | logger.debug? |
28 | 31 | logger.debug 'hogy basza meg a zold tucsok!' |
29 | 32 | expect( real_logger.logged_content ).to match /^DEBUG.*hogy .* a zold tucsok!$/ |
30 | 33 | end |
31 | 34 |
|
| 35 | + it 'delegates to passed logger instance' do |
| 36 | + logger.debug 'debugging' |
| 37 | + expect( real_logger.logged_content ).to match /^DEBUG.*debugging$/ |
| 38 | + real_logger.reset |
| 39 | + logger.info 'infooo' |
| 40 | + expect( real_logger.logged_content ).to match /^INFO.*infooo$/ |
| 41 | + real_logger.reset |
| 42 | + logger.warn 'warning' |
| 43 | + expect( real_logger.logged_content ).to match /^WARN.*warning$/ |
| 44 | + real_logger.reset |
| 45 | + logger.error 'errored' |
| 46 | + expect( real_logger.logged_content ).to match /^ERROR.*errored$/ |
| 47 | + real_logger.reset |
| 48 | + logger.fatal 'totaal!' |
| 49 | + expect( real_logger.logged_content ).to match /^FATAL.*totaal!$/ |
| 50 | + end |
| 51 | + |
| 52 | + it 'uses JRuby::Rack.context when no initialize argument' do |
| 53 | + logger = JRuby::Rack::Logger.new |
| 54 | + logger.debug? |
| 55 | + logger.debug 'hogy basza meg a zold tucsok!' |
| 56 | + expect( logger.real_logger ).to be rack_context |
| 57 | + end |
| 58 | + |
| 59 | + it 'delegates level check (when level is not set)' do |
| 60 | + real_logger.level = level::INFO |
| 61 | + expect( logger.debug? ).to be false |
| 62 | + expect( logger.info? ).to be true |
| 63 | + real_logger.level = level::WARN |
| 64 | + expect( logger.info? ).to be false |
| 65 | + end |
| 66 | + |
| 67 | + it 'uses level check when level is explicitly set' do |
| 68 | + real_logger.level = level::INFO |
| 69 | + logger.level = 2 # Logger.::WARN |
| 70 | + expect( logger.info? ).to be false |
| 71 | + expect( logger.warn? ).to be true |
| 72 | + logger.level = nil |
| 73 | + expect( logger.info? ).to be true |
| 74 | + end |
| 75 | + |
| 76 | + it "combines level check with delegate's level" do |
| 77 | + real_logger.level = level::WARN |
| 78 | + logger.level = 1 # Logger.::INFO |
| 79 | + expect( logger.debug? ).to be false |
| 80 | + expect( logger.info? ).to be false |
| 81 | + expect( logger.warn? ).to be true |
| 82 | + logger.level = nil |
| 83 | + expect( logger.info? ).to be false |
| 84 | + expect( logger.debug? ).to be false |
| 85 | + expect( logger.warn? ).to be true |
| 86 | + end |
| 87 | + |
| 88 | + it "disables real logger's formatting when formatter is set" do |
| 89 | + real_logger.formatting = true |
| 90 | + expect( real_logger.formatting? ).to be true |
| 91 | + |
| 92 | + logger.formatter = Proc.new { |severity, timestamp, progname, msg| "#{severity[0, 1]} #{msg}" } |
| 93 | + logger.warn 'hogy basza meg a zold tucsok!' |
| 94 | + expect( real_logger.logged_content ).to eql "W hogy basza meg a zold tucsok!\n" |
| 95 | + |
| 96 | + expect( real_logger.formatting? ).to be false |
| 97 | + end |
| 98 | + |
| 99 | +# it 'handles constant resolution (for Rails compatibility)' do |
| 100 | +# expect( logger.class::DEBUG ).to eql 0 |
| 101 | +# expect( logger.class::FATAL ).to eql 4 |
| 102 | +# end |
| 103 | + |
32 | 104 | describe JRuby::Rack::ServletLog do |
33 | 105 |
|
34 | 106 | it "writes messages to the servlet context" do |
|
0 commit comments