6 use Log::Contextual qw{:log with_logger set_logger};
7 use Test::More qw(no_plan);
8 my $var_logger1 = VarLogger->new;
9 my $var_logger2 = VarLogger->new;
10 my $var_logger3 = VarLogger->new;
13 with_logger sub { $var_logger2 } => sub {
15 with_logger $var_logger1 => sub {
16 log_debug { 'nothing!' }
18 log_debug { 'frew!' };
22 is( $var_logger1->var, 'dnothing!', 'inner scoped logger works' );
23 is( $var_logger2->var, 'dfrew!', 'outer scoped logger works' );
27 set_logger(sub { $var_logger3 });
28 log_debug { 'set_logger' };
29 is( $var_logger3->var, 'dset_logger', 'set logger works' );
33 with_logger $var_logger1 => sub {
34 log_debug { 'nothing again!' }
37 is( $var_logger1->var, 'dnothing again!',
38 'inner scoped logger works after using set_logger'
41 log_debug { 'frioux!' };
42 is( $var_logger3->var, 'dfrioux!',
43 q{set_logger's logger comes back after scoped logger}
47 ok(!eval { Log::Contextual->import; 1 }, 'Blank Log::Contextual import dies');