summaryrefslogtreecommitdiff
path: root/t/031NDC.t
blob: db8dbc3139fe09c0345e55cab7c6f93e55b22ec7 (plain)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
###########################################
# Test Suite Log::Log4perl::NDC
# Mike Schilli, 2002 (m@perlmeister.com)
###########################################

BEGIN { 
    if($ENV{INTERNAL_DEBUG}) {
        require Log::Log4perl::InternalDebug;
        Log::Log4perl::InternalDebug->enable();
    }
}

use warnings;
use strict;

use Test;

use Log::Log4perl qw(get_logger);
use Log::Log4perl::Level;
use Log::Log4perl::Appender::TestBuffer;
use Log::Log4perl::NDC;
use Log::Log4perl::MDC;

BEGIN { plan tests => 3 }

# Have TestBuffer log the Log::Dispatch priority
Log::Log4perl::Appender::TestBuffer->reset();

my $conf = <<EOT;
log4perl.logger   = ALL, BUF0
log4perl.appender.BUF0           = Log::Log4perl::Appender::TestBuffer
log4perl.appender.BUF0.layout    = Log::Log4perl::Layout::PatternLayout
log4perl.appender.BUF0.layout.ConversionPattern = %m <%x>
EOT

Log::Log4perl::init(\$conf);

my $app0 = Log::Log4perl::Appender::TestBuffer->by_name("BUF0");

my $loga = get_logger("a");

Log::Log4perl::NDC->push("first");
$loga->debug("debug");

    # Push more than MAX
Log::Log4perl::NDC->push("second");
Log::Log4perl::NDC->push("third");
Log::Log4perl::NDC->push("fourth");
Log::Log4perl::NDC->push("fifth");
Log::Log4perl::NDC->push("sixth");
$loga->info("info");

    # Delete NDC stack
Log::Log4perl::NDC->remove();
$loga->warn("warn");

Log::Log4perl::NDC->push("seventh");
$loga->error("error");

ok($app0->buffer(), 
   "debug <first>info <first second third fourth sixth>warn <[undef]>error <seventh>");

Log::Log4perl::Appender::TestBuffer->reset();

Log::Log4perl::MDC->put("remote_host", "blah-host");
Log::Log4perl::MDC->put("ip", "blah-ip");

$conf = <<EOT;
log4perl.logger   = ALL, BUF1
log4perl.appender.BUF1           = Log::Log4perl::Appender::TestBuffer
log4perl.appender.BUF1.layout    = Log::Log4perl::Layout::PatternLayout
log4perl.appender.BUF1.layout.ConversionPattern = %X{remote_host}: %m %X{ip}%n
EOT

Log::Log4perl::init(\$conf);

my $app1 = Log::Log4perl::Appender::TestBuffer->by_name("BUF1");

my $logb = get_logger("b");

$logb->debug("testmessage");

ok($app1->buffer(), 
   "blah-host: testmessage blah-ip\n");

# Check what happens if %X is used with an undef value
Log::Log4perl::Appender::TestBuffer->reset();

$conf = <<EOT;
log4perl.logger   = ALL, BUF1
log4perl.appender.BUF1           = Log::Log4perl::Appender::TestBuffer
log4perl.appender.BUF1.layout    = Log::Log4perl::Layout::PatternLayout
log4perl.appender.BUF1.layout.ConversionPattern = %X{quack}: %m %X{ip}%n
EOT

Log::Log4perl::init(\$conf);

$app1 = Log::Log4perl::Appender::TestBuffer->by_name("BUF1");

$logb = get_logger("b");

$logb->debug("testmessage");

ok($app1->buffer(), 
   "[undef]: testmessage blah-ip\n");