File: 03inheritance.t

package info (click to toggle)
libmoosex-log-log4perl-perl 0.47-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 252 kB
  • sloc: perl: 2,087; makefile: 4
file content (68 lines) | stat: -rw-r--r-- 1,455 bytes parent folder | download | duplicates (2)
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
use strict;
use warnings;

use IO::Scalar;
use Log::Log4perl;

use Test::More tests => 3;

BEGIN {
	my $cfg = <<__ENDCFG__;
log4perl.rootLogger = TRACE, Console

log4perl.appender.Console        = Log::Log4perl::Appender::Screen
log4perl.appender.Console.stderr = 1
log4perl.appender.Console.layout = Log::Log4perl::Layout::PatternLayout
log4perl.appender.Console.layout.ConversionPattern = %p [%c] [%M] %m%n
__ENDCFG__
	Log::Log4perl->init(\$cfg);
}

{
	package Parent;

	use Moo;
	with 'MooseX::Log::Log4perl';

	sub overridden { shift->log->warn('Parent overridden');	}
	sub parentonly { shift->log->warn('Parent parentonly'); }
}

{
	package Child;

	use Moo;
	extends 'Parent';
	with 'MooseX::Log::Log4perl';

	sub overridden { shift->log->warn('Child overridden');	}
}

{
	my $p = Parent->new();
	isa_ok( $p, 'Parent' );
	my $c = Child->new();
	isa_ok( $c, 'Child' );

	tie *STDERR, 'IO::Scalar', \my $err;
	local $SIG{__DIE__} = sub { untie *STDERR; die @_ };

	$p->overridden;
	$c->overridden;
	$p->parentonly;
	$c->parentonly;

	untie *STDERR;

	# Cleanup log output line-endings
	$err =~ s/\r\n/\n/gm;

	my $expect = <<__ENDLOG__;
WARN [Parent] [Parent::overridden] Parent overridden
WARN [Child] [Child::overridden] Child overridden
WARN [Parent] [Parent::parentonly] Parent parentonly
WARN [Child] [Parent::parentonly] Parent parentonly
__ENDLOG__

	is( $err, $expect, "Log messages for overridden and non-overridden methods are correct" );
}