File: 017-handler-special-levels.t

package info (click to toggle)
liblog-handler-perl 0.45-1%2Blenny1
  • links: PTS, VCS
  • area: main
  • in suites: lenny
  • size: 392 kB
  • ctags: 145
  • sloc: perl: 2,017; makefile: 39
file content (69 lines) | stat: -rw-r--r-- 1,204 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
use strict;
use warnings;
use Test::More tests => 23;
use Log::Handler;

my $MESSAGES = 13;
my $RECEIVED = 0;
my %LEVELS   = (
    DEBUG     =>  1,
    INFO      =>  1,
    NOTICE    =>  1,
    WARNING   =>  2,
    ERROR     =>  2,
    CRITICAL  =>  2,
    ALERT     =>  1,
    EMERGENCY =>  2,
    FATAL     =>  1,
);
my @LEVELS = (qw/
    debug
    info
    notice
    warning
    warn
    error
    err
    critical
    crit
    alert
    emergency
    emerg
    fatal
/);

sub forward {
    my $m = shift;
    if ($m->{message} =~ /([A-Z]+) foo/) {
        my $level = $1;
        if (exists $LEVELS{$level}) {
            $LEVELS{$level}--;
        }
        $RECEIVED++;
    }
}

my $log = Log::Handler->new();

$log->add(
    forward => {
        maxlevel => 'debug',
        forward_to => \&forward,
        message_layout => '%L %m',
    }
);

# die
foreach my $level (@LEVELS) {
    my $ul = uc($level);
    eval { $log->die($level => 'foo') };
    ok($@ =~ /foo/, "test die $level");
}

# count messages
ok($RECEIVED == $MESSAGES, "count messages ($RECEIVED:$MESSAGES)");

# got all messages?
while ( my ($level, $count) = each %LEVELS ) {
    ok($count == 0, "test level $level ($count)");
}