summaryrefslogtreecommitdiff
path: root/t/031NDC.t
diff options
context:
space:
mode:
Diffstat (limited to 't/031NDC.t')
-rw-r--r--t/031NDC.t105
1 files changed, 105 insertions, 0 deletions
diff --git a/t/031NDC.t b/t/031NDC.t
new file mode 100644
index 0000000..db8dbc3
--- /dev/null
+++ b/t/031NDC.t
@@ -0,0 +1,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");