File: alien_build_log.t

package info (click to toggle)
libalien-build-perl 2.84-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,116 kB
  • sloc: perl: 10,350; ansic: 134; sh: 66; makefile: 2
file content (101 lines) | stat: -rw-r--r-- 2,145 bytes parent folder | download
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;