POD
[p5sagit/Log-Contextual.git] / t / log.t
CommitLineData
7cec609c 1use strict;
2use warnings;
3
c19d7bee 4use lib 't/lib';
5use VarLogger;
7cec609c 6use Log::Contextual;
7use Test::More qw(no_plan);
c19d7bee 8my $var_logger1 = VarLogger->new;
9my $var_logger2 = VarLogger->new;
10my $var_logger3 = VarLogger->new;
7cec609c 11
c19d7bee 12WITHLOGGER: {
13 with_logger {
7cec609c 14
c19d7bee 15 with_logger {
16 log_debug { 'nothing!' }
17 } sub { $var_logger1 };
18 log_debug { 'frew!' };
2033c911 19
c19d7bee 20 } sub { $var_logger2 };
2033c911 21
c19d7bee 22 is( $var_logger1->var, 'nothing!', 'inner scoped logger works' );
23 is( $var_logger2->var, 'frew!', 'outer scoped logger works' );
24}
25
26SETLOGGER: {
27 set_logger(sub { $var_logger3 });
28 log_debug { 'set_logger' };
29 is( $var_logger3->var, 'set_logger', 'set logger works' );
30}
31
32SETWITHLOGGER: {
33 with_logger {
34 log_debug { 'nothing again!' }
35 } sub { $var_logger1 };
36
37 is( $var_logger1->var, 'nothing again!',
38 'inner scoped logger works after using set_logger'
39 );
40
41 log_debug { 'frioux!' };
42 is( $var_logger3->var, 'frioux!',
43 q{set_logger's logger comes back after scoped logger}
44 );
2033c911 45}