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
|
use 5.008004;
use Test2::V0 -no_srand => 1;
use Alien::Build;
use Alien::Build::Log;
delete $ENV{ALIEN_BUILD_LOG};
subtest constructors => sub {
subtest 'basic' => sub {
eval { Alien::Build::Log->new };
like $@, qr/Cannot instantiate base class/;
my $log = Alien::Build::Log->default;
isa_ok $log, 'Alien::Build::Log';
isa_ok $log, 'Alien::Build::Log::Default';
undef $log;
Alien::Build::Log->set_log_class('Alien::Build::Log::Bogus');
eval { Alien::Build::Log->default };
like $@, qr/Can't locate Alien\/Build\/Log\/Bogus\.pm/;
};
subtest 'override with set_log_class' => sub {
our $roger;
{ package
Alien::Build::Log::Roger;
use parent qw( Alien::Build::Log );
sub log {
my (undef, %opt) = @_;
$main::roger = \%opt;
}
}
Alien::Build::Log->set_log_class('Alien::Build::Log::Roger');
isa_ok(Alien::Build::Log->default, 'Alien::Build::Log');
isa_ok(Alien::Build::Log->default, 'Alien::Build::Log::Roger');
Alien::Build->log("hello"); my $line = __LINE__;
is(
$roger,
hash {
field caller => array {
item 'main';
item __FILE__;
item $line;
};
field message => 'hello';
end;
},
'message sent to log method'
);
};
subtest 'override with environment' => sub {
our $dodger;
{ package
Alien::Build::Log::Dodger;
use parent qw( Alien::Build::Log );
sub log {
my (undef, %opt) = @_;
$main::dodger = \%opt;
}
}
Alien::Build::Log->set_log_class(undef);
$ENV{ALIEN_BUILD_LOG} = 'Alien::Build::Log::Dodger';
isa_ok(Alien::Build::Log->default, 'Alien::Build::Log');
isa_ok(Alien::Build::Log->default, 'Alien::Build::Log::Dodger');
Alien::Build->log("hello"); my $line = __LINE__;
is(
$dodger,
hash {
field caller => array {
item 'main';
item __FILE__;
item $line;
};
field message => 'hello';
end;
},
'message sent to log method'
);
};
};
done_testing;
|